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

Diff of /DarthVader/TrackerLevel2/inc/TrkLevel2.h

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

revision 1.24 by pam-fi, Fri Apr 27 10:39:57 2007 UTC revision 1.28 by pam-fi, Thu May 24 16:45:47 2007 UTC
# Line 17  Line 17 
17  // z-coordinate of track state-vector reference-plane  // z-coordinate of track state-vector reference-plane
18  #define ZINI 23.5    #define ZINI 23.5  
19  // (mechanical) z-coordinate of the tracker planes  // (mechanical) z-coordinate of the tracker planes
20  #define ZTRK6 -22.23  #define ZTRK6 -22.22
21  #define ZTRK5 -13.32  #define ZTRK5 -13.31
22  #define ZTRK4 -4.42  #define ZTRK4 -4.41
23  #define ZTRK3 4.48  #define ZTRK3 4.49
24  #define ZTRK2 13.38  #define ZTRK2 13.39
25  #define ZTRK1 22.28  #define ZTRK1 22.29
26    // magnet cavity dimensions
27    #define ZMAGNHIGH 21.83
28    #define ZMAGNLOW -21.83
29    #define XMAGNHIGH 8.07
30    #define XMAGNLOW -8.07
31    #define YMAGNHIGH 6.57
32    #define YMAGNLOW -6.57
33  // (mechanical) x/y-coordinates of magnet cavity  // (mechanical) x/y-coordinates of magnet cavity
34  #define XTRKL -8.1  #define XTRKL -8.1
35  #define XTRKR  8.1  #define XTRKR  8.1
# Line 137  public: Line 144  public:
144      Bool_t IsSaturated();      Bool_t IsSaturated();
145      Bool_t IsBad(int,int);      Bool_t IsBad(int,int);
146      Float_t GetDEDX();      Float_t GetDEDX();
147      Float_t GetDEDX(int);      Float_t GetDEDX(int ip);
148      Float_t GetDEDX(int,int);      Float_t GetDEDX(int ip,int iv);
149      Int_t GetLeverArmX();      Int_t GetLeverArmX();
150      Int_t GetLeverArmY();      Int_t GetLeverArmY();
151    
152      void SetMeasure(double *xmeas, double *ymeas, double *zmeas);      void SetMeasure(double *xmeas, double *ymeas, double *zmeas);
153      void SetResolution(double *rx, double *ry);      void SetResolution(double *rx, double *ry);
154        void SetTail(double *tx, double *ty, double factor);
155        void SetStudentParam(int flag);
156      void SetGood(int *xg, int *yg);      void SetGood(int *xg, int *yg);
157      void LoadField(TString s);      void LoadField(TString s);
158      void Fit(double pfixed, int& fail, int iprint);      void Fit(double pfixed, int& fail, int iprint, int froml1);
159        void Fit(double pfixed, int& fail, int iprint){ Fit(pfixed,fail,iprint,0); };
160      void FitReset();      void FitReset();
161      void SetTrackingMode(int trackmode);      void SetTrackingMode(int trackmode);
162      void SetPrecisionFactor(double fact);      void SetPrecisionFactor(double fact);
163      void SetStepMin(int istepmin);      void SetStepMin(int istepmin);
164        Bool_t IsInsideCavity();
165    
166        Bool_t EvaluateClusterPositions();
167    
168      void FillMiniStruct(cMini2track&);      void FillMiniStruct(cMini2track&);
169      void SetFromMiniStruct(cMini2track*);      void SetFromMiniStruct(cMini2track*);
# Line 161  public: Line 174  public:
174      Int_t GetSensor(int ip);      Int_t GetSensor(int ip);
175      Bool_t XGood(int ip){ return GetClusterX_ID(ip)!=-1; };      Bool_t XGood(int ip){ return GetClusterX_ID(ip)!=-1; };
176      Bool_t YGood(int ip){ return GetClusterY_ID(ip)!=-1; };      Bool_t YGood(int ip){ return GetClusterY_ID(ip)!=-1; };
177        void ResetXGood(int ip){ xgood[ip]=0; };
178        void ResetYGood(int ip){ ygood[ip]=0; };
179        void SetXGood(int ip, int clid, int is);
180        void SetYGood(int ip, int clid, int is);
181    
182      Bool_t BadClusterX(int ip){ return IsBad(ip,0); };      Bool_t BadClusterX(int ip){ return IsBad(ip,0); };
183      Bool_t BadClusterY(int ip){ return IsBad(ip,1); };      Bool_t BadClusterY(int ip){ return IsBad(ip,1); };
# Line 218  public: Line 235  public:
235   * Each track may have an "image", due to the ambiguity on the Y view, which is stored also.   * Each track may have an "image", due to the ambiguity on the Y view, which is stored also.
236   * Thus, the number of stored tracks ( ntrk() ) differs from the number of "physical" tracks ( GetNTracks() ).   * Thus, the number of stored tracks ( ntrk() ) differs from the number of "physical" tracks ( GetNTracks() ).
237   * Proper methods allow to sort tracks and select the physical ones ( GetTracks() ).   * Proper methods allow to sort tracks and select the physical ones ( GetTracks() ).
238     *
239     * The event status indicates the processing status of data from each DSP, according to the following
240     * notation:
241     *
242     *     xxxx xxxx xxxx xxxx xxxx xxxx
243     *     |||| |||| |||| |||| |||| ||||_ 0 missing packet
244     *     |||| |||| |||| |||| |||| |||__ 1 CRC error
245     *     |||| |||| |||| |||| |||| ||___ 2 on-line software alarm (latch-up, timeout ecc...)
246     *     |||| |||| |||| |||| |||| |____ 3 jump in the trigger counter
247     *     |||| |||| |||| |||| ||||______ 4 decode error
248     *     |||| |||| |||| |||| |||_______ 5 n.clusters > maximum number (level1 processing)
249     *     |||| |||| |||| |||| ||________ 6
250     *     |||| |||| |||| |||| |_________ 7
251     *     |||| |||| |||| ||||___________ 8 n.clusters > maximum value (level2 processing)
252     *     |||| |||| |||| |||____________ 9 n.couples per plane > maximum values (vector dimention)
253     *     |||| |||| |||| ||_____________ 10 n.doublets > maximum values
254     *     |||| |||| |||| |______________ 11 n.triplets > maximum values
255     *     |||| |||| ||||________________ 12 n.yz-clouds > maximum values
256     *     |||| |||| |||_________________ 13 n.xz-clouds > maximum values
257     *     |||| |||| ||__________________ 14 n.candidate-tracks > maximum values
258     *     |||| |||| |___________________ 15 n.couples per plane > maximum values (for Hough transform)
259     *     |||| ||||_____________________ 16
260     *        
261     *
262     * For all data processed before June 2007 the event status was coded according to
263     * a different rule:
264     *
265     * Status of level1 processing
266     *  0 -- OK  
267     *  1 -- missing packet
268     *  2 -- 1  CRC error
269     *  3 -- 2 on-line software alarm (latch-up flags asserted or n.transmitted-words = 0)
270     *  4 -- 3 jump in the trigger counter
271     * 10 -- 4 decode error
272     * 11 -- 5  n.clusters > maximum number (for level1 processing)
273     * Status of level2 processing
274     * 21 -- 0 n.clusters > maximum value (for level2 processing)
275     * 22 -- 1 n.couples per plane > maximum values (vector dimention)
276     * 23 -- 2 n.doublets > maximum values
277     * 24 -- 3 n.triplets > maximum values
278     * 25 -- 4 n.yz-clouds > maximum values
279     * 26 -- 5 n.xz-clouds > maximum values
280     * 27 -- 6 n.candidate-tracks > maximum values
281     * 28 -- 7 n.couples per plane > maximum values (for Hough transform)
282     *  
283     *
284   */   */
285  class TrkLevel2 : public TObject {  class TrkLevel2 : public TObject {
286    
# Line 253  class TrkLevel2 : public TObject { Line 316  class TrkLevel2 : public TObject {
316      void SetFromLevel2Struct()              { SetFromLevel2Struct(&level2event_);     };          void SetFromLevel2Struct()              { SetFromLevel2Struct(&level2event_);     };    
317      void GetLevel2Struct(cTrkLevel2 *) const;      void GetLevel2Struct(cTrkLevel2 *) const;
318      void LoadField(TString);      void LoadField(TString);
319      float GetBX(float*);      float GetBX(float* v){return TrkParams::GetBX(v);};///< Bx (kGauss)
320      float GetBY(float*);      float GetBY(float* v){return TrkParams::GetBY(v);};///< By (kGauss)
321      float GetBZ(float*);      float GetBZ(float* v){return TrkParams::GetBZ(v);};///< Bz (kGauss)
322      Float_t GetZTrk(Int_t);      Float_t GetZTrk(Int_t);
323      Float_t GetXTrkLeft(){return XTRKL;};      Float_t GetXTrkLeft(){return XTRKL;};
324      Float_t GetXTrkRight(){return XTRKR;};      Float_t GetXTrkRight(){return XTRKR;};
# Line 282  class TrkLevel2 : public TObject { Line 345  class TrkLevel2 : public TObject {
345      TrkLevel2*    GetTrkLevel2(){return this;}      TrkLevel2*    GetTrkLevel2(){return this;}
346      TClonesArray* GetTrackArray(){return Track;};///< returns pointer to the track array      TClonesArray* GetTrackArray(){return Track;};///< returns pointer to the track array
347            
348        void   StatusDump(int view);
349        Bool_t StatusCheck(int view, int flagmask);
350    
351      ClassDef(TrkLevel2,3);      ClassDef(TrkLevel2,3);
352    
353  };  };

Legend:
Removed from v.1.24  
changed lines
  Added in v.1.28

  ViewVC Help
Powered by ViewVC 1.1.23