]> git.uio.no Git - u/mrichter/AliRoot.git/blob - PWG0/AliPWG0Helper.h
- digit data type now in CALO definitions
[u/mrichter/AliRoot.git] / PWG0 / AliPWG0Helper.h
1 /* $Id$ */
2
3 #ifndef ALIPWG0HELPER_H
4 #define ALIPWG0HELPER_H
5
6 #include <TObject.h>
7 #include <AliTriggerAnalysis.h>
8
9 // static helper functions
10
11 class AliESDEvent;
12 class AliESDVertex;
13 class TParticle;
14 class TH1;
15 class TH2;
16 class TH3;
17 class AliHeader;
18 class AliGenEventHeader;
19 class AliStack;
20 class TTree;
21 class AliOfflineTrigger;
22
23 class AliPWG0Helper : public TObject
24 {
25   public:
26     enum AnalysisMode { kInvalid = -1, kSPD = 0x1, kTPC = 0x2, kTPCITS = 0x4, kFieldOn = 0x8, kSPDOnlyL0 = 0x10 };
27     // in case we want to use bitmaps...
28     enum MCProcessType { kInvalidProcess = -1, kND = 0x1, kDD = 0x2, kSD = 0x4 };
29
30     static const AliESDVertex* GetVertex(AliESDEvent* aEsd, AnalysisMode analysisMethod, Bool_t debug = kFALSE);
31     static Bool_t TestVertex(const AliESDVertex* vertex, AnalysisMode analysisMode, Bool_t debug = kFALSE);
32     
33     static Bool_t IsPrimaryCharged(TParticle* aParticle, Int_t aTotalPrimaries, Bool_t adebug = kFALSE);
34
35     static AliPWG0Helper::MCProcessType GetEventProcessType(AliHeader* aHeader, Bool_t adebug = kFALSE);
36     static AliPWG0Helper::MCProcessType GetPythiaEventProcessType(AliGenEventHeader* aHeader, Bool_t adebug = kFALSE);
37     static AliPWG0Helper::MCProcessType GetDPMjetEventProcessType(AliGenEventHeader* aHeader, Bool_t adebug = kFALSE);
38     static Int_t GetLastProcessType() { return fgLastProcessType; }
39
40     static TParticle* FindPrimaryMother(AliStack* stack, Int_t label);
41     static Int_t FindPrimaryMotherLabel(AliStack* stack, Int_t label);
42
43     static void CreateProjections(TH3* hist, Bool_t save = kFALSE);
44     static void CreateDividedProjections(TH3* hist, TH3* hist2, const char* axis = 0, Bool_t putErrors = kFALSE, Bool_t save = kFALSE);
45     static const char* GetAxisTitle(TH3* hist, const char axis);
46
47     static void NormalizeToBinWidth(TH1* hist);
48     static void NormalizeToBinWidth(TH2* hist);
49
50     static void PrintConf(AnalysisMode analysisMode, AliTriggerAnalysis::Trigger trigger);
51     
52   protected:
53     static Int_t fgLastProcessType;    // stores the raw value of the last process type extracted
54  
55     ClassDef(AliPWG0Helper, 0)
56
57   private:
58     AliPWG0Helper(const AliPWG0Helper&);
59     AliPWG0Helper& operator=(const AliPWG0Helper&);
60 };
61
62 #endif
63