]> git.uio.no Git - u/mrichter/AliRoot.git/commitdiff
Deepa code electron hadron correlation
authorrbailhac <rbailhac@f7af4fe6-9843-0410-8265-dc069ae4e863>
Thu, 15 Dec 2011 16:17:17 +0000 (16:17 +0000)
committerrbailhac <rbailhac@f7af4fe6-9843-0410-8265-dc069ae4e863>
Thu, 15 Dec 2011 16:17:17 +0000 (16:17 +0000)
PWG3/CMakelibPWG3hfe.pkg
PWG3/PWG3hfeLinkDef.h
PWG3/hfe/AliAnalysisTaskElecHadronCorrel.cxx [new file with mode: 0644]
PWG3/hfe/AliAnalysisTaskElecHadronCorrel.h [new file with mode: 0644]
PWG3/hfe/AliHFEpidEMCAL.cxx
PWG3/hfe/AliHFEpidEMCAL.h

index 514b9638686bdd1d87f3b884c7323bb512a8a75b..566f988028e13f56addd7e0b6460a1f77a54babd 100644 (file)
@@ -77,6 +77,7 @@ set (SRCS
     hfe/AliHFEbayesPIDqa.cxx
     hfe/AliHFEpidBayes.cxx
     hfe/AliHFEpidObject.cxx
+    hfe/AliAnalysisTaskElecHadronCorrel.cxx
     )
 
 string (REPLACE ".cxx" ".h" HDRS "${SRCS}")
index f6902cb9cb2309fbfff36dcb87c52d9fb3359fe2..8f1a19e8d266128636d43b0b79d97654d5f049f7 100644 (file)
@@ -66,5 +66,6 @@
 #pragma link C++ class  AliHFEpidBayes+;
 
 #pragma link C++ class  AliHFEpidObject+;
+#pragma link C++ class  AliAnalysisTaskElecHadronCorrel+;
 
 #endif
