class HMdcClosePairCutsPar: public HParSet

_HADES_CLASS_DESCRIPTION

HMdcClosePairCutsPar
Container storing the cuts to make close pair rejection
If the all values of the cuts are larger than those from mdc-rich tracklet
than traclet is single. Cuts on mdc cluster size, mdc contributing wires
and integrated charge in ring are stored.
Because first two mdc variables are depending on theta,phi angle ,
there are different cuts for several theta,phi regions. There are 8 bins in theta space:
mdc cls finder level bins:
0:  4
1:  5
2:  6
theta bins:
0:  10-20 degrees
1:  20-30 degrees
2:  30-40 degrees
3:  40-50 degrees
4:  50-60 degrees
5:  60-70 degrees
6:  70-80 degrees
7:  80-90 degrees
There are three bins in phi space
phi bins:
:   0-10 & 50-6
1:  10-20 & 40-50
2:  20-30 & 30-40
The rejection power S/B ratio depends on minimal single lepton efficiency therefore there are
4 bins of efficiency
efficiency bins:
0:  80-85
1:  85-90
2:  90-95
3:  95-100

Function Members (Methods)

public:
HMdcClosePairCutsPar(const HMdcClosePairCutsPar&)
HMdcClosePairCutsPar(const Char_t* name = "MdcClosePairCutsPar", const Char_t* title = "close pair rejection parameters for Mdc-Rich", const Char_t* context = "", Int_t h = 3, Int_t l = 8, Int_t m = 3, Int_t n = 4)
virtual~HMdcClosePairCutsPar()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
Int_tcalculateMdcEffBin(Float_t min_eff)
Int_tcalculateMdcLevelBin(Float_t mdc_level)
Int_tcalculateMdcPhiBin(Float_t mdc_phi)
Int_tcalculateMdcThetaBin(Float_t mdc_the)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidclear()
virtual voidTNamed::Clear(Option_t* option = "")
virtual TObject*TNamed::Clone(const char* newname = "") const
virtual Int_tTNamed::Compare(const TObject* obj) const
virtual voidTNamed::Copy(TObject& named) const
voidHParSet::copyComment(HParSet& r)
virtual voidTObject::Delete(Option_t* option = "")MENU
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() constMENU
virtual TObject*TObject::DrawClone(Option_t* option = "") constMENU
virtual voidTObject::Dump() constMENU
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual voidTNamed::FillBuffer(char*& buffer)
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
const Char_t*HParSet::getAuthor() const
TStringgetContainerComment()
const Char_t*HParSet::getDescription() const
const Text_t*HParSet::getDetectorName()
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
Int_tHParSet::getInputVersion(Int_t i)
virtual const char*TNamed::GetName() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
const Char_t*HParSet::getParamContext() const
Int_tgetSize()
virtual const char*TNamed::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
Bool_tHParSet::hasChanged()
virtual ULong_tTNamed::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual Bool_tinit(HParIo* input, Int_t* set)
virtual voidTObject::Inspect() constMENU
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTNamed::IsSortable() const
Bool_tHParSet::isStatic()
Bool_tTObject::IsZombie() const
virtual voidTNamed::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Bool_tTObject::Notify()
static voidTObject::operator delete(void* ptr)
static voidTObject::operator delete(void* ptr, void* vp)
static voidTObject::operator delete[](void* ptr)
static voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
HMdcClosePairCutsPar&operator=(const HMdcClosePairCutsPar&)
HMdcClosePairCutsParTheta&operator[](Int_t l)
virtual voidTObject::Paint(Option_t* option = "")
Bool_tpassCuts(Float_t mdc_level, Float_t mdc_the, Float_t mdc_phi, Float_t min_eff, Float_t mdc_clustersize, Float_t mdc_nwires, Float_t rich_intcharge)
virtual voidTObject::Pop()
virtual voidHParSet::print()
virtual voidTNamed::Print(Option_t* option = "") const
voidprintContainerComment()
voidprintParam()
voidputAsciiHeader(TString&)
virtual Int_tTObject::Read(const char* name)
voidreadline(const Char_t*, Int_t*)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
voidHParSet::resetInputVersions()
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(basic_ostream<char,char_traits<char> >& out, Option_t* option = "")
voidHParSet::setAuthor(const Char_t* s)
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
voidHParSet::setChanged(Bool_t flag = kTRUE)
voidsetContainerComment(TString mycomment)
voidHParSet::setDescription(const Char_t* s)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
voidHParSet::setInputVersion(Int_t v = -1, Int_t i = 0)
virtual voidTNamed::SetName(const char* name)MENU
virtual voidTNamed::SetNameTitle(const char* name, const char* title)
static voidTObject::SetObjectStat(Bool_t stat)
voidHParSet::setParamContext(const Char_t*)
voidHParSet::setStatic(Bool_t flag = kTRUE)
virtual voidTNamed::SetTitle(const char* title = "")MENU
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector& insp, char* parent)
virtual Int_tTNamed::Sizeof() const
virtual voidStreamer(TBuffer& b)
voidStreamerNVirtual(TBuffer& b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_twrite(HParIo* output)
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) const
Bool_twriteline(Char_t*, Int_t, Int_t, Int_t, Int_t)
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()

