14 #include "AliVTrack.h" 33 fPlotOversubtractionHistograms(kFALSE),
34 fDoNotOversubtract(kFALSE),
35 fUseM02SubtractionScheme(kFALSE),
36 fUseConstantSubtraction(kFALSE),
37 fConstantSubtractionValue(0.),
38 fClusterContainerIndexMap(),
39 fParticleContainerIndexMap(),
40 fTrackToContainerMap(),
41 fHistMatchEtaPhiAll(0),
42 fHistMatchEtaPhiAllCl(0),
44 fHistNclusMatchvsCent(0),
49 fHistNClusMatchCent(0)
51 for(
Int_t i=0; i<10; i++) {
68 for(
Int_t j=0; j<4; j++)
72 for(
Int_t j=0; j<9; j++) {
73 for(
Int_t k=0; k<2; k++)
129 for(
Int_t icent=0; icent<nCentChBins; ++icent) {
130 for(
Int_t ipt=0; ipt<9; ++ipt) {
131 for(
Int_t ieta=0; ieta<2; ++ieta) {
132 name = Form(
"fHistMatchEtaPhi_%i_%i_%i",icent,ipt,ieta);
140 name = Form(
"fHistEsubPch_%i",icent);
141 temp = Form(
"%s (Nmatches==1)",name.Data());
143 fHistEsubPch[icent]->SetXTitle(
"#sum p (GeV) weighted with E_{sub}");
144 fOutput->Add(fHistEsubPch[icent]);
146 name = Form(
"fHistEsubPchRat_%i",icent);
147 temp = Form(
"%s (Nmatches==1)",name.Data());
149 fHistEsubPchRat[icent]->SetXTitle(
"#Sigma p (GeV)");
150 fHistEsubPchRat[icent]->SetYTitle(
"E_{sub} / #sum p");
151 fOutput->Add(fHistEsubPchRat[icent]);
154 for(
Int_t itrk=0; itrk<4; ++itrk) {
155 name = Form(
"fHistNCellsEnergy_%i_%i",icent,itrk);
156 temp = Form(
"%s (Nmatches==%d);N_{cells};E_{clus} (GeV)",name.Data(),itrk);
158 fOutput->Add(fHistNCellsEnergy[icent][itrk]);
161 name = Form(
"fHistEsubPchRatAll_%i",icent);
162 temp = Form(
"%s (all Nmatches)",name.Data());
164 fHistEsubPchRatAll[icent]->SetXTitle(
"#Sigma p (GeV)");
165 fHistEsubPchRatAll[icent]->SetYTitle(
"E_{sub} / #sum p");
166 fOutput->Add(fHistEsubPchRatAll[icent]);
168 name = Form(
"fHistMatchEvsP_%i",icent);
169 temp = Form(
"%s (all Nmatches)",name.Data());
171 fHistMatchEvsP[icent]->SetXTitle(
"E_{clus} (GeV)");
172 fHistMatchEvsP[icent]->SetYTitle(
"E_{clus} / #sum p");
173 fOutput->Add(fHistMatchEvsP[icent]);
175 name = Form(
"fHistMatchdRvsEP_%i",icent);
176 temp = Form(
"%s (all Nmatches)",name.Data());
178 fHistMatchdRvsEP[icent]->SetXTitle(
"#Delta R between track and cluster");
179 fHistMatchdRvsEP[icent]->SetYTitle(
"E_{clus} / p");
180 fOutput->Add(fHistMatchdRvsEP[icent]);
182 name = Form(
"fHistNMatchEnergy_%i",icent);
190 fHistNclusvsCent =
new TH1F(
"Nclusvscent",
"NclusVsCent; Cent (%)", 100, 0, 100);
191 fHistNclusMatchvsCent =
new TH1F(
"NclusMatchvscent",
"NclusMatchVsCent (all Nmatches); Cent (%)", 100, 0, 100);
192 fHistEbefore =
new TH1F(
"Ebefore",
"Ebefore; Cent (%); E_{clus} (GeV)", 100, 0, 100);
193 fHistEafter =
new TH1F(
"Eafter",
"Eafter; Cent (%); E_{clus} (GeV)", 100, 0, 100);
195 fHistNMatchCent =
new TH2F(
"NMatchesCent",
"NMatchesCent; Cent (%); Nmatches", 100, 0, 100, 11, -0.5, 10.5);
196 fHistNClusMatchCent =
new TH2F(
"NClusMatchesCent",
"NClusMatchesCent; Cent (%); Nmatches", 100, 0, 100, 11, -0.5, 10.5);
208 name = Form(
"fHistEmbTrackMatchesOversub_%d",icent);
214 name = Form(
"fHistNonEmbTrackMatchesOversub_%d",icent);
220 name = Form(
"fHistOversubMCClusters_%d",icent);
226 name = Form(
"fHistOversubNonMCClusters_%d",icent);
232 name = Form(
"fHistOversub_%d",icent);
234 fHistOversub[icent]->GetXaxis()->SetTitle(
"E_{clus}^{raw} (GeV)");
235 fHistOversub[icent]->GetYaxis()->SetTitle(
"E_{oversub} / E_{clus}^{raw}");
267 AliVCluster *cluster = 0;
270 while ((clusCont = static_cast<AliClusterContainer*>(nextClusCont()))) {
273 cluster =
static_cast<AliVCluster *
>(clusIterator->second);
291 energyclus = cluster->GetNonLinCorrEnergy();
294 if (energyclus < 0) energyclus = 0;
296 cluster->SetHadCorrEnergy(energyclus);
324 if (!partCont) { AliErrorStream() <<
"Failed to retrieve particle container at index " << i <<
"\n"; }
327 AliVTrack * track =
static_cast<AliVTrack *
>(partCont->
GetParticle(j));
341 else if (p>=0.5 && p<1.0)
343 else if (p>=1.0 && p<1.5)
345 else if (p>=1.5 && p<2.)
347 else if (p>=2. && p<3.)
349 else if (p>=3. && p<4.)
351 else if (p>=4. && p<5.)
353 else if (p>=5. && p<8.)
366 Double_t EtaSigma[9]={0.0097,0.0075,0.0059,0.0055,0.0053,0.005,0.005,0.0045,0.0042};
367 return 2.0*EtaSigma[pbin];
385 return PhiMean[pbin];
386 }
else if (centbin==1) {
396 return PhiMean[pbin];
397 }
else if (centbin==2) {
407 return PhiMean[pbin];
408 }
else if (centbin==3) {
418 return PhiMean[pbin];
419 }
else if (centbin==4) {
429 return PhiMean[pbin]*(-1.);
430 }
else if (centbin==5) {
440 return PhiMean[pbin]*(-1.);
441 }
else if (centbin==6) {
451 return PhiMean[pbin]*(-1.);
452 }
else if (centbin==7) {
462 return PhiMean[pbin]*(-1.);
483 return 2.*PhiSigma[pbin];
484 }
else if (centbin==1) {
494 return 2.*PhiSigma[pbin];
495 }
else if (centbin==2) {
505 return 2.*PhiSigma[pbin];
506 }
else if (centbin==3) {
516 return 2.*PhiSigma[pbin];
517 }
else if (centbin==4) {
527 return 2.*PhiSigma[pbin];
528 }
else if (centbin==5) {
538 return 2.*PhiSigma[pbin];
539 }
else if (centbin==6) {
549 return 2.*PhiSigma[pbin];
550 }
else if (centbin==7) {
560 return 2.*PhiSigma[pbin];
574 if (!cluster)
return;
577 Int_t Ntrks = cluster->GetNTracksMatched();
578 for (
Int_t i = 0; i < Ntrks; ++i) {
579 AliVTrack* track = 0;
582 Int_t itrack = cluster->GetTrackMatchedIndex(i);
585 track =
static_cast<AliVTrack*
>(res.second->GetAcceptParticle(res.first));
589 track =
static_cast<AliVTrack*
>(cluster->GetTrackMatched(i));
590 UInt_t rejectionReason = 0;
592 if (!partCont) { AliErrorStream() <<
"Requested particle container not available!\n"; }
596 if (!track)
continue;
604 if (
fDoTrackClus && (track->GetEMCALcluster() != icluster))
continue;
610 if (track->Charge() < 0) centbinch +=
fNcentBins;
614 if (track->Eta() > 0) etabin=1;
639 if ((phidiff < phiCuthi && phidiff > phiCutlo) && TMath::Abs(etadiff) < etaCut) {
652 Double_t dR = TMath::Sqrt(dphi*dphi + deta*deta);
653 Double_t energyclus = cluster->GetNonLinCorrEnergy();
660 if (totalTrkP > 0) trkPMCfrac /= totalTrkP;
670 Double_t energyclus = cluster->GetNonLinCorrEnergy();
672 AliVTrack* track = 0;
674 if (cluster->GetNTracksMatched() > 0) {
676 Int_t itrack = cluster->GetTrackMatchedIndex(0);
679 track =
static_cast<AliVTrack*
>(res.second->GetAcceptParticle(res.first));
683 track =
static_cast<AliVTrack*
>(cluster->GetTrackMatched(0));
684 UInt_t rejectionReason = 0;
686 if (!partCont) { AliErrorStream() <<
"Requested particle container not available!\n"; }
691 if (!track || track->P() < 1e-6)
return energyclus;
702 Int_t cid = track->GetEMCALcluster();
703 if (
fDoTrackClus && (cid != icluster))
return energyclus;
707 if (track->Charge() < 0) centbinch +=
fNcentBins;
712 if(track->Eta() > 0) etabin = 1;
721 Double_t dRmin = TMath::Sqrt(etadiff*etadiff + phidiff*phidiff);
748 if ((dPhiMin < phiCuthi && dPhiMin > phiCutlo) && TMath::Abs(dEtaMin) < etaCut) {
749 energyclus -= hadCorr * mom;
762 Double_t energyclus = cluster->GetNonLinCorrEnergy();
763 Double_t cNcells = cluster->GetNCells();
769 Int_t NMCmatches = 0;
774 Double_t Esub = hadCorr * totalTrkP;
776 if (Esub > energyclus) Esub = energyclus;
781 if (energyclus < clusEexcl) clusEexcl = energyclus;
782 if ((energyclus - Esub) < clusEexcl) Esub = (energyclus - clusEexcl);
799 EsubMC = hadCorr * totalTrkP * trkPMCfrac;
800 EsubBkg = hadCorr * totalTrkP - EsubMC;
801 EclusMC = energyclus * cluster->GetMCEnergyFraction();
802 EclusBkg = energyclus - EclusMC;
804 if (energyclus > Esub)
805 EclusCorr = energyclus - Esub;
807 if (EclusMC > EsubMC)
808 EclusMCcorr = EclusMC - EsubMC;
810 if (EclusBkg > EsubBkg)
811 EclusBkgcorr = EclusBkg - EsubBkg;
813 overSub = EclusMCcorr + EclusBkgcorr - EclusCorr;
831 Double_t EoP = energyclus / totalTrkP;
838 AliVTrack* track = 0;
840 Int_t itrack = cluster->GetTrackMatchedIndex(0);
843 track =
static_cast<AliVTrack*
>(res.second->GetAcceptParticle(res.first));
847 track =
static_cast<AliVTrack*
>(cluster->GetTrackMatched(0));
848 UInt_t rejectionReason = 0;
850 if (!partCont) { AliErrorStream() <<
"Requested particle container not available!\n"; }
855 if (track->Charge() < 0) centbinchm +=
fNcentBins;
864 if (cluster->GetMCEnergyFraction() > 0.95)
866 else if (cluster->GetMCEnergyFraction() < 0.05)
869 if (trkPMCfrac < 0.05)
871 else if (trkPMCfrac > 0.95)
879 if (EclusBkgcorr + EclusMCcorr > 0) {
880 Double_t newfrac = EclusMCcorr / (EclusBkgcorr + EclusMCcorr);
881 cluster->SetMCEnergyFraction(newfrac);
897 Double_t clusM02 = cluster->GetM02();
902 if (clusM02 > 0.1 && clusM02 < 0.4) {
917 else if (Nmatches == 1) {
922 Esub = hadCorr * totalTrkP;
925 else if (Nmatches > 1) {
Int_t fNcentBins
How many centrality bins (this member copied from AliAnalysisTaskEmcal)
Bool_t fEsdMode
flag for ESD
Double_t fHadCorr
hadronic correction (fraction)
AliParticleContainer * GetParticleContainer(Int_t i=0) const
TH2 * fHistMatchEtaPhiAll
!deta vs. dphi of matched cluster-track pairs
TH2 * fHistMatchEtaPhi[10][9][2]
!deta vs. dphi of matched cluster-track pairs
const AliClusterIterableMomentumContainer accepted_momentum() const
TH2 * fHistNonEmbTrackMatchesOversub[5]
!Over-subtracted energy / cluster energy with non-embedded track matches (embedded matches < 5%) ...
bidirectional stl iterator over the EMCAL iterable container
TH2 * fHistNMatchEnergy[5]
!n matches vs. cluster energy
std::pair< int, U * > LocalIndexFromGlobalIndex(const int globalIndex) const
TH2 * fHistOversubMCClusters[5]
!Over-subtracted energy / cluster energy (cluster MC energy fraction > 95%)
Int_t GetNParticles() const
Bool_t fUseConstantSubtraction
Flag to perform constant rather than fractional subtract (only applicable if using M02 scheme) ...
static RegisterCorrectionComponent< AliEmcalCorrectionClusterHadronicCorrection > reg
TH2 * fHistOversubNonMCClusters[5]
!Over-subtracted energy / cluster energy (cluster MC energy fraction < 5%)
virtual void UserCreateOutputObjects()
Bool_t fDoNotOversubtract
do not oversubtract energy from cluster (embedding only)
AliEmcalContainerIndexMap< AliClusterContainer, AliVCluster > fClusterContainerIndexMap
! Mapping between index and cluster containers
TH2 * fHistMatchEvsP[5]
!cluster energy vs. track momentum of matched pairs
Int_t fCentBin
! Event centrality bin
int GlobalIndexFromLocalIndex(const U *inputObject, const int localIndex) const
TH1 * fHistEsubPch[10]
!Esub vs. total momentum of matched tracks (only 1 match)
Container for particles within the EMCAL framework.
Double_t fEtaMatch
eta match value (pp=0.025)
TObjArray fParticleCollArray
Particle/track collection array.
Double_t ApplyHadCorrOneTrack(Int_t icluster, Double_t hadCorr)
TObjArray fClusterCollArray
Cluster collection array.
TH1 * fHistEafter
!average energy of clusters after correction vs. centrality
TH2 * fHistEsubPchRatAll[5]
!Esub/momentum of matched tracks vs. total momentum of matched tracks (all number of matches) ...
Double_t ApplyHadCorrAllTracks(Int_t icluster, Double_t hadCorr)
TH2 * fHistNCellsEnergy[5][4]
!n cells vs. cluster energy
Base class for correction components in the EMCal correction framework.
TH2 * fHistEsubPchRat[10]
!Esub/momentum of matched tracks vs. total momentum of matched tracks (only 1 match) ...
virtual AliVParticle * GetParticle(Int_t i=-1) const
Double_t fEexclCell
energy/cell that we cannot subtract from the clusters
TH2 * fHistNMatchCent
!n matches vs. centraity
static const AliEmcalContainerIndexMap< TClonesArray, AliVCluster > & GetEmcalContainerIndexMap()
Get the EMCal container utils associated with particle containers.
std::map< AliVTrack *, AliParticleContainer * > fTrackToContainerMap
! Mapping between AliVTracks and their respective particle containers. Needed for AODs only...
Int_t fMinMCLabel
Minimum MC label value for the tracks/clusters being considered MC particles.
TH2 * fHistEoPCent
!E/P vs. centrality
V * GetObjectFromGlobalIndex(const int globalIndex) const
Double_t fPhiMatch
phi match value (pp=0.050)
virtual Bool_t AcceptParticle(const AliVParticle *vp, UInt_t &rejectionReason) const
AliEmcalCorrectionClusterHadronicCorrection()
Double_t GetPhiSigma(Int_t pbin, Int_t centbin) const
Double_t fMaxBinPt
Max pt in histograms.
Bool_t fPlotOversubtractionHistograms
compute and plot oversubtracted energy from embedded/signal matches (embedding only) ...
TList * fOutput
! List of output histograms
Double_t ComputeM02Subtraction(const AliVCluster *cluster, Double_t energyclus, Int_t Nmatches, Double_t totalTrkP, Double_t hadCorr)
Bool_t fCreateHisto
Flag to make some basic histograms.
Hadronic correction component in the EMCal correction framework.
TH1 * fHistEbefore
!average energy of clusters before correction vs. centrality
Double_t GetEtaSigma(Int_t pbin) const
Double_t fCent
! Event centrality
virtual Bool_t Initialize()
void DoMatchedTracksLoop(Int_t icluster, Double_t &totalTrkP, Int_t &Nmatches, Double_t &trkPMCfrac, Int_t &NMCmatches)
void GenerateTrackToContainerMap()
Double_t fMinBinPt
Min pt in histograms.
void CopyMappingFrom(const AliEmcalContainerIndexMap< U2, V > &map, U *cont)
TH1 * fHistNclusMatchvsCent
!n clusters matched to some track vs. centrality
TH2 * fHistMatchdRvsEP[5]
!matching distance vs. E/P
void GetEtaPhiDiff(const AliVTrack *t, const AliVCluster *v, Double_t &phidiff, Double_t &etadiff)
Bool_t fDoTrackClus
loop over tracks first
Int_t fNbins
No. of pt bins.
AliEmcalContainerIndexMap< AliParticleContainer, AliVParticle > fParticleContainerIndexMap
! Mapping between index and particle containers
Bool_t fUseM02SubtractionScheme
Flag to enable hadronic correction scheme using cluster M02 value.
Container structure for EMCAL clusters.
TH2 * fHistOversub[5]
!Over-subtracted energy / cluster energy
TH2 * fHistEmbTrackMatchesOversub[5]
!Over-subtracted energy / cluster energy with embedded track matches (non-embedded matches < 5%) ...
void UserCreateOutputObjects()
UInt_t GetMomBin(Double_t pt) const
TH1 * fHistNclusvsCent
!n clusters vs. centrality
static const AliEmcalContainerIndexMap< TClonesArray, AliVParticle > & GetEmcalContainerIndexMap()
Get the EMCal container utils associated with particle containers.
TH2 * fHistMatchEtaPhiAllCl
!deta vs. dphi of all cluster-track pairs (cl loop)
virtual ~AliEmcalCorrectionClusterHadronicCorrection()
Double_t GetPhiMean(Int_t pbin, Int_t centbin) const
TH2 * fHistNClusMatchCent
!n clusters macthed to some track (tracks allowed to match more than one cluster) ...
bool GetProperty(std::string propertyName, T &property, bool requiredProperty=true, std::string correctionName="")
Retrieve property.
Double_t fConstantSubtractionValue
Value to be used for constant subtraction (only applicable if using constant subtraction in M02 schem...