1 /**************************************************************************
2 * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * Author: The ALICE Off-line Project. *
5 * Contributors are mentioned in the code where appropriate. *
7 * Permission to use, copy, modify and distribute this software and its *
8 * documentation strictly for non-commercial purposes is hereby granted *
9 * without fee, provided that the above copyright notice appears in all *
10 * copies and that both the copyright notice and this permission notice *
11 * appear in the supporting documentation. The authors make no claims *
12 * about the suitability of this software for any purpose. It is *
13 * provided "as is" without express or implied warranty. *
14 **************************************************************************/
16 //-----------------------------------------------------------------------
17 // Author : Marta Verweij - UU
18 //-----------------------------------------------------------------------
20 #ifndef ALIPWG4HIGHPTSPECTRA_H
21 #define ALIPWG4HIGHPTSPECTRA_H
23 #include "AliAnalysisTask.h"
24 #include "AliCFManager.h"
31 class AliESDtrackCuts;
34 class AliPWG4HighPtSpectra : public AliAnalysisTask {
38 kStepReconstructed = 0,
39 kStepReconstructedTPCOnly = 1,
42 kStepReconstructedMC = 4,
46 AliPWG4HighPtSpectra();
47 AliPWG4HighPtSpectra(const Char_t* name);
48 // AliPWG4HighPtSpectra& operator= (const AliPWG4HighPtSpectra& c);
49 // AliPWG4HighPtSpectra(const AliPWG4HighPtSpectra& c);
50 ~AliPWG4HighPtSpectra() {;};
52 // ANALYSIS FRAMEWORK STUFF to loop on data and fill output objects
53 virtual void ConnectInputData(Option_t *);
54 virtual void CreateOutputObjects();
55 virtual void Exec(Option_t *option);
56 virtual void Terminate(Option_t *);
58 // CORRECTION FRAMEWORK RELATED FUNCTIONS
59 void SetCFManagerPos(const AliCFManager* io1) {fCFManagerPos = io1;} // global correction manager
60 const AliCFManager * GetCFManagerPos() const {return fCFManagerPos;} // get corr manager
61 void SetCFManagerNeg(const AliCFManager* io2) {fCFManagerNeg = io2;} // global correction manager
62 const AliCFManager * GetCFManagerNeg() const {return fCFManagerNeg;} // get corr manager
64 //AliESDtrackCuts setters
65 void SetCuts(AliESDtrackCuts* trackCuts) {fTrackCuts = trackCuts;}
67 void SelectTrigger(Int_t trig) { fTrigger = trig; }
70 Bool_t IsReadAODData() const {return fReadAODData;}
71 void SetReadAODData(Bool_t flag=kTRUE) {fReadAODData=flag;}
74 Bool_t fReadAODData ; // flag for AOD/ESD input files
75 const AliCFManager *fCFManagerPos ; // pointer to the CF manager for positive charged particles
76 const AliCFManager *fCFManagerNeg ; // pointer to the CF manager for negative charged particles
78 AliESDEvent *fESD; //! ESD object
79 //AliESDtrackCuts options. Must be setted in AddTaskPWG4HighPtQAMC.C. They correspond with different steps in container.
80 AliESDtrackCuts *fTrackCuts; // trackCuts applied
81 Int_t fTrigger; //Trigger flag as defined in AliAnalysisHelperJetTasks.h
84 AliPWG4HighPtSpectra(const AliPWG4HighPtSpectra&);
85 AliPWG4HighPtSpectra& operator=(const AliPWG4HighPtSpectra&);
90 TList *fHistList; //! List of output histograms
91 TH1F *fNEventAll; //! Event counter
92 TH1F *fNEventSel; //! Event counter: Selected events for analysis
94 ClassDef(AliPWG4HighPtSpectra,1);