1 #ifndef ALIANALYSISTASKSEHFQUALITYASSURANCE_H
2 #define ALIANALYSISTASKSEHFQUALITYASSURANCE_H
4 /* Copyright(c) 1998-2009, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
9 //*************************************************************************
10 // Class AliAnalysisTaskSEHFQA
11 // AliAnalysisTaskSE for HF quality assurance
12 // Authors: C.Bianchin, chiara.bianchin@pd.infn.it
13 //*************************************************************************
18 #include "AliAnalysisTaskSE.h"
24 class AliFlowTrackCuts;
26 class AliAnalysisTaskSEHFQA : public AliAnalysisTaskSE
31 enum DecChannel {kDplustoKpipi,kD0toKpi,kDstartoKpipi,kDstoKKpi,kD0toKpipipi,kLambdactopKpi,kLambdactoV0};
33 AliAnalysisTaskSEHFQA();
34 AliAnalysisTaskSEHFQA(const char *name, DecChannel ch, AliRDHFCuts* cuts);
35 virtual ~AliAnalysisTaskSEHFQA();
37 // Implementation of interface methods
38 virtual void UserCreateOutputObjects();
40 virtual void LocalInit() {Init();}
41 virtual void UserExec(Option_t *option);
42 virtual void Terminate(Option_t *option);
45 void SetReadMC(Bool_t mcflag){fReadMC=mcflag;}
46 void SetSimpleMode(Bool_t flag){fSimpleMode=flag;}
47 void SetTrackOn(Bool_t trackon=kTRUE){fOnOff[0]=trackon;}
48 void SetPIDOn(Bool_t pidon=kTRUE){fOnOff[1]=pidon;}
49 void SetCentralityOn(Bool_t centron=kTRUE){fOnOff[2]=centron;}
50 void SetEvSelectionOn(Bool_t evselon=kTRUE){fOnOff[3]=evselon;}
51 void SetFlowObsOn(Bool_t flowobson=kTRUE){fOnOff[4]=flowobson;}
54 AliRDHFCuts* GetCutObject() const {return fCuts;}
55 DecChannel GetDecayChannel()const {return fDecayChannel;}
56 Bool_t GetTrackStatus() const {return fOnOff[0];}
57 Bool_t GetPIDStatus() const {return fOnOff[1];}
58 Bool_t GetCentralityStatus() const {return fOnOff[2];}
59 Bool_t GetEvSelStatus() const {return fOnOff[3];}
60 Bool_t GetFlowObsStatus() const {return fOnOff[4];}
63 AliAnalysisTaskSEHFQA(const AliAnalysisTaskSEHFQA &source);
64 AliAnalysisTaskSEHFQA operator=(const AliAnalysisTaskSEHFQA &source);
65 void FillFlowObs(AliAODEvent *aod);
67 TH1F* fNEntries; //! histogram with number of events on output slot 1
68 TList* fOutputPID; //! list sent on output slot 2
69 TList* fOutputTrack; //! list sent on output slot 3
70 TList* fOutputCounters; //! list sent on output slot 5
71 TList* fOutputCheckCentrality; //! list sent on output slot 6
72 TList* fOutputEvSelection; //! list sent on output slot 7
73 TList* fOutputFlowObs; //! list sent on output slot 8
74 DecChannel fDecayChannel; //identify the decay channel
75 AliRDHFCuts* fCuts; // object containing cuts
76 AliFlowEvent *fFlowEvent; //! to handle the reusage of the flowEvent object
77 AliFlowTrackCuts *fRFPcuts; //! reference flow particle cuts
78 AliRDHFCuts::ECentrality fEstimator; //2nd estimator for centrality
79 Bool_t fReadMC; // flag to read MC
80 Bool_t fSimpleMode; // if true, don't do candidates (much faster in PbPb)
81 Bool_t fOnOff[5]; // on-off the QA on tracks (0), PID (1), centrality (2), event selection -- default is {kTRUE,kTRUE,kTRUE,kTRUE}
82 ClassDef(AliAnalysisTaskSEHFQA,7); //AnalysisTaskSE for the quality assurance of HF in hadrons