Data Members

public:
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
protected:
TObjArray*arrayarray of pointers of HMdcClosePairCutsParPhi
TStringHParSet::authorAuthor of parameters
Bool_tHParSet::changed! flag is kTRUE if parameters have changed
TStringcomment
TStringHParSet::descriptionDescription of parameters
Text_tHParSet::detName[10]! name of the detector the container belongs to
HMdcDetector*fMdc
TStringTNamed::fNameobject identifier
TStringTNamed::fTitleobject title
TStringHParSet::paramContextContext/purpose for parameters and conditions
Int_tphi_bin_size
Int_tphi_nbin
Bool_tHParSet::status! static flag
Int_ttheta_bin_size
Int_ttheta_nbin
Int_tHParSet::versions[3]! versions of container in the 2 possible inputs

Class Charts

Inheritance Inherited Members Includes Libraries
Class Charts

Function documentation

HMdcClosePairCutsPar(const Char_t* name = "MdcClosePairCutsPar", const Char_t* title = "close pair rejection parameters for Mdc-Rich", const Char_t* context = "", Int_t h = 3, Int_t l = 8, Int_t m = 3, Int_t n = 4)
creating array of the  HMdcClosePairCutsParTheta
container has a tree structure
fName="MdcClosePairCutsPar";
fTitle="close pair rejection  parameters for Mdc-Rich";
~HMdcClosePairCutsPar()
 destructor
Int_t getSize()
 return the size of the pointer array
Bool_t init(HParIo* input, Int_t* set)
 intitializes the container from an input
Int_t write(HParIo* output)
 writes the container to an output
void clear()
void putAsciiHeader(TString& )
 puts the ascii header to the string used in HMdcParAsciiFileIo
Bool_t writeline(Char_t* , Int_t , Int_t , Int_t , Int_t )
 writes one line to the buffer used by ascii file I/O
void readline(const Char_t* , Int_t* )
 writes one line to the buffer used by ascii file I/O
void printParam(void)
Bool_t passCuts(Float_t mdc_level, Float_t mdc_the, Float_t mdc_phi, Float_t min_eff, Float_t mdc_clustersize, Float_t mdc_nwires, Float_t rich_intcharge)
The usefull function to check whether values in cluster pass the CPR cuts:
mdc_level ... 4-6
mdc_the,mdc_phi angles in degrees
min_eff 80,85,90 or 95

Int_t calculateMdcThetaBin(Float_t mdc_the)
Int_t calculateMdcPhiBin(Float_t mdc_phi)
Int_t calculateMdcLevelBin(Float_t mdc_level)
Int_t calculateMdcEffBin(Float_t min_eff)
HMdcClosePairCutsParCut& operator[](Int_t l)
HMdcClosePairCutsPar(const Char_t* name = "MdcClosePairCutsPar", const Char_t* title = "close pair rejection parameters for Mdc-Rich", const Char_t* context = "", Int_t h = 3, Int_t l = 8, Int_t m = 3, Int_t n = 4)
void setContainerComment(TString mycomment)
{comment=mycomment;}
TString getContainerComment()
{return comment;}
void printContainerComment()
{printf(comment.Data());}

Last change: Sat May 22 13:00:56 2010
Last generated: 2010-05-22 13:00

This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.