/* $Id: CreateCuts.C,v 1.5 2008/01/11 08:28:52 jgrosseo Exp $ */
-// this macro creates the track and event cuts used in this analysis
+// this macro creates the track cuts used in this analysis
-AliESDtrackCuts* CreateTrackCuts(AliPWG0Helper::AnalysisMode analysisMode, Bool_t fieldOn = kTRUE, Bool_t hists = kTRUE)
+AliESDtrackCuts* CreateTrackCuts(AliPWG0Helper::AnalysisMode analysisMode, Bool_t hists = kTRUE, Float_t ptMin = 0, Float_t etacut =1e10)
{
- AliESDtrackCuts* esdTrackCuts = new AliESDtrackCuts("AliESDtrackCuts");
+ AliESDtrackCuts* esdTrackCuts = 0;
+
+ // see https://twiki.cern.ch/twiki/bin/view/ALICE/SelectionOfPrimaryTracksForPp2009DataAnalysis
+
+ if (analysisMode & AliPWG0Helper::kTPC)
+ {
+ esdTrackCuts = new AliESDtrackCuts("AliESDtrackCuts");
- if (hists)
- esdTrackCuts->DefineHistograms(1);
+ TString tag("TPC-only tracking");
- // default cuts for ITS+TPC
- Double_t cov1 = 2;
- Double_t cov2 = 2;
- Double_t cov3 = 0.5;
- Double_t cov4 = 0.5;
- Double_t cov5 = 2;
- Double_t nSigma = 4;
+ esdTrackCuts->SetMaxDCAToVertexZ(3.2);
+ esdTrackCuts->SetMaxDCAToVertexXY(2.4);
+ esdTrackCuts->SetDCAToVertex2D(kTRUE);
+
+ esdTrackCuts->SetRequireTPCRefit(kTRUE);
+ esdTrackCuts->SetAcceptKinkDaughters(kFALSE);
+ esdTrackCuts->SetMinNClustersTPC(70);
+ esdTrackCuts->SetMaxChi2PerClusterTPC(4);
+ }
- Bool_t tpcRefit = kTRUE;
+ if (analysisMode & AliPWG0Helper::kTPCITS)
+ {
+ esdTrackCuts = AliESDtrackCuts::GetStandardITSTPCTrackCuts2009(kTRUE);
+ esdTrackCuts->SetPtRange(ptMin); // adding pt cut
+ esdTrackCuts->SetEtaRange(-etacut,etacut);
+ TString tag("Global tracking");
+ }
+ if ( analysisMode & AliPWG0Helper::kTPCSPD) {
- TString tag("Global tracking");
+ esdTrackCuts = AliESDtrackCuts::GetStandardITSTPCTrackCuts2009(kFALSE);
+ TString tag("Global tracking+tracklets");
- // TPC-only cuts
- if (analysisMode == AliPWG0Helper::kTPC)
- {
- // eventually replace by kTPCin?
- tpcRefit = kFALSE;
-
- tag = "TPC-only tracking";
}
+ if (hists)
+ esdTrackCuts->DefineHistograms(1);
+
// cuts for data without field
- if (!fieldOn)
+ if (!(analysisMode & AliPWG0Helper::kFieldOn))
{
- cov5 = 1e10;
tag += " without field";
}
-
- esdTrackCuts->SetMaxCovDiagonalElements(cov1, cov2, cov3, cov4, cov5);
-
- esdTrackCuts->SetMinNsigmaToVertex(nSigma);
- esdTrackCuts->SetRequireSigmaToVertex(kTRUE);
-
- esdTrackCuts->SetRequireTPCRefit(tpcRefit);
- esdTrackCuts->SetAcceptKingDaughters(kFALSE);
-
- esdTrackCuts->SetMinNClustersTPC(50);
- esdTrackCuts->SetMaxChi2PerClusterTPC(3.5);
Printf("Created track cuts for: %s", tag.Data());
return esdTrackCuts;
}
+