diff --git a/PWG3/hfe/AliAnalysisTaskElecHadronCorrel.cxx b/PWG3/hfe/AliAnalysisTaskElecHadronCorrel.cxx
new file mode 100644 (file)
index 0000000..5444c86
--- /dev/null
@@ -0,0 +1,632 @@
+/**************************************************************************
+ * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *               
+ *                                                                        *               
+ * Author: The ALICE Off-line Project.                                    *               
+ * Contributors are mentioned in the code where appropriate.              *               
+ *                                                                        *               
+ * Permission to use, copy, modify and distribute this software and its   *               
+ * documentation strictly for non-commercial purposes is hereby granted   *               
+ * without fee, provided that the above copyright notice appears in all   *               
+ * copies and that both the copyright notice and this permission notice   *               
+ * appear in the supporting documentation. The authors make no claims     *               
+ * about the suitability of this software for any purpose. It is          *               
+ * provided "as is" without express or implied warranty.                  *               
+ **************************************************************************/
+
+
+////////////////////////////////////////////////////////////////////////
+//                                                                    //
+//  Task for Heavy Flavour Electron-Hadron DeltaPhi Correlation       //
+//  Non-Photonic Electron identified with Invariant mass              //
+//  analysis methos in function  SelectPhotonicElectron               //
+//  DeltaPhi calculated in function  ElectronHadCorrel                // 
+//                                                                    //
+//  Author: Deepa Thomas (Utrecht University)                         //
+//                                                                    //
+////////////////////////////////////////////////////////////////////////
+
+#include "TChain.h"
+#include "TTree.h"
+#include "TH2F.h"
+#include "TMath.h"
+#include "TCanvas.h"
+#include "THnSparse.h"
+#include "TLorentzVector.h"
+#include "TString.h"
+#include "TFile.h"
+
+#include "AliAnalysisTask.h"
+#include "AliAnalysisManager.h"
+
+#include "AliESDEvent.h"
+#include "AliESDHandler.h"
+#include "AliAODEvent.h"
+#include "AliAODHandler.h"
+
+#include "AliAnalysisTaskElecHadronCorrel.h"
+#include "TGeoGlobalMagField.h"
+#include "AliLog.h"
+#include "AliAnalysisTaskSE.h"
+#include "TRefArray.h"
+#include "TVector.h"
+#include "AliESDInputHandler.h"
+#include "AliESDpid.h"
+#include "AliESDtrackCuts.h"
+#include "AliPhysicsSelection.h"
+#include "AliESDCaloCluster.h"
+#include "AliAODCaloCluster.h"
+#include "AliEMCALRecoUtils.h"
+#include "AliEMCALGeometry.h"
+#include "AliGeomManager.h"
+#include "stdio.h"
+#include "TGeoManager.h"
+#include "iostream"
+#include "fstream"
+
+#include "AliEMCALTrack.h"
+#include "AliMagF.h"
+
+#include "AliKFParticle.h"
+#include "AliKFVertex.h"
+
+#include "AliPID.h"
+#include "AliPIDResponse.h"
+#include "AliHFEcontainer.h"
+#include "AliHFEcuts.h"
+#include "AliHFEpid.h"
+#include "AliHFEpidBase.h"
+#include "AliHFEpidQAmanager.h"
+#include "AliHFEtools.h"
+#include "AliCFContainer.h"
+#include "AliCFManager.h"
+
+ClassImp(AliAnalysisTaskElecHadronCorrel)
+//________________________________________________________________________
+AliAnalysisTaskElecHadronCorrel::AliAnalysisTaskElecHadronCorrel(const char *name) 
+  : AliAnalysisTaskSE(name)
+  ,fESD(0)
+  ,fGeom(0)
+  ,fOutputList(0)
+  ,fTrackCuts1(0)
+  ,fTrackCuts2(0)
+  ,fCuts(0)
+  ,fIdentifiedAsOutInz(kFALSE)
+  ,fPassTheEventCut(kFALSE)
+  ,fRejectKinkMother(kFALSE)
+  ,fVz(0.0)
+  ,fCFM(0)     
+  ,fPID(0)
+  ,fPIDqa(0)          
+  ,fOpeningAngleCut(0.1)
+  ,fInvmassCut(0.01)   
+  ,fNoEvents(0)
+  ,fTrkpt(0)
+  ,fTrkEovPBef(0)       
+  ,fTrkEovPAft(0)      
+  ,fdEdxBef(0)  
+  ,fdEdxAft(0)  
+  ,fInvmassLS(0)               
+  ,fInvmassULS(0)              
+  ,fOpeningAngleLS(0)  
+  ,fOpeningAngleULS(0) 
+  ,fSemiIncElecDphi(0)         
+  ,fPhotElecDphi(0)    
+  ,fInclusiveElecDphi(0)       
+  ,fDphiMassHigh(0)            
+  ,fDphiULSMassLow(0)  
+  ,fDphiLSMassLow(0)
+  ,fPhotoElecPt(0)
+  ,fSemiInclElecPt(0)
+  ,fTrackPtBefTrkCuts(0)        
+  ,fTrackPtAftTrkCuts(0)
+  ,fTPCnsigma(0)        
+{
+  //Named constructor
+  
+  fPID = new AliHFEpid("hfePid");
+  fTrackCuts1 = new AliESDtrackCuts();
+  fTrackCuts2 = new AliESDtrackCuts();  
+
+  // Define input and output slots here
+  // Input slot #0 works with a TChain
+  DefineInput(0, TChain::Class());
+  // Output slot #0 id reserved by the base class for AOD
+  // Output slot #1 writes into a TH1 container
+  // DefineOutput(1, TH1I::Class());
+  DefineOutput(1, TList::Class());
+  //  DefineOutput(3, TTree::Class());
+}
+
+//________________________________________________________________________
+AliAnalysisTaskElecHadronCorrel::AliAnalysisTaskElecHadronCorrel() 
+  : AliAnalysisTaskSE("DefaultAnalysis_AliAnalysisElecHadCorrel")
+  ,fESD(0)
+  ,fGeom(0)  
+  ,fOutputList(0)
+  ,fTrackCuts1(0)
+  ,fTrackCuts2(0)
+  ,fCuts(0)
+  ,fIdentifiedAsOutInz(kFALSE)
+  ,fPassTheEventCut(kFALSE)
+  ,fRejectKinkMother(kFALSE)
+  ,fVz(0.0)
+  ,fCFM(0)     
+  ,fPID(0)       
+  ,fPIDqa(0)          
+  ,fOpeningAngleCut(0.1)
+  ,fInvmassCut(0.01)   
+  ,fNoEvents(0)
+  ,fTrkpt(0)
+  ,fTrkEovPBef(0)       
+  ,fTrkEovPAft(0)       
+  ,fdEdxBef(0)  
+  ,fdEdxAft(0)  
+  ,fInvmassLS(0)               
+  ,fInvmassULS(0)              
+  ,fOpeningAngleLS(0)  
+  ,fOpeningAngleULS(0) 
+  ,fSemiIncElecDphi(0)         
+  ,fPhotElecDphi(0)    
+  ,fInclusiveElecDphi(0)       
+  ,fDphiMassHigh(0)            
+  ,fDphiULSMassLow(0)  
+  ,fDphiLSMassLow(0)
+  ,fPhotoElecPt(0)
+  ,fSemiInclElecPt(0)
+  ,fTrackPtBefTrkCuts(0)        
+  ,fTrackPtAftTrkCuts(0)                 
+  ,fTPCnsigma(0)        
+{
+       //Default constructor
+       fPID = new AliHFEpid("hfePid");
+
+       fTrackCuts1 = new AliESDtrackCuts();
+       fTrackCuts2 = new AliESDtrackCuts();
+
+       // Constructor
+       // Define input and output slots here
+       // Input slot #0 works with a TChain
+       DefineInput(0, TChain::Class());
+       // Output slot #0 id reserved by the base class for AOD
+       // Output slot #1 writes into a TH1 container
+       // DefineOutput(1, TH1I::Class());
+       DefineOutput(1, TList::Class());
+       //DefineOutput(3, TTree::Class());
+}
+//_________________________________________
+
+AliAnalysisTaskElecHadronCorrel::~AliAnalysisTaskElecHadronCorrel()
+{
+  //Destructor 
+  
+  delete fOutputList;
+  delete fGeom;
+  delete fPID;
+  delete fCFM;
+  delete fPIDqa;
+  delete fTrackCuts1;
+  delete fTrackCuts2;
+}
+//_________________________________________
+
+void AliAnalysisTaskElecHadronCorrel::UserExec(Option_t*)
+{
+  //Main loop
+  //Called for each event
+  
+  // create pointer to event
+  fESD = dynamic_cast<AliESDEvent*>(InputEvent());
+  if (!fESD) {
+    printf("ERROR: fESD not available\n");
+    return;
+  }
+  
+  if(!fCuts){
+    AliError("HFE cuts not available");
+    return;
+  }
+  
+  if(!fPID->IsInitialized()){ 
+    // Initialize PID with the given run number
+    AliWarning("PID not initialised, get from Run no");
+    fPID->InitializePID(fESD->GetRunNumber());
+  }
+  
+  //-------trigger selection
+  UInt_t res = ((AliInputEventHandler*)(AliAnalysisManager::GetAnalysisManager()->GetInputEventHandler()))->IsEventSelected();
+  if (res==0)
+    return;
+  
+  if( (((AliInputEventHandler*)(AliAnalysisManager::GetAnalysisManager()->GetInputEventHandler()))->IsEventSelected() & AliVEvent::kFastOnly) )
+    return;
+  
+  if(!(((AliInputEventHandler*)(AliAnalysisManager::GetAnalysisManager()->GetInputEventHandler()))->IsEventSelected() & AliVEvent::kEMC1) ) return;
+  //if(!(((AliInputEventHandler*)(AliAnalysisManager::GetAnalysisManager()->GetInputEventHandler()))->IsEventSelected() & AliVEvent::kMB) ) return;
+  
+  Int_t fNOtrks =  fESD->GetNumberOfTracks();
+  const AliESDVertex *pVtx = fESD->GetPrimaryVertex();
+  
+  Double_t pVtxZ = -999;
+  pVtxZ = pVtx->GetZ();
+  
+  // Event cut
+  //   if(!fCFM->CheckEventCuts(AliHFEcuts::kEventStepReconstructed, fESD)) return;
+  
+  //Check if its an LED event 
+  if(IsLEDEvent()) return;
+  
+  if(TMath::Abs(pVtxZ)>10) return;
+  fNoEvents->Fill(0);
+  
+  if(fNOtrks<2) return;
+  
+  AliPIDResponse *pidResponse = fInputHandler->GetPIDResponse();
+  if(!pidResponse){
+    AliDebug(1, "Using default PID Response");
+    pidResponse = AliHFEtools::GetDefaultPID(kFALSE, fInputEvent->IsA() == AliAODEvent::Class()); 
+  }
+  
+  fPID->SetPIDResponse(pidResponse);
+  
+  fCFM->SetRecEventInfo(fESD);
+  
+  // Track loop 
+  for (Int_t iTracks = 0; iTracks < fESD->GetNumberOfTracks(); iTracks++) {
+    AliESDtrack* track = fESD->GetTrack(iTracks);
+    if (!track) {
+      printf("ERROR: Could not receive track %d\n", iTracks);
+      continue;
+    }
+    
+    fTrackPtBefTrkCuts->Fill(track->Pt());             
+    // RecKine: ITSTPC cuts  
+    if(!ProcessCutStep(AliHFEcuts::kStepRecKineITSTPC, track)) continue;
+    
+    //RecKink
+    if(fRejectKinkMother) { // Quick and dirty fix to reject both kink mothers and daughters
+      if(track->GetKinkIndex(0) != 0) continue;
+    } 
+    
+    // RecPrim
+    if(!ProcessCutStep(AliHFEcuts::kStepRecPrim, track)) continue;
+    
+    // HFEcuts: ITS layers cuts
+    if(!ProcessCutStep(AliHFEcuts::kStepHFEcutsITS, track)) continue;
+    
+    // HFE cuts: TPC PID cleanup
+    if(!ProcessCutStep(AliHFEcuts::kStepHFEcutsTPC, track)) continue;
+    
+    fTrackPtAftTrkCuts->Fill(track->Pt());             
+    
+    Double_t fClsE = -999, p = -999, fEovP=-999, pt = -999, dEdx=-999, fTPCnSigma=0;
+    // Track extrapolation
+    Int_t fClsId = track->GetEMCALcluster();
+    if(fClsId == -1) continue;
+    AliESDCaloCluster *cluster = fESD->GetCaloCluster(fClsId);
+    
+    pt = track->Pt();
+    if(pt<1) continue;
+    fTrkpt->Fill(pt);
+    fClsE = cluster->E();
+    p = track->P();
+    dEdx = track->GetTPCsignal();
+    fEovP = fClsE/p;
+    fTPCnSigma = fPID->GetPIDResponse() ? fPID->GetPIDResponse()->NumberOfSigmasTPC(track, AliPID::kElectron) : 1000;
+    fdEdxBef->Fill(p,dEdx);
+    fTPCnsigma->Fill(p,fTPCnSigma);
+    
+    if(fTPCnSigma >= 1.5 && fTPCnSigma <= 3)fTrkEovPBef->Fill(pt,fEovP);
+    Int_t pidpassed = 1;
+    //--- track accepted, do PID
+    AliHFEpidObject hfetrack;
+    hfetrack.SetAnalysisType(AliHFEpidObject::kESDanalysis);
+    hfetrack.SetRecTrack(track);
+    hfetrack.SetPP();
+    if(!fPID->IsSelected(&hfetrack, NULL, "", fPIDqa)) pidpassed = 0;
+    
+    if(pidpassed==0) continue;
+    fTrkEovPAft->Fill(pt,fEovP);
+    fdEdxAft->Fill(p,dEdx);
+    
+    Bool_t fFlagPhotonicElec = kFALSE;
+    // select photonic electron
+    SelectPhotonicElectron(iTracks,track,fFlagPhotonicElec);
+    
+    //Inclusive electron-hadron correlation
+    ElectronHadCorrel(iTracks, track, fInclusiveElecDphi);
+    
+    // photonic electron
+    if(fFlagPhotonicElec){
+      //Electron hadron correlation
+      ElectronHadCorrel(iTracks, track, fPhotElecDphi);
+      fPhotoElecPt->Fill(pt);
+    }
+    
+    // Semi inclusive electron 
+    if(!fFlagPhotonicElec){
+      //Electron hadron correlation
+      ElectronHadCorrel(iTracks, track, fSemiIncElecDphi);
+      fSemiInclElecPt->Fill(pt);
+    }
+  }
+  
+  
+  PostData(1, fOutputList);
+}
+//_________________________________________
+void AliAnalysisTaskElecHadronCorrel::UserCreateOutputObjects()
+{
+  //Create histograms
+  TGeoManager::Import("geometry.root");
+  fGeom =  AliEMCALGeometry::GetInstance("EMCAL_COMPLETEV1");
+  
+  //--------Initialize PID
+  fPID->SetHasMCData(kFALSE);
+  if(!fPID->GetNumberOfPIDdetectors()) 
+    {
+      fPID->AddDetector("TPC", 0);
+      fPID->AddDetector("EMCAL", 1);
+    }
+  
+  fPID->SortDetectors(); 
+  fPIDqa = new AliHFEpidQAmanager();
+  fPIDqa->Initialize(fPID);
+  
+  //--------Initialize correction Framework and Cuts
+  fCFM = new AliCFManager;
+  const Int_t kNcutSteps = AliHFEcuts::kNcutStepsMCTrack + AliHFEcuts::kNcutStepsRecTrack + AliHFEcuts::kNcutStepsDETrack;
+  fCFM->SetNStepParticle(kNcutSteps);
+  for(Int_t istep = 0; istep < kNcutSteps; istep++)
+    fCFM->SetParticleCutsList(istep, NULL);
+  
+  if(!fCuts){
+    AliWarning("Cuts not available. Default cuts will be used");
+    fCuts = new AliHFEcuts;
+    fCuts->CreateStandardCuts();
+  }
+  fCuts->Initialize(fCFM);
+  
+  //---------Output Tlist
+  fOutputList = new TList();
+  fOutputList->SetOwner();
+  fOutputList->Add(fPIDqa->MakeList("PIDQA"));
+  
+  fNoEvents = new TH1F("fNoEvents","",1,0,1) ;
+  fOutputList->Add(fNoEvents);
+  
+  fTrkpt = new TH1F("fTrkpt","track pt",1000,0,50);
+  fOutputList->Add(fTrkpt);
+  
+  fTrackPtBefTrkCuts = new TH1F("fTrackPtBefTrkCuts","track pt before track cuts",1000,0,50);
+  fOutputList->Add(fTrackPtBefTrkCuts);
+  
+  fTrackPtAftTrkCuts = new TH1F("fTrackPtAftTrkCuts","track pt after track cuts",1000,0,50);
+  fOutputList->Add(fTrackPtAftTrkCuts);
+  
+  fTPCnsigma = new TH2F("fTPCnsigma", "TPC - n sigma",1000,0,50,200,-10,10);
+  fOutputList->Add(fTPCnsigma);
+  
+  fTrkEovPBef = new TH2F("fTrkEovPBef","track E/p before HFE pid",1000,0,50,100,0,2);
+  fOutputList->Add(fTrkEovPBef);
+  
+  fTrkEovPAft = new TH2F("fTrkEovPAft","track E/p after HFE pid",1000,0,50,100,0,2);
+  fOutputList->Add(fTrkEovPAft);
+  
+  fdEdxBef = new TH2F("fdEdxBef","track dEdx vs p before HFE pid",1000,0,50,150,0,150);
+  fOutputList->Add(fdEdxBef);
+  
+  fdEdxAft = new TH2F("fdEdxAft","track dEdx vs p after HFE pid",1000,0,50,150,0,150);
+  fOutputList->Add(fdEdxAft);
+  
+  fInvmassLS = new TH1F("fInvmassLS", "Inv mass of LS (e,e); mass(GeV/c^2); counts;", 1000,0,0.5);
+  fOutputList->Add(fInvmassLS);
+  
+  fInvmassULS = new TH1F("fInvmassULS", "Inv mass of ULS (e,e); mass(GeV/c^2); counts;", 1000,0,0.5);
+  fOutputList->Add(fInvmassULS);
+  
+  fOpeningAngleLS = new TH1F("fOpeningAngleLS","Opening angle for LS pairs",100,0,1);
+  fOutputList->Add(fOpeningAngleLS);
+  
+  fOpeningAngleULS = new TH1F("fOpeningAngleULS","Opening angle for ULS pairs",100,0,1);
+  fOutputList->Add(fOpeningAngleULS);
+  
+  fSemiIncElecDphi = new TH2F("fSemiIncElecDphi", "Semi Inclusive elec-had Dphi correlation",200,0,20,100,-3.14,3.14);
+  fOutputList->Add(fSemiIncElecDphi);
+  
+  fPhotElecDphi = new TH2F("fPhotElecDphi", "Photon elec-had Dphi correlation",200,0,20,100,-3.14,3.14);
+  fOutputList->Add(fPhotElecDphi);
+  
+  fInclusiveElecDphi = new TH2F("fInclusiveElecDphi", "Inclusive elec-had Dphi correlation",200,0,20,100,-3.14,3.14);
+  fOutputList->Add(fInclusiveElecDphi);
+  
+  fDphiMassHigh = new TH2F("fDphiMassHigh", "e-h Dphi LS+ULS, mass>0.01",200,0,20,100,-3.14,3.14);
+  fOutputList->Add(fDphiMassHigh);
+  
+  fDphiULSMassLow = new TH2F("fDphiULSMassLow", "e-h Dphi ULS, mass<0.01",200,0,20,100,-3.14,3.14);
+  fOutputList->Add(fDphiULSMassLow);
+  
+  fDphiLSMassLow = new TH2F("fDphiLSMassLow", "e-h Dphi LS, mass<0.01",200,0,20,100,-3.14,3.14);
+  fOutputList->Add(fDphiLSMassLow);
+  
+  fPhotoElecPt = new TH1F("fPhotoElecPt", "photonic electron pt",1000,0,100);
+  fOutputList->Add(fPhotoElecPt);
+  
+  fSemiInclElecPt = new TH1F("fSemiInclElecPt", "Semi-inclusive electron pt",1000,0,100);
+  fOutputList->Add(fSemiInclElecPt);
+  PostData(1,fOutputList);
+}
+
+//________________________________________________________________________
+void AliAnalysisTaskElecHadronCorrel::Terminate(Option_t *)
+{
+  // Info("Terminate");
+       AliAnalysisTaskSE::Terminate();
+}
+
+//________________________________________________________________________
+Bool_t AliAnalysisTaskElecHadronCorrel::ProcessCutStep(Int_t cutStep, AliVParticle *track)
+{
+  // Check single track cuts for a given cut step
+  const Int_t kMCOffset = AliHFEcuts::kNcutStepsMCTrack;
+  if(!fCFM->CheckParticleCuts(cutStep + kMCOffset, track)) return kFALSE;
+  return kTRUE;
+}
+//_________________________________________
+void AliAnalysisTaskElecHadronCorrel::SelectPhotonicElectron(Int_t itrack, AliESDtrack *track, Bool_t &fFlagPhotonicElec)
+{
+  //Identify non-heavy flavour electrons using Invariant mass method
+  
+  fTrackCuts1->SetAcceptKinkDaughters(kFALSE);
+  fTrackCuts1->SetRequireTPCRefit(kTRUE);
+  fTrackCuts1->SetEtaRange(-0.9,0.9);
+  fTrackCuts1->SetRequireSigmaToVertex(kTRUE);
+  fTrackCuts1->SetMaxChi2PerClusterTPC(3.5);
+  fTrackCuts1->SetMinNClustersTPC(80);
+  
+  const AliESDVertex *pVtx = fESD->GetPrimaryVertex();
+  
+  Bool_t flagPhotonicElec = kFALSE;
+  
+  for(Int_t jTracks = itrack+1; jTracks<fESD->GetNumberOfTracks(); jTracks++){
+    AliESDtrack* trackAsso = fESD->GetTrack(jTracks);
+    if (!trackAsso) {
+      printf("ERROR: Could not receive track %d\n", jTracks);
+      continue;
+    }
+    
+    Double_t dEdxAsso = -999., ptAsso=-999., openingAngle = -999.;
+    Double_t mass=999., width = -999;
+    Bool_t fFlagLS=kFALSE, fFlagULS=kFALSE;
+    
+    dEdxAsso = trackAsso->GetTPCsignal();
+    ptAsso = trackAsso->Pt();
+    Int_t chargeAsso = trackAsso->Charge();
+    Int_t charge = track->Charge();
+    
+    if(ptAsso <0.3) continue;
+    if(!fTrackCuts1->AcceptTrack(trackAsso)) continue;
+    if(dEdxAsso <70 || dEdxAsso>100) continue; //11a pass1
+    
+    Int_t fPDGe1 = 11; Int_t fPDGe2 = 11;
+    if(charge>0) fPDGe1 = -11;
+    if(chargeAsso>0) fPDGe2 = -11;
+    
+    if(charge == chargeAsso) fFlagLS = kTRUE;
+    if(charge != chargeAsso) fFlagULS = kTRUE;
+    
+    AliKFParticle ge1(*track, fPDGe1);
+    AliKFParticle ge2(*trackAsso, fPDGe2);
+    AliKFParticle recg(ge1, ge2);
+    
+    if(recg.GetNDF()<1) continue;
+    Double_t chi2recg = recg.GetChi2()/recg.GetNDF();
+    if(TMath::Sqrt(TMath::Abs(chi2recg))>3.) continue;
+    
+    AliKFVertex primV(*pVtx);
+    primV += recg;
+    recg.SetProductionVertex(primV);
+    
+    recg.SetMassConstraint(0,0.0001);
+    
+    openingAngle = ge1.GetAngle(ge2);
+    if(fFlagLS) fOpeningAngleLS->Fill(openingAngle);
+    if(fFlagULS) fOpeningAngleULS->Fill(openingAngle);
+    
+    if(openingAngle > fOpeningAngleCut) continue;
+    
+    recg.GetMass(mass,width);
+    
+    if(fFlagLS) fInvmassLS->Fill(mass);
+    if(fFlagULS) fInvmassULS->Fill(mass);
+    
+    if(mass>fInvmassCut){
+      ElectronHadCorrel(itrack,track,fDphiMassHigh);
+    }
+    if(mass>fInvmassCut){
+      if(fFlagULS) ElectronHadCorrel(itrack,track,fDphiULSMassLow);
+      if(fFlagLS) ElectronHadCorrel(itrack,track,fDphiLSMassLow);
+    }
+    
+    if(mass<fInvmassCut && fFlagULS && !flagPhotonicElec){
+      flagPhotonicElec = kTRUE;
+    }
+    
+  }
+  fFlagPhotonicElec = flagPhotonicElec;
+  
+}
+//_________________________________________
+void AliAnalysisTaskElecHadronCorrel::ElectronHadCorrel(Int_t itrack, AliESDtrack *track, TH2F *DphiPt)
+{
+  //Construct Delta Phi between electrons and hadrons
+  
+  fTrackCuts2->SetAcceptKinkDaughters(kFALSE);
+  fTrackCuts2->SetRequireTPCRefit(kTRUE);
+  fTrackCuts2->SetRequireITSRefit(kTRUE);
+  fTrackCuts2->SetEtaRange(-0.9,0.9);
+  fTrackCuts2->SetRequireSigmaToVertex(kTRUE);
+  fTrackCuts2->SetMaxChi2PerClusterTPC(3.5);
+  fTrackCuts2->SetMinNClustersTPC(80);
+  
+  for(Int_t ktracks = 0; ktracks<fESD->GetNumberOfTracks(); ktracks++){
+    AliESDtrack* trackHad = fESD->GetTrack(ktracks);
+    if (!trackHad) {
+      printf("ERROR: Could not receive track %d\n", ktracks);
+      continue;
+    }
+    if(ktracks == itrack) continue; //do not select the same electron
+    
+    Double_t ptHad= -999, pHad=-999., dEdxHad = -999;
+    Double_t ptEle = -999;
+    Double_t phiEle = -999, phiHad = -999, Dphi = -999;
+    Double_t pi = 3.14;
+    
+    dEdxHad = trackHad->GetTPCsignal();
+    ptHad = trackHad->Pt();
+    pHad = trackHad->P();
+    
+    if(ptHad <0.3) continue;
+    if(!fTrackCuts2->AcceptTrack(trackHad)) continue;
+    
+    phiEle = track->Phi();
+    phiHad = trackHad->Phi();
+    Dphi = phiEle - phiHad;
+    if (Dphi > pi)
+      Dphi = Dphi - 2*pi;
+    if (Dphi < -pi)
+      Dphi = Dphi + 2*pi;
+    
+    ptEle = track->Pt();
+    
+    DphiPt->Fill(ptEle,Dphi);
+  }
+}
+//_________________________________________
+Bool_t AliAnalysisTaskElecHadronCorrel::IsLEDEvent() const
+{
+ // Identify LED events which had to be discarded
+
+ AliESDCaloCells *cells = fESD->GetEMCALCells();
+ Short_t nCells = cells->GetNumberOfCells();
+ Int_t nCellCount[2] = {0,0};
+ for(Int_t iCell=0; iCell<nCells; iCell++)
+   {
+     Int_t cellId = cells->GetCellNumber(iCell);
+     Double_t cellE = cells->GetCellAmplitude(cellId);
+     Int_t sMod = fGeom->GetSuperModuleNumber(cellId);
+
+     if(sMod==3 || sMod==4)
+       {
+         if(cellE>2)
+           nCellCount[sMod-3]++;
+       }
+   }
+
+ if(nCellCount[0]>7 || nCellCount[1]>7)
+   {
+     //cout<<"Bad event!"<<endl;
+     return kTRUE;
+   }
+ return kFALSE;
+}
+
diff --git a/PWG3/hfe/AliAnalysisTaskElecHadronCorrel.h b/PWG3/hfe/AliAnalysisTaskElecHadronCorrel.h
new file mode 100644 (file)
index 0000000..1725351
--- /dev/null
@@ -0,0 +1,107 @@
+#ifndef ALIANALYSISTASKELECHADRONCORREL_H
+#define ALIANALYSISTASKELECHADRONCORREL_H
+
+/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
+ * See cxx source for full Copyright notice                               */
+
+////////////////////////////////////////////////////////////////////////
+//                                                                    //
+//  Task for Heavy Flavour Electron-Hadron DeltaPhi Correlation       //
+//                                                                    //
+//  Author: Deepa Thomas (Utrecht University)                         //
+//                                                                    //
+////////////////////////////////////////////////////////////////////////
+
+class THnSparse;
+class TH2F;
+class TLorentzVector;
+
+class AliEMCALTrack;
+class AliMagF;
+class AliESDEvent;
+class AliAODEvent;
+class AliEMCALGeometry;
+class AliEMCALRecoUtils;
+class AliAnalysisFilter;
+class AliESDtrackCuts;
+class AliESDtrack;
+class AliHFEcontainer;
+class AliHFEcuts;
+class AliHFEpid;
+class AliHFEpidQAmanager;
+class AliCFManager;
+
+#include "AliAnalysisTaskSE.h"
+
+class AliAnalysisTaskElecHadronCorrel : public AliAnalysisTaskSE {
+ public:
+  AliAnalysisTaskElecHadronCorrel();
+  AliAnalysisTaskElecHadronCorrel(const char *name);
+  virtual ~AliAnalysisTaskElecHadronCorrel();
+  
+  virtual void   UserCreateOutputObjects();
+  virtual void   UserExec(Option_t *option);
+  virtual void   Terminate(Option_t *);
+  
+  void SetHFECuts(AliHFEcuts * const cuts) { fCuts = cuts; };
+  void SetOpeningAngleCut (Double_t openingAngle) {fOpeningAngleCut = openingAngle;};
+  void SetInvariantMassCut (Double_t invmass) {fInvmassCut = invmass;};
+  AliHFEpid *GetPID() const { return fPID; }
+  void SetRejectKinkMother(Bool_t rejectKinkMother = kFALSE) { fRejectKinkMother = rejectKinkMother; };
+  void SelectPhotonicElectron(Int_t itrack, AliESDtrack *track, Bool_t &fFlagPhotonicElec);
+  void ElectronHadCorrel(Int_t itrack, AliESDtrack *track, TH2F *DphiPt);      
+  Bool_t IsLEDEvent() const;   
+ private:
+  
+  Bool_t ProcessCutStep(Int_t cutStep, AliVParticle *track);
+  
+  AliESDEvent          *fESD;                  //!ESD object
+  AliEMCALGeometry     *fGeom;                 //! emcal geometry 
+  
+  TList                *fOutputList;           //! output list
+  
+  AliESDtrackCuts      *fTrackCuts1;           //! ESD track cuts
+  AliESDtrackCuts      *fTrackCuts2;           //! ESD track cuts
+  AliHFEcuts           *fCuts;                 //! Cut Collection
+  Bool_t               fIdentifiedAsOutInz;    //Out Of Range in z
+  Bool_t               fPassTheEventCut;       //Pass The Event Cut
+  Bool_t               fRejectKinkMother;      //Reject Kink Mother
+  Double_t             fVz;                    //z position of the primary vertex
+  AliCFManager                 *fCFM;                  //! Correction Framework Manager
+  AliHFEpid            *fPID;                  //! PID
+  AliHFEpidQAmanager   *fPIDqa;                //! PID QA manager
+  Double_t             fOpeningAngleCut;       //openingAngle cut value
+  Double_t             fInvmassCut;            //invariant mass cut value
+  
+  TH1F                 *fNoEvents;             //! no of events
+  TH1F                 *fTrkpt;                //! track pt
+  TH2F                 *fTrkEovPBef;           //! track E/p before HFE pid
+  TH2F                 *fTrkEovPAft;           //! track E/p after HFE pid
+  TH2F                 *fdEdxBef;              //! track dEdx vs p before HFE pid
+  TH2F                 *fdEdxAft;              //! track dEdx vs p before HFE pid
+  TH1F                 *fInvmassLS;            //! Inv mass of LS (e,e)
+  TH1F                 *fInvmassULS;           //! Inv mass of ULS (e,e)
+  TH1F                 *fOpeningAngleLS;       //! opening angle for LS pairs
+  TH1F                 *fOpeningAngleULS;      //! opening angle for ULS pairs
+  TH2F                 *fSemiIncElecDphi;      //! Semi Inclusive elec - had DPhi
+  TH2F                 *fPhotElecDphi;         //! Photon elec - had DPhi
+  TH2F                 *fInclusiveElecDphi;    //! Inclusive elec - had DPhi
+  TH2F                 *fDphiMassHigh;         //! Dphi - LS+ULS, mass>0.01
+  TH2F                 *fDphiULSMassLow;       //! Dphi - ULS, mass<0.01
+  TH2F                 *fDphiLSMassLow;        //! Dphi - LS, mass<0.01
+  TH1F                 *fPhotoElecPt;          //! photonic elec pt 
+  TH1F                 *fSemiInclElecPt;       //! Semi inclusive ele pt
+  
+  TH1F                 *fTrackPtBefTrkCuts;    //! Track pt before track cuts  
+  TH1F                 *fTrackPtAftTrkCuts;    //! Track pt after track cuts
+  TH2F                 *fTPCnsigma;            //! TPC n sigma vs p    
+  
+  AliAnalysisTaskElecHadronCorrel(const AliAnalysisTaskElecHadronCorrel&); // not implemented
+  AliAnalysisTaskElecHadronCorrel& operator=(const AliAnalysisTaskElecHadronCorrel&); // not implemented
+  
+  ClassDef(AliAnalysisTaskElecHadronCorrel, 1); //!example of analysis
+};
+
+#endif
+
+
index a59a2f35782ff32da6d79cbabfc755daf2665406..035b1ef6fc4616d4ce036443267ec3fd90cae1f8 100644 (file)
@@ -24,6 +24,7 @@
 //
 //
 #include <TMath.h>
