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 // Task for Efficiency studies
17 // Used for testing classes AliHFEcontainer and AliHFEfilter
18 // Creates Efficiency Histograms
20 #ifndef ALIHFEEFFICIENCY_H
21 #define ALIHFEEFFICIENCY_H
23 #include "AliAnalysisTaskSE.h"
27 class AliCFAcceptanceCuts;
30 class AliHFEcollection;
31 class AliHFEcontainer;
32 class AliHFEtrackFilter;
34 class AliHFEefficiency : public AliAnalysisTaskSE{
37 AliHFEefficiency(const Char_t *name);
40 virtual void UserCreateOutputObjects();
41 virtual void UserExec(Option_t *);
42 virtual void Terminate(Option_t *);
45 void CutTRD() { fCutTRD = kTRUE; }
47 void SetHFEcontainer(AliHFEcontainer * const cont) { fEfficiency = cont; };
48 void UnsetHFEcontainer() { fEfficiency = NULL; }
50 void Load(const char* filename = "EffTask.root");
52 Bool_t IsRunningTerminate() const { return TestBit(kTerminate); }
53 void SetRunTerminate(Bool_t terminate = kTRUE) { SetBit(kTerminate, terminate); }
55 void CalculatePTsmearing();
56 void DrawPtResolution(const TList * const l);
57 void DrawSignalEfficiency(AliCFEffGrid *eff, AliCFContainer *cont, Int_t var);
58 void DrawCutEfficiency(AliCFEffGrid *eff, AliCFContainer *cont, Int_t var);
65 enum{ // Bit Definition
68 AliHFEefficiency(const AliHFEefficiency &);
69 AliHFEefficiency &operator=(const AliHFEefficiency &);
72 AliHFEtrackFilter *fFilter; //! Track Filter
73 AliHFEcutStep *fMCcut; //! MC Signal
74 AliCFAcceptanceCuts *fAcceptanceCuts; //! MC Acceptance cuts
75 AliHFEcontainer *fEfficiency; //! Efficiency container
76 AliHFEcollection *fOutput; //! QA histo container
77 Bool_t fCutTRD; // Apply TRD cuts
79 ClassDef(AliHFEefficiency, 1);