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

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.4 by mocchiut, Thu Dec 18 21:05:52 2008 UTC revision 1.12 by mocchiut, Thu Sep 10 12:53:56 2009 UTC
# Line 5  Line 5 
5  #ifndef caloprofile_h  #ifndef caloprofile_h
6  #define caloprofile_h  #define caloprofile_h
7    
8    #define EMPTY -1
9    #define MAX 50
10    
11  #include <iostream>  #include <iostream>
12    #include <stdio.h>
13    #include <string.h>
14    #include <ctype.h>
15  #include <TTree.h>  #include <TTree.h>
16  #include <TFriendElement.h>  #include <TFriendElement.h>
17  #include <TChain.h>  #include <TChain.h>
# Line 23  Line 29 
29  #include <TSystemDirectory.h>  #include <TSystemDirectory.h>
30  #include <TSQLServer.h>  #include <TSQLServer.h>
31  #include <TF1.h>  #include <TF1.h>
32    #include <TGraphErrors.h>
33    
34  #include <PamLevel2.h>  #include <PamLevel2.h>
35    
36  using namespace std;  using namespace std;
37    
38    struct stack{
39        char data[MAX];
40        int top;
41    };
42    
43  /**  /**
44   *   *
45   */   */
# Line 45  class CaloLat : public TObject { Line 57  class CaloLat : public TObject {
57      UInt_t atime;      UInt_t atime;
58      //      //
59      Float_t estrip[2][22][96];      Float_t estrip[2][22][96];
60        TString suf;
61      //      //
62    
63   public:   public:
# Line 68  class CaloLat : public TObject { Line 81  class CaloLat : public TObject {
81      void Print();      void Print();
82      void Print(Option_t *option){Print();};      void Print(Option_t *option){Print();};
83      //      //
84      ClassDef(CaloLat,1);      void SetSuffix(TString suffix){ suf = suffix;};
85        //
86        ClassDef(CaloLat,2);
87  };  };
88    
89  /**  /**
# Line 107  class CaloLong : public TObject { Line 122  class CaloLong : public TObject {
122      Float_t etmax;      Float_t etmax;
123      Float_t asymm;      Float_t asymm;
124      Float_t X0pl;      Float_t X0pl;
125        Float_t defE0;
126        Float_t umax;
127        Float_t lmax;
128        TString sumax;
129        TString slmax;
130      Int_t fitresult;      Int_t fitresult;
131      //      //
132      Bool_t no18x;      Bool_t no18x;
133        Bool_t maskXE;
134        Bool_t maskYE;
135        Bool_t maskXO;
136        Bool_t maskYO;
137        //
138        Bool_t xyaverage;
139        //
140        Bool_t heavytail;
141        Float_t letmax;
142        Float_t lmipth;
143      //      //
144      Float_t eplane[2][22];      Float_t eplane[2][22];
145      //      //
146        CaloLevel2 *clp;
147        //
148        Float_t Evaluate(TString s, Float_t tmax, Float_t X0pl ); // expression must be of the form "tmax+2.*X0pl", "5*tmax"."tmax+10","tmax-(4*tmax)+3.*X0pl"...
149        //
150        TString suf;
151    
152   public:   public:
153      //      //
# Line 122  class CaloLong : public TObject { Line 157  class CaloLong : public TObject {
157      //      //
158      //    Double_t ccurve(Double_t *t, Double_t *par);      //    Double_t ccurve(Double_t *t, Double_t *par);
159      //      //
160        void SetCaloLevel2Pointer(CaloLevel2 *cp){ clp = cp;};
161        //
162      Float_t Get_E0(){this->Fit(); return E0;};      Float_t Get_E0(){this->Fit(); return E0;};
163        Float_t Get_defE0(){this->Fit(); return defE0;};
164      Float_t Get_a(){this->Fit(); return a;};      Float_t Get_a(){this->Fit(); return a;};
165      Float_t Get_b(){this->Fit(); return b;};      Float_t Get_b(){this->Fit(); return b;};
166      Float_t Get_errE0(){this->Fit(); return errE0;};      Float_t Get_errE0(){this->Fit(); return errE0;};
# Line 135  class CaloLong : public TObject { Line 173  class CaloLong : public TObject {
173      Float_t Get_asymm(){this->Fit(); return asymm;};      Float_t Get_asymm(){this->Fit(); return asymm;};
174      Float_t Get_exptmax(){this->Process(); return etmax;};      Float_t Get_exptmax(){this->Process(); return etmax;};
175      Float_t Get_X0pl(){this->Process(); return X0pl;};      Float_t Get_X0pl(){this->Process(); return X0pl;};
     Int_t Get_fitresult(){this->Fit(); return fitresult;};  
176      //      //
177        Float_t Get_letmax(){ return letmax;};
178        Float_t Get_lmipth(){ return lmipth;};
179        Int_t Get_fitresult(){this->Fit(); return fitresult;};    
180        //
181        void ForceNextFit(){atime=0;fatime=0;};
182      void Draw();      void Draw();
183      void Draw(Int_t);      void Draw(Int_t);
184      //      //
# Line 147  class CaloLong : public TObject { Line 189  class CaloLong : public TObject {
189      void SetDebug(Bool_t d){ debug=d; };      void SetDebug(Bool_t d){ debug=d; };
190      void UsePlane18X(){ no18x=false; };      void UsePlane18X(){ no18x=false; };
191      //      //
192        void UseAverage(){ xyaverage = true;};
193        void UseAllMeas(){ xyaverage = false;};
194        //
195        void MaskSection(TString);
196        void UnMaskSection(TString);
197        void UnMaskSections();
198      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);      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);
199      void Contamination(){sel = false; cont = true;}; ///< Set contamination mode: planes from N to 22 are used.      void Contamination(){sel = false; cont = true;}; ///< Set contamination mode: planes from N to 22 are used.
200      void SetNoWpreSampler(Int_t n);      void SetNoWpreSampler(Int_t n);
# Line 154  class CaloLong : public TObject { Line 202  class CaloLong : public TObject {
202      void SplitInto(Int_t NoWpreSampler, Int_t NoWcalo);      void SplitInto(Int_t NoWpreSampler, Int_t NoWcalo);
203      Int_t GetNoWpreSampler(){return N;}; ///< Get the number of W planes used as presampler.      Int_t GetNoWpreSampler(){return N;}; ///< Get the number of W planes used as presampler.
204      Int_t GetNoWcalo(){return NC;}; ///< Get the number of W planes used as calorimeter.      Int_t GetNoWcalo(){return NC;}; ///< Get the number of W planes used as calorimeter.
205        void SetEnergies(Float_t myene[][22]);
206        //
207        void SetLowerLimit(Float_t l){ lmax = l; };
208        void SetUpperLimit(Float_t u){ umax = u; };
209        void SetLowerLimit(TString sl){ slmax = sl; };// expression must be of the form "5*t"."t+10","t-(4*t)"... where t will be replaced by the fitted maximum (X0)
210        void SetUpperLimit(TString su){ sumax = su; };// expression must be of the form "5*t"."t+10","t-(4*t)"... where t will be replaced by the fitted maximum (X0)
211        //
212        void Setletmax(Float_t l){ letmax = l;};
213        void Setlmipth(Float_t l){ lmipth = l;};
214        void HeavyTail(Bool_t b){ heavytail=b;};
215        //
216        Float_t GetLowerLimit(){ return lmax;};
217        Float_t GetUpperLimit(){ return umax;};
218        //
219        void SetSuffix(TString suffix){ suf = suffix;};
220      //      //
221      void Clear();      void Clear();
222      void Clear(Option_t *option){Clear();};      void Clear(Option_t *option){Clear();};
# Line 164  class CaloLong : public TObject { Line 227  class CaloLong : public TObject {
227      void Print();      void Print();
228      void Print(Option_t *option){Print();};      void Print(Option_t *option){Print();};
229      //      //
230      ClassDef(CaloLong,2);      ClassDef(CaloLong,3);
231  };  };
232    
233  /**  /**
# Line 187  class Calo2D : public TObject { Line 250  class Calo2D : public TObject {
250      Int_t smax[23];      Int_t smax[23];
251      Int_t smay[23];      Int_t smay[23];
252      //      //
253        TString suf;
254    
255   public:   public:
256      //      //
# Line 205  class Calo2D : public TObject { Line 269  class Calo2D : public TObject {
269      void Delete();      void Delete();
270      void Delete(Option_t *option){Delete();};      void Delete(Option_t *option){Delete();};
271      //      //
272        void SetSuffix(TString suffix){ suf = suffix;};
273        //
274      void Process(); ///< Process data      void Process(); ///< Process data
275      void Print();      void Print();
276      void Print(Option_t *option){Print();};      void Print(Option_t *option){Print();};
277      //      //
278      ClassDef(Calo2D,1);      ClassDef(Calo2D,2);
279  };  };
280    
281  #endif  #endif

Legend:
Removed from v.1.4  
changed lines
  Added in v.1.12

  ViewVC Help
Powered by ViewVC 1.1.23