1 #ifndef ALIDIELECTRONVARCUTS_H
2 #define ALIDIELECTRONVARCUTS_H
4 /* Copyright(c) 1998-2009, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
7 //#############################################################
9 //# Class AliDielectronVarCuts #
10 //# Provide cuts for all variables handled in #
11 //# AliDielectronVarManager #
14 //# Anton Andronic, GSI / A.Andronic@gsi.de #
15 //# Ionut C. Arsene, GSI / I.C.Arsene@gsi.de #
16 //# Julian Book, Uni Ffm / Julian.Book@cern.ch #
17 //# Frederick Kramer, Uni Ffm, / Frederick.Kramer@cern.ch #
18 //# Magnus Mager, CERN / Magnus.Mager@cern.ch #
19 //# WooJin J. Park, GSI / W.J.Park@gsi.de #
20 //# Jens Wiechula, Uni HD / Jens.Wiechula@cern.ch #
22 //#############################################################
27 #include <AliAnalysisCuts.h>
28 #include "AliDielectronVarManager.h"
31 class AliDielectronVarCuts : public AliAnalysisCuts {
33 // Whether all cut criteria have to be fulfilled of just any
34 enum CutType { kAll=0, kAny };
36 AliDielectronVarCuts();
37 AliDielectronVarCuts(const char* name, const char* title);
38 virtual ~AliDielectronVarCuts();
39 //TODO: make copy constructor and assignment operator public
40 void AddCut(AliDielectronVarManager::ValueTypes type, Double_t min, Double_t max, Bool_t excludeRange=kFALSE);
41 void AddCut(AliDielectronVarManager::ValueTypes type, Double_t value, Bool_t excludeRange=kFALSE);
42 void AddCut(AliDielectronVarManager::ValueTypes type, Double_t min, TH1 * const max, Bool_t excludeRange=kFALSE);
45 void SetCutOnMCtruth(Bool_t mc=kTRUE) { fCutOnMCtruth=mc; }
46 void SetCutType(CutType type) { fCutType=type; }
49 Bool_t GetCutOnMCtruth() const { return fCutOnMCtruth; }
50 CutType GetCutType() const { return fCutType; }
53 //Analysis cuts interface
55 virtual Bool_t IsSelected(TObject* track);
56 virtual Bool_t IsSelected(TList* /* list */ ) {return kFALSE;}
58 // virtual Bool_t IsSelected(TObject* track, TObject */*event*/=0);
59 // virtual Long64_t Merge(TCollection* /* list */) { return 0; }
64 virtual UInt_t GetSelectedCutsMask() const { return fSelectedCutsMask; }
66 virtual void Print(const Option_t* option = "") const;
71 TBits *fUsedVars; // list of used variables
72 UShort_t fActiveCuts[AliDielectronVarManager::kNMaxValues]; // list of activated cuts
73 UShort_t fNActiveCuts; // number of acive cuts
74 UInt_t fActiveCutsMask; // mask of active cuts
76 UInt_t fSelectedCutsMask; // Maks of selected cuts, is available after calling IsSelected
78 Bool_t fCutOnMCtruth; // whether to cut on the MC truth of the particle
80 CutType fCutType; // type of the cut: any, all
82 Double_t fCutMin[AliDielectronVarManager::kNMaxValues]; // minimum values for the cuts
83 Double_t fCutMax[AliDielectronVarManager::kNMaxValues]; // maximum values for the cuts
84 Bool_t fCutExclude[AliDielectronVarManager::kNMaxValues]; // inverse cut logic?
85 TH1 *fUpperCut[AliDielectronVarManager::kNMaxValues]; // use object as upper cut
87 AliDielectronVarCuts(const AliDielectronVarCuts &c);
88 AliDielectronVarCuts &operator=(const AliDielectronVarCuts &c);
90 ClassDef(AliDielectronVarCuts,4) //Cut class providing cuts to all infomation available for the AliVParticle interface
97 inline void AliDielectronVarCuts::AddCut(AliDielectronVarManager::ValueTypes type, Double_t value, Bool_t excludeRange)
100 // Set cut in a small delta around value
102 const Double_t kDelta=1e-20;
103 AddCut(type,value-kDelta,value+kDelta, excludeRange);