1 #ifndef ALIANAPARTICLEISOLATION_H
2 #define ALIANAPARTICLEISOLATION_H
3 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * See cxx source for full Copyright notice */
6 //_________________________________________________________________________
8 // Class for the analysis of particle isolation
9 // Input is selected particles put in AOD branch (AliAODPWG4ParticleCorrelation)
11 // Class created from old AliPHOSGammaJet
12 // (see AliRoot versions previous Release 4-09)
14 //-- Author: Gustavo Conesa (INFN-LNF)
16 // --- ROOT system ---
21 // --- ANALYSIS system ---
22 #include "AliAnaCaloTrackCorrBaseClass.h"
23 class AliAODPWG4Particle;
24 class AliAODPWG4ParticleCorrelation ;
27 class AliAnaParticleIsolation : public AliAnaCaloTrackCorrBaseClass {
30 AliAnaParticleIsolation() ; // default ctor
31 virtual ~AliAnaParticleIsolation() { ; } //virtual dtor
33 // Main general methods
35 void CalculateCaloUEBand (AliAODPWG4ParticleCorrelation * pCandidate,
36 Float_t & etaBand, Float_t & phiBand) ;
37 void CalculateCaloCellUEBand(AliAODPWG4ParticleCorrelation * pCandidate,
38 Float_t & etaBand, Float_t & phiBand) ;
39 void CalculateTrackUEBand (AliAODPWG4ParticleCorrelation * pCandidate,
40 Float_t & etaBand, Float_t & phiBand) ;
42 void CalculateCaloSignalInCone (AliAODPWG4ParticleCorrelation * aodParticle, Float_t & coneptsumCluster) ;
43 void CalculateCaloCellSignalInCone(AliAODPWG4ParticleCorrelation * aodParticle, Float_t & coneptsumCell) ;
44 void CalculateTrackSignalInCone (AliAODPWG4ParticleCorrelation * aodParticle, Float_t & coneptsumTrack ) ;
46 Float_t CalculateExcessAreaFraction(const Float_t excess, const Float_t conesize);
48 void CalculateNormalizeUEBandPerUnitArea(AliAODPWG4ParticleCorrelation * pCandidate,
49 const Float_t coneptsumCluster,const Float_t coneptsumCell, const Float_t coneptsumTrack ) ;
51 TObjString * GetAnalysisCuts() ;
53 TList * GetCreateOutputObjects() ;
57 void InitParameters() ;
59 void MakeAnalysisFillAOD() ;
61 void MakeAnalysisFillHistograms() ;
64 void Print( const Option_t * opt ) const ;
66 //Analysis specific methods
68 void FillPileUpHistograms(Int_t clusterID) ;
70 void FillTrackMatchingShowerShapeControlHistograms(AliAODPWG4ParticleCorrelation * pCandidate,
71 const AliCaloTrackReader * reader,
72 const AliCaloPID * pid) ;
74 void MakeSeveralICAnalysis( AliAODPWG4ParticleCorrelation * ph ) ;
76 // Analysis Setters and Getters
78 TString GetCalorimeter() const { return fCalorimeter ; }
79 Int_t GetNCones() const { return fNCones ; }
80 Int_t GetNPtThresFrac() const { return fNPtThresFrac ; }
81 Float_t GetConeSizes(Int_t i) const { return fConeSizes[i] ; }
82 Float_t GetPtThresholds(Int_t i) const { return fPtThresholds[i] ; }
83 Float_t GetSumPtThresholds(Int_t i) const { return fSumPtThresholds[i]; }
84 Float_t GetPtFractions(Int_t i) const { return fPtFractions[i] ; }
86 void SetCalorimeter(TString & det) { fCalorimeter = det ; }
87 void SetNCones(Int_t ncs) { fNCones = ncs ; }
88 void SetNPtThresFrac(Int_t npt) { fNPtThresFrac = npt ; }
89 void SetConeSizes(Int_t i, Float_t r) { fConeSizes[i] = r ; }
90 void SetPtThresholds(Int_t i, Float_t pt) { fPtThresholds[i] = pt ; }
91 void SetPtFractions(Int_t i, Float_t pt) { fPtFractions[i] = pt ; }
92 void SetSumPtThresholds(Int_t i, Float_t pt){ fSumPtThresholds[i] = pt ; }
95 Bool_t IsReIsolationOn() const { return fReMakeIC ; }
96 void SwitchOnReIsolation() { fReMakeIC = kTRUE ; }
97 void SwitchOffReIsolation() { fReMakeIC = kFALSE ; }
99 Bool_t IsSeveralIsolationOn() const { return fMakeSeveralIC ; }
100 void SwitchOnSeveralIsolation() { fMakeSeveralIC = kTRUE ; }
101 void SwitchOffSeveralIsolation() { fMakeSeveralIC = kFALSE ; }
103 void SwitchOnFillPileUpHistograms() { fFillPileUpHistograms = kTRUE ; }
104 void SwitchOffFillPileUpHistograms() { fFillPileUpHistograms = kFALSE ; }
106 void SwitchOnTMHistoFill() { fFillTMHisto = kTRUE ; }
107 void SwitchOffTMHistoFill() { fFillTMHisto = kFALSE ; }
109 void SwitchOnSSHistoFill() { fFillSSHisto = kTRUE ; }
110 void SwitchOffSSHistoFill() { fFillSSHisto = kFALSE ; }
112 //Histogrammes setters and getters
114 void SetHistoPtSumRangeAndNBins(Float_t min, Float_t max, Int_t n) {
115 fHistoNPtSumBins = n ; fHistoPtSumMax = max ; fHistoPtSumMin = min ; }
117 Int_t GetHistoNPtSumBins() const { return fHistoNPtSumBins ; }
118 Float_t GetHistoPtSumMin() const { return fHistoPtSumMin ; }
119 Float_t GetHistoPtSumMax() const { return fHistoPtSumMax ; }
121 void SetHistoPtInConeRangeAndNBins(Float_t min, Float_t max, Int_t n) {
122 fHistoNPtInConeBins = n ; fHistoPtInConeMax = max ; fHistoPtInConeMin = min ; }
124 Int_t GetHistoNPtInConeBins() const { return fHistoNPtInConeBins; }
125 Float_t GetHistoPtInConeMin() const { return fHistoPtInConeMin ; }
126 Float_t GetHistoPtInConeMax() const { return fHistoPtInConeMax ; }
130 TString fCalorimeter ; // Calorimeter where neutral particles in cone for isolation are;
131 Bool_t fReMakeIC ; // Do isolation analysis
132 Bool_t fMakeSeveralIC ; // Do analysis for different IC
133 Bool_t fFillPileUpHistograms; // Fill pile-up related histograms
134 Bool_t fFillTMHisto; // Fill track matching plots
135 Bool_t fFillSSHisto; // Fill Shower shape plots
137 // Analysis data members for multiple cones and pt thresholds
138 Int_t fNCones ; //! Number of cone sizes to test
139 Int_t fNPtThresFrac ; //! Number of ptThres and ptFrac to test
141 Float_t fConeSizes[5] ; //! Array with cones to test
142 Float_t fPtThresholds[5] ; //! Array with pt thresholds to test
143 Float_t fPtFractions[5] ; //! Array with pt thresholds to test frac
144 Float_t fSumPtThresholds[5] ; //! Array with pt thresholds to test frac
148 TH1F * fhEIso ; //! Number of isolated particles vs energy
149 TH1F * fhPtIso ; //! Number of isolated particles vs pT
150 TH2F * fhPtCentralityIso ; //! centrality vs pT
151 TH2F * fhPtEventPlaneIso ; //! event plane angle vs pT
152 TH2F * fhPtNLocMaxIso ; //! Number of isolated particles vs NLM in cluster
153 TH2F * fhPhiIso ; //! Phi of isolated particles
154 TH2F * fhEtaIso ; //! eta of isolated particles
155 TH2F * fhEtaPhiIso ; //! eta vs phi of isolated particles
156 TH2F * fhEtaPhiNoIso ; //! eta vs phi of not isolated leading particles
157 TH1F * fhENoIso ; //! Number of not isolated leading particles vs Energy
158 TH1F * fhPtNoIso ; //! Number of not isolated leading particles vs pT
159 TH2F * fhPtNLocMaxNoIso ; //! Number of not isolated particles vs NLM in cluster
160 TH1F * fhPtDecayIso ; //! Number of isolated Pi0 decay particles (invariant mass tag)
161 TH1F * fhPtDecayNoIso ; //! Number of not isolated Pi0 decay leading particles (invariant mass tag)
162 TH2F * fhEtaPhiDecayIso ; //! eta vs phi of isolated Pi0 decay particles
163 TH2F * fhEtaPhiDecayNoIso ; //! eta vs phi of not isolated leading Pi0 decay particles
165 TH2F * fhPtInCone ; //! Cluster/track Pt in the cone
166 TH2F * fhPtClusterInCone ; //! Cluster Pt in the cone
167 TH2F * fhPtCellInCone ; //! Cell amplitude in the cone
168 TH2F * fhPtTrackInCone ; //! Track Pt in the cone
169 TH2F * fhPtTrackInConeOtherBC ; //! Track Pt in the cone, tracks out of main BC Time window
170 TH2F * fhPtTrackInConeOtherBCPileUpSPD ; //! Track Pt in the cone, tracks out of main BC Time window
171 TH2F * fhPtTrackInConeBC0 ; //! Track Pt in the cone, tracks in BC=0
172 TH2F * fhPtTrackInConeVtxBC0 ; //! Track Pt in the cone, tracks in BC=0
173 TH2F * fhPtTrackInConeBC0PileUpSPD ; //! Track Pt in the cone, tracks in BC=0
174 TH2F * fhPtInConePileUp[7] ; //! Particle Pt in the cone, if event is from pile-up (SPD method)
175 TH2F * fhPtInConeCent ; //! Particle Pt in the cone versus centrality
176 TH2F * fhPerpConeSumPt ; //! Sum Pt in cone at the perpendicular phi region to trigger axis (phi +90)
177 TH2F * fhPtInPerpCone ; //! Particle Pt in cone at the perpendicular phi region to trigger axis (phi +90)
179 TH2F * fhEtaBandCluster ; //! Accumulated pT in Eta band to estimate UE in cone, only clusters
180 TH2F * fhPhiBandCluster ; //! Accumulated pT in Phi band to estimate UE in cone, only clusters
181 TH2F * fhEtaBandTrack ; //! Accumulated pT in Eta band to estimate UE in cone, only tracks
182 TH2F * fhPhiBandTrack ; //! Accumulated pT in Phi band to estimate UE in cone, only tracks
183 TH2F * fhEtaBandCell ; //! Accumulated pT in Eta band to estimate UE in cone, only cells
184 TH2F * fhPhiBandCell ; //! Accumulated pT in Phi band to estimate UE in cone, only cells
186 TH2F * fhConeSumPt ; //! Cluster and tracks Sum Pt Sum Pt in the cone
187 TH2F * fhConeSumPtCellTrack ; //! Cells and tracks Sum Pt Sum Pt in the cone
188 TH2F * fhConeSumPtCell ; //! Cells Sum Pt Sum Pt in the cone
189 TH2F * fhConeSumPtCluster ; //! Clusters Sum Pt Sum Pt in the cone
190 TH2F * fhConeSumPtTrack ; //! Tracks Sum Pt Sum Pt in the cone
191 TH2F * fhConeSumPtEtaBandUECluster; //! Cluster Sum Pt in the eta band for clusters, before normalization
192 TH2F * fhConeSumPtPhiBandUECluster; //! Cluster Sum Pt in the phi band for clusters, before normalization
193 TH2F * fhConeSumPtEtaBandUETrack; //! Track Sum Pt in the eta band for tracks , before normalization
194 TH2F * fhConeSumPtPhiBandUETrack; //! Track Sum Pt in the phi badn for tracks , before normalization
195 TH2F * fhConeSumPtEtaBandUECell; //! Cell Sum amplitude in the eta band for cells, before normalization
196 TH2F * fhConeSumPtPhiBandUECell; //! Cell Sum amplitude in the phi band for cells, before normalization
198 TH2F * fhConeSumPtTrigEtaPhi ; //! Cluster and tracks Sum Pt Sum Pt in the cone, per eta-phi bin of trigger,
199 TH2F * fhConeSumPtCellTrackTrigEtaPhi ; //! Cell and tracks Sum Pt Sum Pt in the cone, per eta-phi bin of trigger,
200 TH2F * fhConeSumPtEtaBandUEClusterTrigEtaPhi; //! Cluster Sum Pt in the eta band for clusters, per eta-phi bin of trigger,before normalization
201 TH2F * fhConeSumPtPhiBandUEClusterTrigEtaPhi; //! Cluster Sum Pt in the phi band for clusters, per eta-phi bin of trigger, before normalization
202 TH2F * fhConeSumPtEtaBandUETrackTrigEtaPhi; //! Track Sum Pt in the eta band for tracks , per eta-phi bin of trigger, before normalization
203 TH2F * fhConeSumPtPhiBandUETrackTrigEtaPhi; //! Track Sum Pt in the phi badn for tracks , per eta-phi bin of trigger, before normalization
204 TH2F * fhConeSumPtEtaBandUECellTrigEtaPhi; //! Cluster Sum amplitude in the eta band for cells, per eta-phi bin of trigger, before normalization
205 TH2F * fhConeSumPtPhiBandUECellTrigEtaPhi; //! Cluster Sum amplitude in the phi band for cells, per eta-phi bin of trigger, before normalization
207 TH2F * fhConeSumPtEtaUESub; //! Cluster and tracks Sum Pt in the cone after bkg subtraction, vs pT trigger
208 TH2F * fhConeSumPtPhiUESub; //! Cluster and tracks Sum Pt in the cone after bkg subtraction, vs pT trigger
209 TH2F * fhConeSumPtEtaUESubTrigEtaPhi; //! Cluster and tracks Sum Pt in the cone after bkg subtraction, vs eta-phi trigger
210 TH2F * fhConeSumPtPhiUESubTrigEtaPhi; //! Cluster and tracks Sum Pt in the cone after bkg subtraction, vs eta-phi trigger
212 TH2F * fhConeSumPtEtaUESubTrackCell; //! Cluster and tracks Sum Pt in the cone after bkg subtraction, vs pT trigger
213 TH2F * fhConeSumPtPhiUESubTrackCell; //! Cluster and tracks Sum Pt in the cone after bkg subtraction, vs pT trigger
214 TH2F * fhConeSumPtEtaUESubTrackCellTrigEtaPhi;//! Cluster and tracks Sum Pt in the cone after bkg subtraction, vs eta-phi trigger
215 TH2F * fhConeSumPtPhiUESubTrackCellTrigEtaPhi;//! Cluster and tracks Sum Pt in the cone after bkg subtraction, vs eta-phi trigger
217 TH2F * fhConeSumPtEtaUESubCluster; //! Cluster Sum Pt in the cone after bkg subtraction, vs pT trigger
218 TH2F * fhConeSumPtPhiUESubCluster; //! Cluster Sum Pt in the cone after bkg subtraction, vs pT trigger
219 TH2F * fhConeSumPtEtaUESubClusterTrigEtaPhi; //! Cluster Sum Pt in the cone after bkg subtraction, vs eta-phi trigger
220 TH2F * fhConeSumPtPhiUESubClusterTrigEtaPhi; //! Cluster Sum Pt in the cone after bkg subtraction, vs eta-phi trigger
222 TH2F * fhConeSumPtEtaUESubCell; //! Cell Sum amplitude in the cone after bkg subtraction, vs pT trigger
223 TH2F * fhConeSumPtPhiUESubCell; //! Cell Sum amplitude in the cone after bkg subtraction, vs pT trigger
224 TH2F * fhConeSumPtEtaUESubCellTrigEtaPhi; //! Cell Sum amplitude in the cone after bkg subtraction, vs eta-phi trigger
225 TH2F * fhConeSumPtPhiUESubCellTrigEtaPhi; //! Cell Sum amplitude in the cone after bkg subtraction, vs eta-phi trigger
227 TH2F * fhConeSumPtEtaUESubTrack; //! Track Sum Pt in the cone after bkg subtraction, vs pT trigger
228 TH2F * fhConeSumPtPhiUESubTrack; //! Track Sum Pt in the cone after bkg subtraction, vs pT trigger
229 TH2F * fhConeSumPtEtaUESubTrackTrigEtaPhi; //! Track Sum Pt in the cone after bkg subtraction, vs eta-phi trigger
230 TH2F * fhConeSumPtPhiUESubTrackTrigEtaPhi; //! Track Sum Pt in the cone after bkg subtraction, vs eta-phi trigger
232 TH2F * fhFractionTrackOutConeEta; //! Fraction of cone out of tracks acceptance in eta
233 TH2F * fhFractionTrackOutConeEtaTrigEtaPhi; //! Fraction of cone out of tracks acceptance in eta, vs trigger eta-phi
234 TH2F * fhFractionClusterOutConeEta; //! Fraction of cone out of clusters acceptance in eta
235 TH2F * fhFractionClusterOutConeEtaTrigEtaPhi; //! Fraction of cone out of clusters acceptance in eta, vs trigger eta-phi
236 TH2F * fhFractionClusterOutConePhi; //! Fraction of cone out of clusters acceptance in phi
237 TH2F * fhFractionClusterOutConePhiTrigEtaPhi; //! Fraction of cone out of clusters acceptance in phi, vs trigger eta-phi
239 TH2F * fhFractionCellOutConeEta; //! Fraction of cone out of cells acceptance in eta
240 TH2F * fhFractionCellOutConeEtaTrigEtaPhi; //! Fraction of cone out of cells acceptance in eta, vs trigger eta-phi
241 TH2F * fhFractionCellOutConePhi; //! Fraction of cone out of cells acceptance in phi
242 TH2F * fhFractionCellOutConePhiTrigEtaPhi; //! Fraction of cone out of cells acceptance in phi, vs trigger eta-phi
244 TH2F * fhConeSumPtClustervsTrack ; //! Cluster vs tracks Sum Pt Sum Pt in the cone
245 TH2F * fhConeSumPtEtaUESubClustervsTrack ; //! Cluster vs tracks Sum Pt Sum Pt in the cone, after subtraction in eta band
246 TH2F * fhConeSumPtPhiUESubClustervsTrack ; //! Cluster vs tracks Sum Pt Sum Pt in the cone, after subtraction in phi band
247 TH2F * fhConeSumPtCellvsTrack; //! Cell vs tracks Sum Pt Sum Pt in the cone
248 TH2F * fhConeSumPtEtaUESubCellvsTrack ; //! Cell vs tracks Sum Pt Sum Pt in the cone, after subtraction in eta band
249 TH2F * fhConeSumPtPhiUESubCellvsTrack ; //! Cell vs tracks Sum Pt Sum Pt in the cone, after subtraction in phi band
251 TH2F * fhEtaBandClustervsTrack ; //! Accumulated pT in Eta band to estimate UE in cone, clusters vs tracks
252 TH2F * fhPhiBandClustervsTrack ; //! Accumulated pT in Phi band to estimate UE in cone, clusters vs tracks
253 TH2F * fhEtaBandNormClustervsTrack ; //! Accumulated pT in Eta band to estimate UE in cone, normalized to cone size, clusters vs tracks
254 TH2F * fhPhiBandNormClustervsTrack ; //! Accumulated pT in Phi band to estimate UE in cone, normalized to cone size, clusters vs tracks
255 TH2F * fhEtaBandCellvsTrack ; //! Accumulated pT in Eta band to estimate UE in cone, cells vs tracks
256 TH2F * fhPhiBandCellvsTrack ; //! Accumulated pT in Phi band to estimate UE in cone, cells vs tracks
257 TH2F * fhEtaBandNormCellvsTrack ; //! Accumulated pT cell in Eta band to estimate UE in cone, normalized to cone size, clusters vs tracks
258 TH2F * fhPhiBandNormCellvsTrack ; //! Accumulated pT cell in Phi band to estimate UE in cone, normalized to cone
260 TH2F * fhConeSumPtSubvsConeSumPtTotPhiTrack; //! Tracks, phi band: sum pT in cone after bkg sub vs sum pT in cone before bkg sub
261 TH2F * fhConeSumPtSubNormvsConeSumPtTotPhiTrack; //! Tracks, phi band: sum pT in cone after bkg sub normalized by sum pT in cone before bkg sub vs sum pT in cone before bkg sub
262 TH2F * fhConeSumPtSubvsConeSumPtTotEtaTrack; //! Tracks, eta band: sum pT in cone after bkg sub vs sum pT in cone before bkg sub
263 TH2F * fhConeSumPtSubNormvsConeSumPtTotEtaTrack; //! Tracks, eta band: sum pT in cone after bkg sub normalized by sum pT in cone before bkg sub vs sum pT in cone before bkg sub
264 TH2F * fhConeSumPtSubvsConeSumPtTotPhiCluster; //! Clusters, phi band: sum pT in cone after bkg sub vs sum pT in cone before bkg sub
265 TH2F * fhConeSumPtSubNormvsConeSumPtTotPhiCluster; //! Clusters, phi band: sum pT in cone after bkg sub normalized by sum pT in cone before bkg sub vs sum pT in cone before bkg sub
266 TH2F * fhConeSumPtSubvsConeSumPtTotEtaCluster; //! Clusters, eta band: sum pT in cone after bkg sub vs sum pT in cone before bkg sub
267 TH2F * fhConeSumPtSubNormvsConeSumPtTotEtaCluster; //! Clusters, eta band: sum pT in cone after bkg sub normalized by sum pT in cone before bkg sub vs sum pT in cone before bkg sub
268 TH2F * fhConeSumPtSubvsConeSumPtTotPhiCell; //! Cells, phi band: sum pT in cone after bkg sub vs sum pT in cone before bkg sub
269 TH2F * fhConeSumPtSubNormvsConeSumPtTotPhiCell; //! Cells, phi band: sum pT in cone after bkg sub normalized by sum pT in cone before bkg sub vs sum pT in cone before bkg sub
270 TH2F * fhConeSumPtSubvsConeSumPtTotEtaCell; //! Cells, eta band: sum pT in cone after bkg sub vs sum pT in cone before bkg sub
271 TH2F * fhConeSumPtSubNormvsConeSumPtTotEtaCell; //! Cells, eta band: sum pT in cone after bkg sub normalized by sum pT in cone before bkg sub vs sum pT in cone before bkg sub
275 TH1F * fhPtIsoPrompt; //! Number of isolated prompt gamma
276 TH2F * fhPhiIsoPrompt; //! Phi of isolated prompt gamma
277 TH2F * fhEtaIsoPrompt; //! eta of isolated prompt gamma
278 TH1F * fhPtThresIsolatedPrompt[5][5]; //! Isolated prompt gamma with pt threshold
279 TH1F * fhPtFracIsolatedPrompt[5][5]; //! Isolated prompt gamma with pt frac
280 TH2F * fhPtSumIsolatedPrompt[5]; //! Isolated prompt gamma with threshold on cone pt sume
281 TH1F * fhPtIsoFragmentation; //! Number of isolated fragmentation gamma
282 TH2F * fhPhiIsoFragmentation; //! Phi of isolated fragmentation gamma
283 TH2F * fhEtaIsoFragmentation; //! eta of isolated fragmentation gamma
284 TH1F * fhPtThresIsolatedFragmentation[5][5]; //! Isolated fragmentation gamma with pt threshold
285 TH1F * fhPtFracIsolatedFragmentation[5][5]; //! Isolated fragmentation gamma with pt frac
286 TH2F * fhPtSumIsolatedFragmentation[5]; //! Isolated fragmentation gamma with threshold on cone pt sume
287 TH1F * fhPtIsoPi0; //! Number of isolated pi0 (2 gamma)
288 TH2F * fhPhiIsoPi0; //! Phi of isolated pi0 (2 gamma)
289 TH2F * fhEtaIsoPi0; //! eta of isolated pi0 (2 gamma)
290 TH1F * fhPtThresIsolatedPi0[5][5]; //! Isolated pi0 (2 gamma) with pt threshold
291 TH1F * fhPtFracIsolatedPi0[5][5]; //! Isolated pi0 (2 gamma) with pt frac
292 TH2F * fhPtSumIsolatedPi0[5]; //! Isolated pi0 (2 gamma) with threshold on cone pt sum
293 TH1F * fhPtIsoPi0Decay; //! Number of isolated pi0 decay gamma
294 TH2F * fhPhiIsoPi0Decay; //! Phi of isolated pi0 decay gamma
295 TH2F * fhEtaIsoPi0Decay; //! eta of isolated pi0 decay gamma
296 TH1F * fhPtThresIsolatedPi0Decay[5][5]; //! Isolated pi0 decay gamma with pt threshold
297 TH1F * fhPtFracIsolatedPi0Decay[5][5]; //! Isolated pi0 decay gamma with pt frac
298 TH2F * fhPtSumIsolatedPi0Decay[5]; //! Isolated pi0 decay gamma with threshold on cone pt sume
299 TH1F * fhPtIsoEtaDecay; //! Number of isolated eta decay gamma
300 TH2F * fhPhiIsoEtaDecay; //! Phi of isolated eta decay gamma
301 TH2F * fhEtaIsoEtaDecay; //! eta of isolated eta decay gamma
302 TH1F * fhPtThresIsolatedEtaDecay[5][5]; //! Isolated eta decay gamma with pt threshold
303 TH1F * fhPtFracIsolatedEtaDecay[5][5]; //! Isolated eta decay gamma with pt frac
304 TH2F * fhPtSumIsolatedEtaDecay[5]; //! Isolated eta fecay gamma with threshold on cone pt sume
305 TH1F * fhPtIsoOtherDecay; //! Number of isolated other decay gamma
306 TH2F * fhPhiIsoOtherDecay; //! Phi of isolated other decay gamma
307 TH2F * fhEtaIsoOtherDecay; //! eta of isolated other decay gamma
308 TH1F * fhPtThresIsolatedOtherDecay[5][5]; //! Isolated OtherDecay gamma with pt threshold
309 TH1F * fhPtFracIsolatedOtherDecay[5][5]; //! Isolated OtherDecay gamma with pt frac
310 TH2F * fhPtSumIsolatedOtherDecay[5]; //! Isolated OtherDecay gamma with threshold on cone pt sume
311 // TH1F * fhPtIsoConversion; //! Number of isolated Conversion gamma
312 // TH2F * fhPhiIsoConversion; //! Phi of isolated Conversion gamma
313 // TH2F * fhEtaIsoConversion; //! eta of isolated Conversion gamma
314 // TH1F * fhPtThresIsolatedConversion[5][5]; //! Isolated Conversion gamma with pt threshold
315 // TH1F * fhPtFracIsolatedConversion[5][5]; //! Isolated Conversion gamma with pt frac
316 // TH2F * fhPtSumIsolatedConversion[5]; //! Isolated Conversion gamma with threshold on cone pt sume
317 TH1F * fhPtIsoHadron; //! Number of isolated Hadron
318 TH2F * fhPhiIsoHadron; //! Phi of isolated Hadron
319 TH2F * fhEtaIsoHadron; //! eta of isolated Hadron
320 TH1F * fhPtThresIsolatedHadron[5][5]; //! Isolated Hadron gamma with pt threshold
321 TH1F * fhPtFracIsolatedHadron[5][5]; //! Isolated Hadron gamma with pt frac
322 TH2F * fhPtSumIsolatedHadron[5]; //! Isolated Hadron gamma with threshold on cone pt sume
324 // Multi Cut analysis Several IC
325 TH1F * fhPtNoIsoPi0; //! Number of not isolated leading pi0 (2 gamma)
326 TH1F * fhPtNoIsoPi0Decay; //! Number of not isolated leading pi0 decay gamma
327 TH1F * fhPtNoIsoEtaDecay; //! Number of not isolated leading eta decay gamma
328 TH1F * fhPtNoIsoOtherDecay; //! Number of not isolated leading other decay gamma
329 TH1F * fhPtNoIsoPrompt; //! Number of not isolated leading prompt gamma
330 TH1F * fhPtIsoMCPhoton; //! Number of isolated leading gamma
331 TH1F * fhPtNoIsoMCPhoton; //! Number of not isolated leading gamma
332 // TH1F * fhPtNoIsoConversion; //! Number of not isolated leading conversion gamma
333 TH1F * fhPtNoIsoFragmentation; //! Number of not isolated leading fragmentation gamma
334 TH1F * fhPtNoIsoHadron; //! Number of not isolated leading hadrons
336 TH2F * fhSumPtLeadingPt[5] ; //! Sum Pt in the cone
337 TH2F * fhPtLeadingPt[5] ; //! Particle Pt in the cone
338 TH2F * fhPerpSumPtLeadingPt[5] ; //! Sum Pt in the cone at the perpendicular phi region to trigger axis (phi +90)
339 TH2F * fhPerpPtLeadingPt[5]; //! Sum Pt in the cone at the perpendicular phi region to trigger axis (phi +90)
341 TH1F * fhPtThresIsolated[5][5] ; //! Isolated particle with pt threshold
342 TH1F * fhPtFracIsolated[5][5] ; //! Isolated particle with pt threshold frac
343 TH1F * fhPtSumIsolated[5][5] ; //! Isolated particle with threshold on cone pt sum
345 TH2F * fhEtaPhiPtThresIso[5][5] ; //! eta vs phi of isolated particles with pt threshold
346 TH2F * fhEtaPhiPtThresDecayIso[5][5] ; //! eta vs phi of isolated particles with pt threshold
347 TH1F * fhPtPtThresDecayIso[5][5] ; //! Number of isolated Pi0 decay particles (invariant mass tag) with pt threshold
349 TH2F * fhEtaPhiPtFracIso[5][5] ; //! eta vs phi of isolated particles with pt frac
350 TH2F * fhEtaPhiPtFracDecayIso[5][5] ; //! eta vs phi of isolated particles with pt frac
351 TH1F * fhPtPtFracDecayIso[5][5] ; //! Number of isolated Pi0 decay particles (invariant mass tag) with pt fra
353 TH2F * fhEtaPhiPtSumIso[5][5] ; //! eta vs phi of isolated particles with pt sum
354 TH2F * fhEtaPhiPtSumDecayIso[5][5] ; //! eta vs phi of isolated particles with pt sum
355 TH1F * fhPtPtSumDecayIso[5][5] ; //! Number of isolated Pi0 decay particles (invariant mass tag) with pt sum
357 TH2F * fhEtaPhiSumDensityIso[5][5]; //! Isolated particle with threshold on cone sum density
358 TH2F * fhEtaPhiSumDensityDecayIso[5][5]; //! Isolated particle with threshold on cone sum density
359 TH1F * fhPtSumDensityIso[5][5]; //! Isolated particle with threshold on cone sum density
360 TH1F * fhPtSumDensityDecayIso[5][5]; //! Isolated decay particle with threshold on cone sum density
362 TH1F * fhPtFracPtSumIso[5][5] ; //! Number of isolated Pi0 decay particles (invariant mass tag) with pt sum
363 TH1F * fhPtFracPtSumDecayIso[5][5] ; //! Number of isolated Pi0 decay particles (invariant mass tag) with pt sum
364 TH2F * fhEtaPhiFracPtSumIso[5][5]; //! Isolated particle with threshold on cone sum density
365 TH2F * fhEtaPhiFracPtSumDecayIso[5][5]; //! Isolated particle with threshold on cone sum density
367 // Track matching studies
368 TH2F * fhTrackMatchedDEta[2] ; //! Eta distance between track and cluster vs cluster E
369 TH2F * fhTrackMatchedDPhi[2] ; //! Phi distance between track and cluster vs cluster E
370 TH2F * fhTrackMatchedDEtaDPhi[2] ; //! Eta vs Phi distance between track and cluster, E cluster > 0.5 GeV
371 TH2F * fhdEdx[2] ; //! matched track dEdx vs cluster E
372 TH2F * fhEOverP[2]; //! matched track E cluster over P track vs cluster E, after dEdx cut
373 TH2F * fhTrackMatchedMCParticle[2]; //! Trace origin of matched particle
375 // Shower Shape histograms
376 TH2F * fhELambda0[2]; //! Shower shape of (non) isolated photons (do not apply SS cut previously)
377 TH2F * fhELambda1[2]; //! Shower shape of (non) isolated photons (do not apply SS cut previously)
378 TH2F * fhELambda0SSBkg; //! Shower shape of non isolated photons close to isolation threshold (do not apply SS cut previously)
379 TH2F * fhELambda0TRD[2]; //! Shower shape of (non) isolated photons, SM behind TRD (do not apply SS cut previously)
380 TH2F * fhELambda1TRD[2]; //! Shower shape of (non) isolated photons, SM behind TRD (do not apply SS cut previously)
381 TH2F * fhELambda0MCPhoton[2]; //! Shower shape of (non) isolated photon candidates originated by particle photon not decay (do not apply SS cut previously)
382 TH2F * fhELambda0MCPi0[2]; //! Shower shape of (non) isolated photon candidates originated by particle 2 merged pi0 photons (do not apply SS cut previously)
383 TH2F * fhELambda0MCPi0Decay[2]; //! Shower shape of (non) isolated photon candidates originated by particle pi0 decay photon (do not apply SS cut previously)
384 TH2F * fhELambda0MCEtaDecay[2]; //! Shower shape of (non) isolated photon candidates originated by particle eta decay photon (do not apply SS cut previously)
385 TH2F * fhELambda0MCOtherDecay[2]; //! Shower shape of (non) isolated photon candidates originated by particle other decay photon (do not apply SS cut previously)
386 TH2F * fhELambda0MCHadron[2]; //! Shower shape of (non) isolated photon candidates originated by particle other hadrons (do not apply SS cut previously)
389 TH2F * fhNLocMax[2]; //! number of maxima in selected clusters
390 TH2F * fhELambda0LocMax1[2] ; //! E vs lambda0 of selected cluster, 1 local maxima in cluster
391 TH2F * fhELambda1LocMax1[2] ; //! E vs lambda1 of selected cluster, 1 local maxima in cluster
392 TH2F * fhELambda0LocMax2[2] ; //! E vs lambda0 of selected cluster, 2 local maxima in cluster
393 TH2F * fhELambda1LocMax2[2] ; //! E vs lambda1 of selected cluster, 2 local maxima in cluster
394 TH2F * fhELambda0LocMaxN[2] ; //! E vs lambda0 of selected cluster, N>2 local maxima in cluster
395 TH2F * fhELambda1LocMaxN[2] ; //! E vs lambda1 of selected cluster, N>2 local maxima in cluster
398 TH1F * fhEIsoPileUp[7] ; //! Number of isolated particles
399 TH1F * fhPtIsoPileUp[7] ; //! Number of isolated particles
400 TH1F * fhENoIsoPileUp[7] ; //! Number of not isolated particles
401 TH1F * fhPtNoIsoPileUp[7] ; //! Number of not isolated particles
402 TH2F * fhTimeENoCut; //! time of cluster vs E, no cut
403 TH2F * fhTimeESPD; //! time of cluster vs E, IsSPDPileUp
404 TH2F * fhTimeESPDMulti; //! time of cluster vs E, IsSPDPileUpMulti
405 TH2F * fhTimeNPileUpVertSPD; //! time of cluster vs n pile-up vertices from SPD
406 TH2F * fhTimeNPileUpVertTrack; //! time of cluster vs n pile-up vertices from Tracks
407 TH2F * fhTimeNPileUpVertContributors; //! time of cluster vs n pile-up vertex from SPD contributors
408 TH2F * fhTimePileUpMainVertexZDistance; //! time of cluster vs difference of z main vertex and pile-up vertex
409 TH2F * fhTimePileUpMainVertexZDiamond; //! time of cluster vs difference of z diamond and pile-up vertex
411 //Histograms settings
412 Int_t fHistoNPtSumBins; // Number of bins in PtSum histograms
413 Float_t fHistoPtSumMax; // PtSum maximum in histogram
414 Float_t fHistoPtSumMin; // PtSum minimum in histogram
415 Int_t fHistoNPtInConeBins; // Number of bins in PtInCone histogram
416 Float_t fHistoPtInConeMax; // PtInCone maximum in histogram
417 Float_t fHistoPtInConeMin; // PtInCone maximum in histogram
419 AliAnaParticleIsolation( const AliAnaParticleIsolation & iso) ; // cpy ctor
420 AliAnaParticleIsolation & operator = (const AliAnaParticleIsolation & iso) ; // cpy assignment
422 ClassDef(AliAnaParticleIsolation,23)
426 #endif //ALIANAPARTICLEISOLATION_H