+#include <TRandom3.h>
 #include "AliESDInputHandler.h"
 #include "AliESDpid.h"
 
@@ -189,25 +190,27 @@ Int_t AliHFEpidEMCAL::IsSelected(const AliHFEpidObject *track, AliHFEpidQAmanage
 //__________________________________________________________________________
 Double_t AliHFEpidEMCAL::CalEopCutMax(const AliVParticle *const track, Int_t flageop) const
 {
+ // max nSig cuts for 10d
+
   double maxCut = 0.0;
   const AliESDtrack *esdtrack = dynamic_cast<const AliESDtrack *>(track);
   if(esdtrack==NULL)return maxCut;
-  double Pt = esdtrack->Pt();
+  double pt = esdtrack->Pt();
 
   if(flageop<0.5)
     { //<--- new para for updated non-liniarity
      double meanP[3] = {1.056,1.169,0.1339}; 
      double sigP[3] = {3.37e-05,1.298e-04,1.403e-04}; 
-     double mean = meanP[0]*tanh(meanP[1]+meanP[2]*Pt); 
-     double sig = sigP[0]/tanh(sigP[1]+sigP[2]*Pt); 
+     double mean = meanP[0]*tanh(meanP[1]+meanP[2]*pt); 
+     double sig = sigP[0]/tanh(sigP[1]+sigP[2]*pt); 
      maxCut = mean+3.0*sig; 
     }
   else
     {
      double meanP[3] = {0.99,1.299,0.35}; 
      double sigP[3] = {4.11e-02,1.588e-01,2.664e-01}; 
-     double mean = meanP[0]*tanh(meanP[1]+meanP[2]*Pt); 
-     double sig = sigP[0]/tanh(sigP[1]+sigP[2]*Pt); 
+     double mean = meanP[0]*tanh(meanP[1]+meanP[2]*pt); 
+     double sig = sigP[0]/tanh(sigP[1]+sigP[2]*pt); 
      maxCut = mean+3.0*sig; 
     }
      return maxCut;
@@ -215,18 +218,19 @@ Double_t AliHFEpidEMCAL::CalEopCutMax(const AliVParticle *const track, Int_t fla
 
 Double_t AliHFEpidEMCAL::CalEopCutMim(const AliVParticle *const track, Int_t flageop) const
 {
+ // mim nsig cuts for 10d
   double mimCut = 0.0;
   const AliESDtrack *esdtrack = dynamic_cast<const AliESDtrack *>(track);
   if(esdtrack==NULL)return mimCut;
-  double Pt = esdtrack->Pt();
+  double pt = esdtrack->Pt();
 
   if(flageop<0.5) // real
      { 
       //printf("real"); 
      double meanP[3] = {1.056,1.169,0.1339}; 
      double sigP[3] = {3.37e-05,1.298e-04,1.403e-04}; 
-     double mean = meanP[0]*tanh(meanP[1]+meanP[2]*Pt); 
-     double sig = sigP[0]/tanh(sigP[1]+sigP[2]*Pt); 
+     double mean = meanP[0]*tanh(meanP[1]+meanP[2]*pt); 
+     double sig = sigP[0]/tanh(sigP[1]+sigP[2]*pt); 
      mimCut = mean-2.0*sig;
     }
    else // MC
@@ -234,8 +238,8 @@ Double_t AliHFEpidEMCAL::CalEopCutMim(const AliVParticle *const track, Int_t fla
       //printf("MC"); 
      double meanP[3] = {0.99,1.299,0.35}; 
      double sigP[3] = {4.11e-02,1.588e-01,2.664e-01}; 
-     double mean = meanP[0]*tanh(meanP[1]+meanP[2]*Pt); 
-     double sig = sigP[0]/tanh(sigP[1]+sigP[2]*Pt); 
+     double mean = meanP[0]*tanh(meanP[1]+meanP[2]*pt); 
+     double sig = sigP[0]/tanh(sigP[1]+sigP[2]*pt); 
      mimCut = mean-2.0*sig;
     }
      return mimCut;
@@ -259,6 +263,16 @@ Double_t AliHFEpidEMCAL::MomentumEnergyMatchV2(const AliVParticle *const track)
 
        matchclsE = cluster->E();
   
+   //printf("energy org  %f \n",matchclsE);
+   //printf("Label %d \n",esdtrack->GetLabel());
+   if(esdtrack->GetLabel()>-1)
+     {
+            double energyMC = cluster->E();
+           TRandom3 *smear = new TRandom3(icl); 
+           matchclsE = smear->Gaus(energyMC,0.07 * TMath::Sqrt(energyMC));
+     } 
+
+   //printf("energy af  %f \n",matchclsE);
 
    if(matchclsE<9999.0) feop = matchclsE/esdtrack->P();
 
index d2f6057baade07172783a43381d3134dfca53416..68488ba269232fb2116daf8a820048e8b0c24875 100644 (file)
@@ -44,6 +44,7 @@ class AliHFEpidEMCAL : public AliHFEpidBase{
     AliPID        *fPID;           //! PID Object
     Float_t    feopMim;         // EMCAL eop mim. cut
     Float_t    feopMax;         // EMCAL eop max. cut
+    //TRandom3   fRandom;
 
     ClassDef(AliHFEpidEMCAL, 1)
 };