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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.18 - (show 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 /**
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 #include <TROOT.h> // EMILIANO: needed to compile with ROOT > 5.16/x
13
14 #include <GLTables.h>
15 #include <TrkStruct.h>
16 #include <TrkCalib.h>
17
18 #define NTYPES 10
19 #define NGF 14
20
21 /**
22 * \brief Class to store tracker parameter information
23 *
24 * 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 *
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 * Internal parameters are initialized to default values
42 *
43 * 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 * setting (either from DB or from environment variables) and loading of parameters.
51 * 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 */
61 class TrkParams : public TObject {
62
63 private:
64
65 static Bool_t simuflag;
66 static Int_t GetIndex( UInt_t type );
67
68 public:
69
70 static void SetSimuFlag(Bool_t);
71 static Bool_t GetSimuFlag();
72 // ---------------------------------------------
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 static TrkCalib* calib1;
81 static TrkCalib* calib2;
82 // ---------------------------------------------
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 // -----------------------------------------------
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 static cDbg init__dbg_mode; //debug mode (for both c++ and F77 roiutines)
97 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 static double init__deltab_0;
100 static double init__deltab_1;
101 static double init__dlt;
102
103 // ------------------------------------------
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 TrkParams();
115
116 // ---------------------------------------------
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 static UInt_t ValidateTrkCalib( CalibTrk1Event* );
123 // static void FillFCalibFrom(TFile* , Int_t , Int_t );//full
124 // static void FillTCalibFrom(TFile* , Int_t , Int_t );//truncated
125 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 static Bool_t Set( GL_RUN* glrun, TSQLServer* dbc, UInt_t type, UInt_t abstime=0);
133 static Bool_t Set( GL_RUN* glrun, TSQLServer* dbc){
134 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 };
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 static GL_PARAM GetParams( UInt_t type ){ return gl[TrkParams::GetIndex(type)]; };
149
150 // ---------------------------------------------
151 // retrieve parameters
152 // ---------------------------------------------
153 static float GetBX(float*);
154 static float GetBY(float*);
155 static float GetBZ(float*);
156 static float GetResolution(int,float);
157 static int GetPFA(){return sw_.pfaid;};
158 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
168
169
170 // ---------------------------------------------
171 // debug mode
172 // ---------------------------------------------
173
174 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
182 // ------------------------------------------------
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 static void SetDeltaB() {deltab_.delta0 = init__deltab_0;
191 deltab_.delta1 = init__deltab_1;};
192 static void SetDLT() {deltab_.dlt = init__dlt;};
193 static void SetMiniDefault() {
194 SetTrackingMode();
195 SetPrecisionFactor();
196 SetStepMin();
197 SetDeltaB();
198 SetDLT();
199 }; //
200 static void SetPFA();
201
202 // set to custom values
203 static void SetTrackingMode(int);
204 static void SetPrecisionFactor(double);
205 static void SetStepMin(int);
206 static void SetDeltaB(int,double);
207 static void SetDLT(double);
208 static void SetPFA(int);
209 static void SetPFA(float *);
210
211 // ---------------------------------------------
212 // varie ed eventuali...
213 // ---------------------------------------------
214 static TSQLServer* SetDBConnection();
215
216
217 ClassDef(TrkParams,2);
218
219 };
220
221 #endif
222

  ViewVC Help
Powered by ViewVC 1.1.23