2 // Class AliMixEventCutObj
4 // AliMixEventCutObj object contains information about one cut on for event mixing
5 // used by AliMixEventPool class
8 // Martin Vala (martin.vala@cern.ch)
11 #ifndef ALIMIXEVENTCUTOBJ_H
12 #define ALIMIXEVENTCUTOBJ_H
20 class AliMixEventCutObj : public TObject {
22 enum EEPAxis_t {kMultiplicity = 0, kZVertex = 1, kNumberV0s = 2, kNumberTracklets = 3, kCentrality = 4, kAllEventAxis = 5};
24 AliMixEventCutObj(AliMixEventCutObj::EEPAxis_t type = kMultiplicity, Float_t min = 0.0, Float_t max = 0.0, Float_t step = 1.0, const char* opt = "");
25 AliMixEventCutObj(const AliMixEventCutObj &obj);
26 AliMixEventCutObj &operator=(const AliMixEventCutObj &obj);
28 virtual void Print(const Option_t *) const;
29 void PrintCurrentInterval();
30 void PrintValues(AliVEvent *main, AliVEvent* mix);
34 Bool_t HasMore() const;
36 Int_t GetNumberOfBins() const;
37 Float_t GetMin() const { return fCurrentVal; }
38 Float_t GetMax() const { return fCurrentVal + fCutStep - fCutSmallVal; }
39 Float_t GetStep() const { return fCutStep; }
40 Short_t GetType() const { return fCutType; }
41 Int_t GetBinNumber(Float_t num) const;
42 Int_t GetIndex(AliVEvent *ev);
43 Double_t GetValue(AliVEvent *ev);
44 Double_t GetValue(AliESDEvent *ev);
45 Double_t GetValue(AliAODEvent *ev);
47 const char *GetCutName(Int_t index = -1) const;
49 void SetCurrentValueToIndex(Int_t index);
52 Int_t fCutType; // cut type
53 TString fCutOpt; // cut option string
54 Float_t fCutMin; // cut min
55 Float_t fCutMax; // cut max
56 Float_t fCutStep; // cut step
57 Float_t fCutSmallVal; // small value
59 Float_t fCurrentVal; // current value
61 ClassDef(AliMixEventCutObj, 2)