]> git.uio.no Git - u/mrichter/AliRoot.git/blame - PWG4/JetTasks/AliAnalysisTaskPhiCorrelations.h
allowing also to measure sum pt
[u/mrichter/AliRoot.git] / PWG4 / JetTasks / AliAnalysisTaskPhiCorrelations.h
CommitLineData
e0331fd9 1#ifndef AliAnalysisTaskPhiCorrelations_H
2#define AliAnalysisTaskPhiCorrelations_H
3
4/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
6
7////////////////////////////////////////////////////////////////////////
8//
9// Analysis class for Underlying Event studies w.r.t. leading track
10//
11// Look for correlations on the tranverse regions w.r.t
12// the leading track in the event
13//
14// This class needs input AODs.
15// The output is a list of analysis-specific containers.
16//
17// The AOD can be either connected to the InputEventHandler
18// for a chain of AOD files
19// or
20// to the OutputEventHandler
21// for a chain of ESD files,
22// in this case the class should be in the train after the jet-finder
23//
24// Authors:
25// Arian Abrahantes Quintana
26// Jan Fiete Grosse-Oetringhaus
27// Ernesto Lopez Torres
28// Sara Vallero
29//
30////////////////////////////////////////////////////////////////////////
31
32#include "AliAnalysisTask.h"
33#include "AliUEHist.h"
2a910c25 34#include "TString.h"
e0331fd9 35
36class AliAODEvent;
37class AliAnalyseLeadingTrackUE;
38class AliInputEventHandler;
39class AliMCEvent;
40class AliMCEventHandler;
41class AliUEHistograms;
42class AliVParticle;
43class TH1D;
44class TObjArray;
2a910c25 45class AliEventPoolManager;
85bfac17 46class AliESDEvent;
e0331fd9 47
48class AliAnalysisTaskPhiCorrelations : public AliAnalysisTask
49 {
50 public:
51 AliAnalysisTaskPhiCorrelations(const char* name="AliAnalysisTaskPhiCorrelations");
52 virtual ~AliAnalysisTaskPhiCorrelations();
53
54
55 // Implementation of interace methods
56 virtual void ConnectInputData(Option_t *);
57 virtual void CreateOutputObjects();
58 virtual void Exec(Option_t *option);
59
60 // Setters/Getters
61 // general configuration
62 virtual void SetDebugLevel( Int_t level ) { fDebug = level; }
63 virtual void SetMode(Int_t mode) { fMode = mode; }
64 virtual void SetReduceMemoryFootprint(Bool_t flag) { fReduceMemoryFootprint = flag; }
eed401dc 65 virtual void SetEventMixing(Bool_t flag) { fFillMixed = flag; }
c3294f09 66 virtual void SetCompareCentralities(Bool_t flag) { fCompareCentralities = flag; }
1bba939a 67 virtual void SetTwoTrackEfficiencyStudy(Bool_t flag) { fTwoTrackEfficiencyStudy = flag; }
e0331fd9 68
69 // histogram settings
70 void SetTrackingEfficiency( const TH1D* hist) { fkTrackingEfficiency = hist; }
71
72 // for event QA
73 void SetTracksInVertex( Int_t val ){ fnTracksVertex = val; }
74 void SetZVertex( Double_t val ) { fZVertex = val; }
75
76 // track cuts
77 void SetTrackEtaCut( Double_t val ) { fTrackEtaCut = val; }
78 void SetPtMin(Double_t val) { fPtMin = val; }
79 void SetFilterBit( UInt_t val ) { fFilterBit = val; }
2a910c25 80
e0331fd9 81 void SetEventSelectionBit( UInt_t val ) { fSelectBit = val; }
82 void SetUseChargeHadrons( Bool_t val ) { fUseChargeHadrons = val; }
2a910c25 83 void SetSelectCharge(Int_t selectCharge) { fSelectCharge = selectCharge; }
84 void SetCentralityMethod(const char* method) { fCentralityMethod = method; }
c05ff6be 85 void SetFillpT(Bool_t flag) { fFillpT = flag; }
2a910c25 86
e0331fd9 87
88 private:
89 AliAnalysisTaskPhiCorrelations(const AliAnalysisTaskPhiCorrelations &det);
90 AliAnalysisTaskPhiCorrelations& operator=(const AliAnalysisTaskPhiCorrelations &det);
91 void AddSettingsTree(); // add list of settings to output list
92 // Analysis methods
93 void AnalyseCorrectionMode(); // main algorithm to get correction maps
94 void AnalyseDataMode(); // main algorithm to get raw distributions
95 void Initialize(); // initialize some common pointer
96
97
98
99 // General configuration
100 Int_t fDebug; // Debug flag
101 Int_t fMode; // fMode = 0: data-like analysis
102 // fMode = 1: corrections analysis
103 Bool_t fReduceMemoryFootprint; // reduce memory consumption by writing less debug histograms
eed401dc 104 Bool_t fFillMixed; // enable event mixing (default: ON)
c3294f09 105 Bool_t fCompareCentralities; // use the z vtx axis for a centrality comparison
1bba939a 106 Bool_t fTwoTrackEfficiencyStudy; // two-track efficiency study on
e0331fd9 107
108 // Pointers to external UE classes
109 AliAnalyseLeadingTrackUE* fAnalyseUE; //! points to class containing common analysis algorithms
110 AliUEHistograms* fHistos; //! points to class to handle histograms/containers
111 AliUEHistograms* fHistosMixed; //! points to class to handle mixed histograms/containers
112
113 const TH1D* fkTrackingEfficiency; // used for study of bias by tracking
114
115 // Handlers and events
116 AliAODEvent* fAOD; //! AOD Event
85bfac17 117 AliESDEvent* fESD; //! ESD Event
e0331fd9 118 TClonesArray* fArrayMC; //! Array of MC particles
119 AliInputEventHandler* fInputHandler; //! Generic InputEventHandler
120 AliMCEvent* fMcEvent; //! MC event
121 AliMCEventHandler* fMcHandler; //! MCEventHandler
2a910c25 122 AliEventPoolManager* fPoolMgr; //! event pool manager
e0331fd9 123
124 // Histogram settings
125 TList* fListOfHistos; // Output list of containers
126
127 // Event QA cuts
c05ff6be 128 Int_t fnTracksVertex; // QA tracks pointing to principal vertex
e0331fd9 129 Double_t fZVertex; // Position of Vertex in Z direction
2a910c25 130 TString fCentralityMethod; // Method to determine centrality
e0331fd9 131
132 // Track cuts
133 Double_t fTrackEtaCut; // Eta cut on particles
134 Double_t fPtMin; // Min pT to start correlations
135 UInt_t fFilterBit; // Select tracks from an specific track cut (default 0xFF all track selected)
136 UInt_t fSelectBit; // Select events according to AliAnalysisTaskJetServices bit maps
137 Bool_t fUseChargeHadrons; // Only use charge hadrons
138
2a910c25 139 Int_t fSelectCharge; // (un)like sign selection when building correlations: 0: no selection; 1: unlike sign; 2: like sign
c05ff6be 140 Bool_t fFillpT; // fill sum pT instead of number density
2a910c25 141
e0331fd9 142 ClassDef( AliAnalysisTaskPhiCorrelations, 1); // Analysis task for Underlying Event analysis w.r.t. leading track
143 };
144
145#endif
146
147