1 |
This directory contains some very simple macros, just to show how to use the PamLevel2 class. |
2 |
The macros need as input the name of a Level2 .root file produced by DarthVader |
3 |
(example1 and example2) or a list of files (see example3). |
4 |
|
5 |
example1 - Example to integrate all detector info and solve the y-view tracks ambiguity |
6 |
example2 - Example to get pamela tracks and integrate the trajectory in the apparatus |
7 |
example3 - Example to loop over events, reading more than one file |
8 |
Loop - Example to loop over events, apply some selection cuts (My-Selection.cpp) and filling an |
9 |
output file with histograms (My-Histos.cpp) and/or trees. |
10 |
|
11 |
In order to run the scripts: |
12 |
|
13 |
1) Copy the magnetic field maps into the magnetic-field/ directory. |
14 |
You can find them in the CVS repository, inside DarthVader/param/trk-param/field_param-0/ |
15 |
|
16 |
2) Add the path of the directory containing the DarthVader libraries and the PamLevel2 library to the |
17 |
shell variable LD_LIBRARY_PATH |
18 |
|
19 |
3) Open a root session and execute the following commands: |
20 |
|
21 |
[] .x load.C |
22 |
[] .L example1.C |
23 |
[] example1("level2-data-path/level2-file, execute the command.root") |
24 |
Tracker : set branch address TrkLevel2 |
25 |
Calorimeter : set branch address CaloLevel2 |
26 |
ToF : set branch address ToFLevel2 |
27 |
Trigger : set branch address TrigLevel2 |
28 |
S4 : set branch address S4Level2 |
29 |
NeutronD : set branch address NDLevel2 |
30 |
Anticounter : set branch address AcLevel2 |
31 |
|
32 |
Start loop over events |
33 |
|
34 |
Done |
35 |
|
36 |
4) Macros example1 and example2 produce some histograms. Example3 just loop over events and tracks and |
37 |
counts time. It is usefull to check processing time. |
38 |
|
39 |
|
40 |
5) To create Loop.exe execute the command (you need the PAMELA environment variables): |
41 |
|
42 |
> make Loop.exe |
43 |
|
44 |
The executable is create by compiling and linking the files: |
45 |
|
46 |
Loop.cpp |
47 |
My-Selection.cpp |
48 |
My-Histos.cpp |
49 |
|
50 |
You can use My-Selection.cpp and My-Histos.cpp as a template to inplement your own |
51 |
selection cuts and analysis. |
52 |
More generally, you can compile and link Loop.cpp with your own source files (you need |
53 |
to edit also the Makefile), where you should implement at least the following functions: |
54 |
|
55 |
bool Select(PamLevel2*); |
56 |
void CreateHistos(TFile*); |
57 |
void FillHistos(PamLevel2*); |
58 |
void SaveHistos(TFile*); |
59 |
|
60 |
To know how to use Loop.exe, issue: |
61 |
./Loop.exe --help |
62 |
|
63 |
(If you execute "make Loop-0.exe" the old example code, previously posted on the cvs, |
64 |
is compiled and linked. This is not a very general example, better use the new one) |