public:
// Whether all cut criteria have to be fulfilled of just any
enum CutType { kAll=0, kAny };
-
+
AliDielectronVarCuts();
AliDielectronVarCuts(const char* name, const char* title);
virtual ~AliDielectronVarCuts();
//TODO: make copy constructor and assignment operator public
void AddCut(AliDielectronVarManager::ValueTypes type, Double_t min, Double_t max, Bool_t excludeRange=kFALSE);
void AddCut(AliDielectronVarManager::ValueTypes type, Double_t value, Bool_t excludeRange=kFALSE);
+ void AddBitCut(AliDielectronVarManager::ValueTypes type, UInt_t bit, Bool_t excludeRange=kFALSE);
void AddCut(AliDielectronVarManager::ValueTypes type, Double_t min, THnBase * const max, Bool_t excludeRange=kFALSE);
-
+
// setters
void SetCutOnMCtruth(Bool_t mc=kTRUE) { fCutOnMCtruth=mc; }
void SetCutType(CutType type) { fCutType=type; }
-
+
// getters
Bool_t GetCutOnMCtruth() const { return fCutOnMCtruth; }
CutType GetCutType() const { return fCutType; }
//
virtual Bool_t IsSelected(TObject* track);
virtual Bool_t IsSelected(TList* /* list */ ) {return kFALSE;}
-
+
// virtual Bool_t IsSelected(TObject* track, TObject */*event*/=0);
// virtual Long64_t Merge(TCollection* /* list */) { return 0; }
-
+
//
// Cut information
//
virtual void Print(const Option_t* option = "") const;
-
+
private:
TBits *fUsedVars; // list of used variables
UShort_t fActiveCuts[AliDielectronVarManager::kNMaxValues]; // list of activated cuts
UShort_t fNActiveCuts; // number of acive cuts
UInt_t fActiveCutsMask; // mask of active cuts
-
+
UInt_t fSelectedCutsMask; // Maks of selected cuts, is available after calling IsSelected
Bool_t fCutOnMCtruth; // whether to cut on the MC truth of the particle
CutType fCutType; // type of the cut: any, all
-
+
Double_t fCutMin[AliDielectronVarManager::kNMaxValues]; // minimum values for the cuts
Double_t fCutMax[AliDielectronVarManager::kNMaxValues]; // maximum values for the cuts
Bool_t fCutExclude[AliDielectronVarManager::kNMaxValues]; // inverse cut logic?
- THnBase *fUpperCut[AliDielectronVarManager::kNMaxValues]; // use object as upper cut
+ Bool_t fBitCut[AliDielectronVarManager::kNMaxValues]; // bit cut
+ THnBase *fUpperCut[AliDielectronVarManager::kNMaxValues]; // use object as upper cut
AliDielectronVarCuts(const AliDielectronVarCuts &c);
AliDielectronVarCuts &operator=(const AliDielectronVarCuts &c);
-
- ClassDef(AliDielectronVarCuts,5) //Cut class providing cuts to all infomation available for the AliVParticle interface
+
+ ClassDef(AliDielectronVarCuts,6) //Cut class providing cuts to all infomation available for the AliVParticle interface
};