/[PAMELA software]/calo/flight/CaloProfile/inc/CaloProfile.h
ViewVC logotype

Annotation of /calo/flight/CaloProfile/inc/CaloProfile.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.6 - (hide annotations) (download)
Tue Aug 11 14:23:08 2009 UTC (15 years, 5 months ago) by mocchiut
Branch: MAIN
Changes since 1.5: +8 -0 lines
File MIME type: text/plain
New small features added

1 mocchiut 1.1 /**
2     * \file CaloProfile.h
3     * \author Emiliano Mocchiutti
4     */
5     #ifndef caloprofile_h
6     #define caloprofile_h
7    
8 mocchiut 1.3 #include <iostream>
9 mocchiut 1.1 #include <TTree.h>
10     #include <TFriendElement.h>
11     #include <TChain.h>
12     #include <TCanvas.h>
13     #include <TGraph.h>
14     #include <TH1F.h>
15     #include <TH2F.h>
16     #include <TFile.h>
17     #include <TPolyLine.h>
18     #include <TMath.h>
19     #include <TStyle.h>
20     #include <TList.h>
21     #include <TKey.h>
22     #include <TSystemFile.h>
23     #include <TSystemDirectory.h>
24     #include <TSQLServer.h>
25     #include <TF1.h>
26 mocchiut 1.3
27     #include <PamLevel2.h>
28 mocchiut 1.1
29     using namespace std;
30    
31     /**
32     *
33     */
34     class CaloLat : public TObject {
35    
36     private:
37     //
38     PamLevel2 *L2;
39     Bool_t debug;
40     //
41     // needed to avoid reprocessing the same event over and over to obtain the variables
42     //
43     UInt_t OBT;
44     UInt_t PKT;
45     UInt_t atime;
46     //
47     Float_t estrip[2][22][96];
48     //
49    
50     public:
51     //
52     //
53     void Draw();
54     void Draw(Int_t,Int_t);
55     //
56     CaloLat();
57     CaloLat(PamLevel2 *L2);
58     ~CaloLat(){ Delete(); };
59     //
60     void SetDebug(Bool_t d){ debug=d; };
61     //
62     void Clear();
63     void Clear(Option_t *option){Clear();};
64     void Delete();
65 mocchiut 1.2 void Delete(Option_t *option){Delete();};
66 mocchiut 1.1 //
67     void Process(); ///< Process data
68     void Print();
69 mocchiut 1.2 void Print(Option_t *option){Print();};
70 mocchiut 1.1 //
71     ClassDef(CaloLat,1);
72     };
73    
74     /**
75     *
76     */
77     class CaloLong : public TObject {
78    
79     private:
80     //
81     PamLevel2 *L2;
82     Bool_t debug;
83     //
84     // needed to avoid reprocessing the same event over and over to obtain the variables
85     //
86     UInt_t OBT;
87     UInt_t PKT;
88     UInt_t atime;
89 mocchiut 1.3 UInt_t fOBT;
90     UInt_t fPKT;
91     UInt_t fatime;
92     //
93     Int_t N;
94     Int_t NC;
95     Bool_t sel;
96     Bool_t cont;
97     Int_t mask18b;
98     //
99     Float_t chi2;
100     Float_t ndf;
101     Float_t E0;
102     Float_t a;
103     Float_t b;
104     Float_t errE0;
105     Float_t erra;
106     Float_t errb;
107     Float_t etmax;
108     Float_t asymm;
109     Float_t X0pl;
110     Int_t fitresult;
111     //
112     Bool_t no18x;
113 mocchiut 1.5 Bool_t maskXE;
114     Bool_t maskYE;
115     Bool_t maskXO;
116     Bool_t maskYO;
117 mocchiut 1.1 //
118     Float_t eplane[2][22];
119     //
120 mocchiut 1.6 CaloLevel2 *clp;
121     //
122 mocchiut 1.1
123     public:
124     //
125     //
126 mocchiut 1.3 void Fit();
127     void Fit(Bool_t draw);
128     //
129     // Double_t ccurve(Double_t *t, Double_t *par);
130     //
131 mocchiut 1.6 void SetCaloLevel2Pointer(CaloLevel2 *cp){ clp = cp;};
132     //
133 mocchiut 1.3 Float_t Get_E0(){this->Fit(); return E0;};
134     Float_t Get_a(){this->Fit(); return a;};
135     Float_t Get_b(){this->Fit(); return b;};
136     Float_t Get_errE0(){this->Fit(); return errE0;};
137     Float_t Get_erra(){this->Fit(); return erra;};
138     Float_t Get_errb(){this->Fit(); return errb;};
139     Float_t Get_chi2(){this->Fit(); return chi2;};
140     Float_t Get_ndf(){this->Fit(); return ndf;};
141     Float_t Get_nchi2(){this->Fit(); if ( ndf > 0 ) return (chi2/ndf); return 0;};
142     Float_t Get_tmax(){this->Fit(); if ( b != 0 ) return ((a-1.)/b); return 0;};
143     Float_t Get_asymm(){this->Fit(); return asymm;};
144     Float_t Get_exptmax(){this->Process(); return etmax;};
145     Float_t Get_X0pl(){this->Process(); return X0pl;};
146     Int_t Get_fitresult(){this->Fit(); return fitresult;};
147     //
148 mocchiut 1.6 void ForceNextFit(){atime=0;fatime=0;};
149 mocchiut 1.1 void Draw();
150     void Draw(Int_t);
151     //
152     CaloLong();
153     CaloLong(PamLevel2 *L2);
154     ~CaloLong(){ Delete(); };
155     //
156     void SetDebug(Bool_t d){ debug=d; };
157 mocchiut 1.3 void UsePlane18X(){ no18x=false; };
158     //
159 mocchiut 1.5 void MaskSection(TString);
160 mocchiut 1.6 void UnMaskSection(TString);
161     void UnMaskSections();
162 mocchiut 1.3 void Selection(){sel = true; cont = false;}; ///< Set selection mode: planes from 1 to 22-N are used, plane 18 - N is masked if "emulate18" variable is true (DEFAULT);
163     void Contamination(){sel = false; cont = true;}; ///< Set contamination mode: planes from N to 22 are used.
164     void SetNoWpreSampler(Int_t n);
165     void SetNoWcalo(Int_t n);
166 mocchiut 1.4 void SplitInto(Int_t NoWpreSampler, Int_t NoWcalo);
167 mocchiut 1.3 Int_t GetNoWpreSampler(){return N;}; ///< Get the number of W planes used as presampler.
168     Int_t GetNoWcalo(){return NC;}; ///< Get the number of W planes used as calorimeter.
169 mocchiut 1.6 void SetEnergies(Float_t myene[][22]);
170 mocchiut 1.3 //
171     void Clear();
172     void Clear(Option_t *option){Clear();};
173     void Delete();
174     void Delete(Option_t *option){Delete();};
175     //
176     void Process(); ///< Process data
177     void Print();
178     void Print(Option_t *option){Print();};
179     //
180     ClassDef(CaloLong,2);
181     };
182    
183     /**
184     *
185     */
186     class Calo2D : public TObject {
187    
188     private:
189     //
190     PamLevel2 *L2;
191     Bool_t debug;
192     //
193     // needed to avoid reprocessing the same event over and over to obtain the variables
194     //
195     UInt_t OBT;
196     UInt_t PKT;
197     UInt_t atime;
198     //
199     Float_t estrip[23][96][96];
200     Int_t smax[23];
201     Int_t smay[23];
202     //
203    
204     public:
205     //
206     //
207     void Draw();
208     void Draw(Int_t);
209     //
210     Calo2D();
211     Calo2D(PamLevel2 *L2);
212     ~Calo2D(){ Delete(); };
213     //
214     void SetDebug(Bool_t d){ debug=d; };
215 mocchiut 1.1 //
216     void Clear();
217     void Clear(Option_t *option){Clear();};
218     void Delete();
219 mocchiut 1.2 void Delete(Option_t *option){Delete();};
220 mocchiut 1.1 //
221     void Process(); ///< Process data
222     void Print();
223 mocchiut 1.2 void Print(Option_t *option){Print();};
224 mocchiut 1.1 //
225 mocchiut 1.3 ClassDef(Calo2D,1);
226 mocchiut 1.1 };
227    
228     #endif
229    

  ViewVC Help
Powered by ViewVC 1.1.23