* about the suitability of this software for any purpose. It is *
* provided "as is" without express or implied warranty. *
**************************************************************************/
-
#include <TROOT.h>
#include <TRandom.h>
fh2deltaPt1Pt2(0x0),
fh2RelPtFGen(0x0),
fh3RelPtFGenLeadTrkPt(0x0),
- fHistList(0x0)
+ fHistList(0x0),
+ fh1EvtSelection(0),
+ fMaxVertexZ(100.),
+ fMinNcontributors(0),
+ fRejectPileup(0)
+
{
for(int ij = 0;ij <kJetTypes;++ij){
fh2deltaPt1Pt2(0x0),
fh2RelPtFGen(0x0),
fh3RelPtFGenLeadTrkPt(0x0),
- fHistList(0x0)
+ fHistList(0x0),
+ fh1EvtSelection(0),
+ fMaxVertexZ(100.),
+ fMinNcontributors(0),
+ fRejectPileup(0)
{
for(int ij = 0;ij <kJetTypes;++ij){
// Histogram
+ fh1EvtSelection = new TH1F("fh1EvtSelection", "Event Selection", 7, -0.5, 6.5);
+ fh1EvtSelection->GetXaxis()->SetBinLabel(1,"ACCEPTED");
+ fh1EvtSelection->GetXaxis()->SetBinLabel(2,"event selection: rejected");
+ fh1EvtSelection->GetXaxis()->SetBinLabel(3,"event class: rejected");
+ fh1EvtSelection->GetXaxis()->SetBinLabel(4,"vertex Ncontr: rejected");
+ fh1EvtSelection->GetXaxis()->SetBinLabel(5,"vertex z: rejected");
+ fh1EvtSelection->GetXaxis()->SetBinLabel(6,"vertex type: rejected");
+ fh1EvtSelection->GetXaxis()->SetBinLabel(7,"pileup: rejected");
+ fHistList->Add(fh1EvtSelection);
+
const Int_t nBinPt = 150;
Double_t binLimitsPt[nBinPt+1];
for(Int_t iPt = 0;iPt <= nBinPt;iPt++){
selected = AliAnalysisHelperJetTasks::TestSelectInfo(fEventSelectionMask);
}
+ if(!selected){
+ // no selection by the service task, we continue
+ if (fDebug > 1)Printf("Not selected %s:%d SelectInfo %d Class %d",(char*)__FILE__,__LINE__, AliAnalysisHelperJetTasks::Selected(),AliAnalysisHelperJetTasks::EventClass());
+ fh1EvtSelection->Fill(1.);
+ PostData(1, fHistList);
+ return;
+ }
+
if(fEventClass>0){
selected = selected&&(AliAnalysisHelperJetTasks::EventClass()==fEventClass);
}
if(!selected){
// no selection by the service task, we continue
if (fDebug > 1)Printf("Not selected %s:%d SelectInfo %d Class %d",(char*)__FILE__,__LINE__, AliAnalysisHelperJetTasks::Selected(),AliAnalysisHelperJetTasks::EventClass());
+ fh1EvtSelection->Fill(2.);
PostData(1, fHistList);
return;
}
}
}
+ AliAODVertex* primVtx = aod->GetPrimaryVertex();
+ Int_t nTracksPrim = primVtx->GetNContributors();
+
+
+ if (fDebug > 1) Printf("%s:%d primary vertex selection: %d", (char*)__FILE__,__LINE__,nTracksPrim);
+ if(nTracksPrim < fMinNcontributors){
+ if (fDebug > 1) Printf("%s:%d primary vertex selection: event REJECTED...",(char*)__FILE__,__LINE__);
+ fh1EvtSelection->Fill(3.);
+ PostData(1, fHistList);
+ return;
+ }
+
+ if(TMath::Abs(primVtx->GetZ())>fMaxVertexZ){
+ if (fDebug > 1) Printf("%s:%d primary vertex z = %f: event REJECTED...",(char*)__FILE__,__LINE__,primVtx->GetZ());
+ fh1EvtSelection->Fill(4.);
+ PostData(1, fHistList);
+ return;
+ }
+
+ TString primVtxName(primVtx->GetName());
+
+ if(primVtxName.CompareTo("TPCVertex",TString::kIgnoreCase) == 1){
+ if (fDebug > 1) Printf("%s:%d primary vertex selection: TPC vertex, event REJECTED...",(char*)__FILE__,__LINE__);
+ fh1EvtSelection->Fill(5.);
+ PostData(1, fHistList);
+ return;
+ }
+
+ if(fRejectPileup && AliAnalysisHelperJetTasks::IsPileUp()){
+ if (fDebug > 1) Printf("%s:%d SPD pileup: event REJECTED...",(char*)__FILE__,__LINE__);
+ fh1EvtSelection->Fill(6.);
+ PostData(1, fHistList);
+ return;
+ }
+
+ if (fDebug > 1) Printf("%s:%d event ACCEPTED ...",(char*)__FILE__,__LINE__);
+ fh1EvtSelection->Fill(0.);
+
// new Scheme
// first fill all the pure histograms, i.e. full jets
class TProfile2D;
class TSTring;
-
class AliAnalysisTaskJetSpectrum2 : public AliAnalysisTaskSE
{
public:
virtual void SetNAcceptance(Int_t n);
virtual void SetAcceptance(Int_t i,Float_t phiMin,Float_t phiMax,Float_t etaMin,Float_t etaMax);// non overlapping regions
virtual Int_t CheckAcceptance(Float_t phi,Float_t eta);
+
+
+ void SetMaxVertexZ(Float_t a) {fMaxVertexZ = a;}
+ void SetMinNcontributors(Int_t i) {fMinNcontributors = i;}
+ void SetPileupRejection(Bool_t a) {fRejectPileup = a;}
+
+
+
// Helper
//
AliVParticle *LeadingTrackFromJetRefs(AliAODJet* jet);
AliVParticle *LeadingTrackInCone(AliAODJet* jet,TList *list,Float_t r = 0.4);
-
AliJetHeader *fJetHeaderRec;//! The jet header that can be fetched from the userinfo
AliJetHeader *fJetHeaderGen;//! The jet header that can fetched from the userinfo
AliAODEvent *fAODIn; //! where we take the jets from
TH2F* fh2DijetPt2vsPt1[kJetTypes]; //! dijet pt2 vs pt1
TH2F* fh2DijetDifvsSum[kJetTypes]; //! dijet dif vs sum
+ TH1F* fh1EvtSelection;
+ Float_t fMaxVertexZ;
+ Int_t fMinNcontributors;
+ Bool_t fRejectPileup;
+
TList *fHistList; //! Output list