Adding flag to reject lasers events
authormarian <marian@f7af4fe6-9843-0410-8265-dc069ae4e863>
Tue, 9 Dec 2008 12:27:50 +0000 (12:27 +0000)
committermarian <marian@f7af4fe6-9843-0410-8265-dc069ae4e863>
Tue, 9 Dec 2008 12:27:50 +0000 (12:27 +0000)
and superimposed laser events
(Marian)

TPC/AliTPCcalibBase.cxx
TPC/AliTPCcalibBase.h

index f27bb23..5037b9b 100644 (file)
@@ -61,6 +61,8 @@ AliTPCcalibBase::AliTPCcalibBase():
     fMagF(0),                 //! current magnetic field
     fTriggerMaskReject(-1),   //trigger mask - reject trigger
     fTriggerMaskAccept(-1),   //trigger mask - accept trigger
+    fHasLaser(kFALSE),                    //flag the laser is overlayed with given event 
+    fRejectLaser(kTRUE),                 //flag- reject laser
     fDebugLevel(0)
 {
   //
@@ -79,6 +81,8 @@ AliTPCcalibBase::AliTPCcalibBase(const AliTPCcalibBase&calib):
   fMagF(0),                 //! current magnetic field
   fTriggerMaskReject(calib.fTriggerMaskReject),   //trigger mask - reject trigger
   fTriggerMaskAccept(calib.fTriggerMaskAccept),   //trigger mask - accept trigger
+  fHasLaser(calib.fHasLaser),                    //flag the laser is overlayed with given event
+  fRejectLaser(calib.fRejectLaser),                 //flag- reject laser
   fDebugLevel(calib.fDebugLevel)
 {
   //
@@ -142,14 +146,45 @@ void    AliTPCcalibBase::UpdateEventInfo(AliESDEvent * event){
   fTime    = event->GetTimeStamp();
   fTrigger = event->GetTriggerMask();
   fMagF    = event->GetMagneticField();
+  fHasLaser = HasLaser(event); 
 }
 
+
+Bool_t AliTPCcalibBase::HasLaser(AliESDEvent *event){
+  //
+  //
+  //
+  // Thresholds more than 8 tracks with small dip angle
+  
+  const Int_t kMinLaserTracks = 8;
+  const Float_t kThrLaser       = 0.3;
+  const Float_t kLaserTgl       = 0.01;
+
+  Int_t ntracks = event->GetNumberOfTracks();
+  if (ntracks<kMinLaserTracks) return kFALSE;
+  Float_t nlaser=0;
+  Float_t nall=0;
+  for (Int_t i=0;i<ntracks;++i) {
+    AliESDtrack *track=event->GetTrack(i);
+    if (!track) continue;
+    if (track->GetTPCNcls()<=0) continue; 
+    nall++;
+    if (TMath::Abs(track->GetTgl())<kLaserTgl) nlaser++;
+  }
+  if (nlaser>kMinLaserTracks) return kTRUE;
+  if (nall>0 && nlaser/nall>kThrLaser) return kTRUE;
+  return kFALSE;
+}
+
+
+
 Bool_t AliTPCcalibBase::AcceptTrigger(){
   //
   // Apply trigger mask - Don't do calibration for non proper triggers
   // 
-  if (fTriggerMaskReject==fTrigger) return kFALSE;
-  if (fTriggerMaskAccept>0 && fTriggerMaskAccept!=fTrigger) return kFALSE;
+  if (fTriggerMaskReject==(Int_t)fTrigger) return kFALSE;
+  if (fTriggerMaskAccept>0 && fTriggerMaskAccept!=(Int_t)fTrigger) return kFALSE;
+  if (fHasLaser && fRejectLaser) return kFALSE;
   return kTRUE;
 }
 
index 2aebea3..67bbc4b 100644 (file)
@@ -29,7 +29,8 @@ public:
   virtual void     Terminate();
   virtual void     UpdateEventInfo(AliESDEvent * event);
   virtual Bool_t   AcceptTrigger();
-  virtual void     SetTriggerMask(Int_t accept, Int_t reject){fTriggerMaskAccept=accept;fTriggerMaskReject=reject;}
+  virtual void     SetTriggerMask(Int_t accept, Int_t reject, Bool_t rejectLaser){fTriggerMaskAccept=accept;fTriggerMaskReject=reject; fRejectLaser = rejectLaser;}
   //
   // debug streamer support
   TTreeSRedirector *GetDebugStreamer();
@@ -38,6 +39,8 @@ public:
   Int_t      GetStreamLevel() const {return fStreamLevel;}
   Int_t      GetDebugLevel() const {return fDebugLevel;}
   virtual void RegisterDebugOutput(const char *path);
+  static     Bool_t HasLaser(AliESDEvent *event);
+
 protected: 
   TTreeSRedirector *fDebugStreamer;     //! debug streamer
   Int_t  fStreamLevel;                  //  debug stream level
@@ -48,6 +51,8 @@ protected:
   Float_t fMagF;                        //! current magnetic field 
   Int_t   fTriggerMaskReject;           //trigger mask - non accept trigger
   Int_t   fTriggerMaskAccept;           //trigger mask - accept
+  Bool_t  fHasLaser;                    //flag the laser is overlayed with given event
+  Bool_t  fRejectLaser;                 //flag- reject laser
 private:
   Int_t  fDebugLevel;                   //  debug level