/[PAMELA software]/DarthVader/TrackerLevel2/inc/TrkParams.h
ViewVC logotype

Annotation of /DarthVader/TrackerLevel2/inc/TrkParams.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.18 - (hide annotations) (download)
Wed Mar 6 14:20:15 2013 UTC (11 years, 8 months ago) by mocchiut
Branch: MAIN
Changes since 1.17: +4 -1 lines
File MIME type: text/plain
Simulation flag (Valerio's style) added for Tracker

1 pam-fi 1.1 /**
2     * \file TrkParams.h
3     * \author Elena Vannuccini
4     */
5     #ifndef trkparams_h
6     #define trkparams_h
7    
8     #include <TObject.h>
9     #include <TString.h>
10     #include <TSQLServer.h>
11     #include <TSystem.h>
12 mocchiut 1.9 #include <TROOT.h> // EMILIANO: needed to compile with ROOT > 5.16/x
13 pam-fi 1.1
14     #include <GLTables.h>
15     #include <TrkStruct.h>
16     #include <TrkCalib.h>
17    
18     #define NTYPES 10
19 pam-fi 1.13 #define NGF 14
20 pam-fi 1.1
21     /**
22     * \brief Class to store tracker parameter information
23     *
24 pam-fi 1.5 * Tracker parameters include calibration parameters (PED, SIG and BAD),
25     * parameters loaded from DB (alignment, ADC-to-mip, etc. ) and some parameters
26     * to configure tracker processing (PFA, ecc...).
27     *
28     * Calibrations can be either those evaluated online or default values.
29     * External parameter are labelled according to the DB convention:
30 pam-fi 1.2 *
31     * type description
32     * -----------------
33     * 1 field
34     * 2 adc-to-mip
35     * 3 charge-correlation
36     * 4 p.f.a. (eta)
37     * 5 alignment
38     * 6 VA1 mask
39     * 7 default calibration
40     *
41 pam-fi 1.5 * Internal parameters are initialized to default values
42 pam-fi 1.7 *
43 pam-fi 1.2 * TrkParams::SetCalib(...) and TrkParams::Set(...) methods allow to set
44     * required parameters, from an input path, from the DB (for a given input
45     * run id) and from environment variable PAM_CALIB.
46     * TrkParams::LoadCalib() and TrkParams::Load() methods load parameters into
47     * F77 common.
48     *
49     * Tracker libraries (TrkLevel0, TrkLevel1 and TrkLevel2) implement automatic
50 pam-fi 1.4 * setting (either from DB or from environment variables) and loading of parameters.
51 pam-fi 1.2 * If one needs to load custom parameters, it is enough to call TrkParams::Set(...)
52     * with proper arguments. All the methods are static, and can be used as standalone functions.
53     *
54     * For example:
55     *
56     * TrkParams::Set("/param-path/new-mip-param/",2);
57     *
58     * After this instruction (to be called once), new adc-to-mip conversion parameters
59     * will be loaded automatically (once) and used until the next set instruction
60 pam-fi 1.1 */
61     class TrkParams : public TObject {
62    
63     private:
64    
65 mocchiut 1.18 static Bool_t simuflag;
66 pam-fi 1.1 static Int_t GetIndex( UInt_t type );
67    
68     public:
69    
70 mocchiut 1.18 static void SetSimuFlag(Bool_t);
71     static Bool_t GetSimuFlag();
72 pam-fi 1.1 // ---------------------------------------------
73     // variables to store loaded-calibration info
74     // ---------------------------------------------
75     static GL_TRK_CALIB calib;
76     static TString calibpatht; //truncated
77     static TString calibpathf; //full
78     static Bool_t calib104;
79     static Bool_t calibload;
80 pam-fi 1.16 static TrkCalib* calib1;
81     static TrkCalib* calib2;
82 pam-fi 1.1 // ---------------------------------------------
83     // variables to store loaded-parameters info
84     // ---------------------------------------------
85     static UInt_t trkparamtype[NTYPES];
86     static GL_PARAM gl[NTYPES];
87     static TString glpath[NTYPES];
88     static Bool_t glload[NTYPES];
89 pam-fi 1.5 // -----------------------------------------------
90     // some parameters to configure tracker processing
91     // -----------------------------------------------
92     static int init__pfa;
93     static int init__mini_trackmode;
94     static int init__mini_istepmin;
95     static double init__mini_fact;
96 pam-fi 1.7 static cDbg init__dbg_mode; //debug mode (for both c++ and F77 roiutines)
97 pam-fi 1.8 static float init__pfa_e234ax[6]; // angle intervals for eta2-3-4
98     static float init__pfa_e234ay[6]; // angle intervals for eta2-3-4
99 pam-fi 1.11 static double init__deltab_0;
100     static double init__deltab_1;
101 pam-fi 1.12 static double init__dlt;
102 pam-fi 1.8
103 pam-fi 1.13 // ------------------------------------------
104     // nominal z-coordinates to define acceptance
105     // ------------------------------------------
106     static int nGF;
107     static float zGF[NGF];
108     static float xGF_min[NGF];
109     static float xGF_max[NGF];
110     static float yGF_min[NGF];
111     static float yGF_max[NGF];
112     static TString GF_element[NGF];
113    
114 pam-fi 1.1 TrkParams();
115 pam-fi 1.13
116 pam-fi 1.1 // ---------------------------------------------
117     // calibration (PED-SIG-BAD)
118     // ---------------------------------------------
119     static Bool_t SetCalib( GL_RUN* , TSQLServer* );
120     static Bool_t LoadCalib( );
121     static Bool_t CalibIsLoaded(){ return calibload; };
122 pam-fi 1.3 static UInt_t ValidateTrkCalib( CalibTrk1Event* );
123 pam-fi 1.16 // static void FillFCalibFrom(TFile* , Int_t , Int_t );//full
124     // static void FillTCalibFrom(TFile* , Int_t , Int_t );//truncated
125 pam-fi 1.1 static void FillTCalibFrom(TString path);
126     static void FillACalibFrom(TFile* , Int_t , Int_t );//all
127     static void FillMask(TFile* , Int_t , Int_t );
128    
129     // ---------------------------------------------
130     // parameters
131     // ---------------------------------------------
132 mocchiut 1.18 static Bool_t Set( GL_RUN* glrun, TSQLServer* dbc, UInt_t type, UInt_t abstime=0);
133 pam-fi 1.1 static Bool_t Set( GL_RUN* glrun, TSQLServer* dbc){
134 pam-fi 1.17 Bool_t result = true;
135     for(Int_t i=0; i<NTYPES; i++)
136     if( !TrkParams::Set(glrun,dbc,trkparamtype[i]) )
137     result = false;
138     return result;
139 pam-fi 1.1 };
140     static Bool_t Set( TString, UInt_t );
141     static Bool_t Set( UInt_t );
142     static Bool_t Set( );
143     static Bool_t Load( UInt_t );
144     static Bool_t Load( );
145     static Bool_t IsLoaded( UInt_t type ){return glload[TrkParams::GetIndex(type)];};
146     static Bool_t IsLoaded( );
147    
148 pam-fi 1.16 static GL_PARAM GetParams( UInt_t type ){ return gl[TrkParams::GetIndex(type)]; };
149    
150 pam-fi 1.5 // ---------------------------------------------
151     // retrieve parameters
152     // ---------------------------------------------
153     static float GetBX(float*);
154     static float GetBY(float*);
155     static float GetBZ(float*);
156 pam-fi 1.6 static float GetResolution(int,float);
157 pam-fi 1.8 static int GetPFA(){return sw_.pfaid;};
158 pam-fi 1.14 static int GetPFA_NbinsAngle();
159     static int GetPFA_NbinsETA();
160     static int GetPFA_NbinsCharge(){return 0;};
161     static int GetPFA_AngleBin(float);
162     static float* GetPFA_ETAcorr(TString,int,int,int);
163     static float* GetPFA_ETAabs(TString,int);
164     static float GetPFA_ETAlandi(int,int,int);
165     static float GetPFA_ETAlandi(int nv,int nl,float ang)
166     { return TrkParams::GetPFA_ETAlandi(nv,nl,TrkParams::GetPFA_AngleBin(ang)); };
167 pam-fi 1.4
168 pam-fi 1.15
169    
170 pam-fi 1.4 // ---------------------------------------------
171     // debug mode
172     // ---------------------------------------------
173    
174 pam-fi 1.7 static void SetDebugMode() {init__dbg_mode.SetDebug(); dbg_=init__dbg_mode;};
175     static void SetVerboseMode(){init__dbg_mode.SetVerbose(); dbg_=init__dbg_mode;};
176     static void SetWarningMode(){init__dbg_mode.SetWarning(); dbg_=init__dbg_mode;};
177     static void SetQuietMode() {init__dbg_mode.SetNone(); dbg_=init__dbg_mode;};
178     static Bool_t DebugMode(){return init__dbg_mode.debug;};
179     static Bool_t WarningMode(){return init__dbg_mode.warning;};
180     static Bool_t VerboseMode(){return init__dbg_mode.verbose;};
181 pam-fi 1.4
182 pam-fi 1.5 // ------------------------------------------------
183     // alcuni metodi che non sapevo dove mettere
184     // per inizializzare alcune variabili in F77 common
185     // ------------------------------------------------
186     // set to default values
187     static void SetTrackingMode() {track_.trackmode = init__mini_trackmode;};
188     static void SetPrecisionFactor(){track_.fact = init__mini_fact; };
189     static void SetStepMin() {track_.istepmin = init__mini_istepmin; };
190 pam-fi 1.11 static void SetDeltaB() {deltab_.delta0 = init__deltab_0;
191     deltab_.delta1 = init__deltab_1;};
192 pam-fi 1.12 static void SetDLT() {deltab_.dlt = init__dlt;};
193 pam-fi 1.11 static void SetMiniDefault() {
194     SetTrackingMode();
195     SetPrecisionFactor();
196     SetStepMin();
197     SetDeltaB();
198 pam-fi 1.12 SetDLT();
199 pam-fi 1.11 }; //
200     static void SetPFA();
201    
202 pam-fi 1.5 // set to custom values
203     static void SetTrackingMode(int);
204     static void SetPrecisionFactor(double);
205     static void SetStepMin(int);
206 pam-fi 1.11 static void SetDeltaB(int,double);
207 pam-fi 1.12 static void SetDLT(double);
208 pam-fi 1.5 static void SetPFA(int);
209 pam-fi 1.8 static void SetPFA(float *);
210 pam-fi 1.5
211 pam-fi 1.10 // ---------------------------------------------
212     // varie ed eventuali...
213     // ---------------------------------------------
214     static TSQLServer* SetDBConnection();
215    
216    
217 pam-fi 1.4 ClassDef(TrkParams,2);
218 pam-fi 1.1
219     };
220    
221     #endif
222    

  ViewVC Help
Powered by ViewVC 1.1.23