class HMdcCal2ParSim: public HParSet

_HADES_CLASS_DESCRIPTION

 HMdcCal2ParSim

 Container class for the calibration parameters from Cal1 to Cal2 of the MDC
 distance -> time.Contains functions for calculating distance->time for track fitter
 and Digitizer of Mdc

Function Members (Methods)

public:
HMdcCal2ParSim(const HMdcCal2ParSim&)
HMdcCal2ParSim(const Char_t* name = "MdcCal2ParSim", const Char_t* title = "cal2 calibration parameters for Mdc [distance->time]", const Char_t* context = "MdcCal2ParSimProduction", Int_t n = 6)
virtual~HMdcCal2ParSim()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
Float_tcalcDriftVelocity(Int_t, Int_t, Float_t, Float_t)
Float_tcalcResolution(Int_t, Int_t, Float_t, Float_t)
Double_tcalcTime(Int_t, Int_t, Double_t, Double_t)
Float_tcalcTime(Int_t, Int_t, Float_t, Float_t)
voidcalcTime(Int_t, Int_t, Double_t, Double_t, Double_t*, Double_t*)
Float_tcalcTime2(Int_t, Int_t, Float_t, Float_t)
voidcalcTime2Digitizer(Int_t, Int_t, Float_t, Float_t, Float_t*, Float_t*)
Float_tcalcTime2Err(Int_t, Int_t, Float_t, Float_t)
voidcalcTimeDigitizer(Int_t, Int_t, Float_t, Float_t, Float_t*, Float_t*)
Double_tcalcTimeErr(Int_t, Int_t, Double_t, Double_t)
Float_tcalcTimeErr(Int_t, Int_t, Float_t, Float_t)
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
Int_tgetNumberOfBins()
Int_tgetNumberOfLines()
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()
Float_tgetSlopeOutside()
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*, Int_t*)
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)
HMdcCal2ParSim&operator=(const HMdcCal2ParSim&)
HMdcCal2ParSecSim&operator[](Int_t i)
virtual voidTObject::Paint(Option_t* option = "")
voidplot(Int_t, Int_t)
voidplot2D(Int_t, Int_t, Int_t)
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)
voidsetConstantTime1Err(Float_t m0 = 0, Float_t m1 = 0, Float_t m2 = 0, Float_t m3 = 0)
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*)
voidsetScalerTime1Err(Float_t m0 = 0, Float_t m1 = 0, Float_t m2 = 0, Float_t m3 = 0)
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
voidtransformToDistance(Int_t, Int_t, Int_t, Float_t, HMdcCal2Par*)
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_twrite(HParIo*)
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)
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:
Float_tangleDeg
Int_tangleStep
TObjArray*arrayarray of pointers of type HMdcCal2ParSecSim
TStringHParSet::authorAuthor of parameters
Bool_tHParSet::changed! flag is kTRUE if parameters have changed
TStringcomment
Float_tconstError[4]! const error of time1 per module type
TStringHParSet::descriptionDescription of parameters
Text_tHParSet::detName[10]! name of the detector the container belongs to
Float_tdistance
Int_tdmax
Int_tdmin
HMdcDetector*fMdc
TStringTNamed::fNameobject identifier
TStringTNamed::fTitleobject title
Float_tfinaltime
Int_tlinecounter
Int_tlinecounterwrite
Int_tmodule
TStringHParSet::paramContextContext/purpose for parameters and conditions
Float_tscaleError[4]! scaler for error of time1 per module type
Int_tsector
Float_tslopeOutside
Bool_tHParSet::status! static flag
Float_ttime
Float_ttime2
Int_ttype
Bool_tuseConstErr! switch for using const errors
Int_tHParSet::versions[3]! versions of container in the 2 possible inputs

Class Charts

Inheritance Inherited Members Includes Libraries
Class Charts

Function documentation

HMdcCal2ParSim(const Char_t* name = "MdcCal2ParSim", const Char_t* title = "cal2 calibration parameters for Mdc [distance->time]", const Char_t* context = "MdcCal2ParSimProduction", Int_t n = 6)
 constructor
~HMdcCal2ParSim()
 destructor
Bool_t init(HParIo* , Int_t* )
 intitializes the container from an input
Double_t calcTime(Int_t s,Int_t m,Double_t a,Double_t dist)
 This function calculates the drift time for a given distance
 to sense wire.A Interpolation between the two closest angle steps
 is performed and the drift time value returned.
 Input is the angle of the track (alphaTrack:90 degree for perpendicular impact),which
 has to be recalculated to the angle of minimum drift distance (alphaDrDist:0 degree for
 perpendicular impact).
   y ^
     |  |------------*----|              cathod  plane
     |  | cell        *   |
     |  |            / *  |
     |  |           /90 * |
     |  | driftDist/     *|
     |  |         / |     *
   --|--|--------*^-|-----|*--------->   sense/potential plane
     |  |           |     | *        x
     |  |      alphaDrDist|  *
        |                 |/  *          alphaDriftDist=90-alphaTrack
        |      alphaTrack /    *
        |-----------------|     * track  cathod plane

 angles must be between 0 and 90 degree, all other angles have to be shifted
 before calling the function.
Double_t calcTimeErr(Int_t s,Int_t m,Double_t a,Double_t dist)
 This function calculates the Error of drift time1 for a given distance
 to sense wire.A Interpolation between the two closest angle steps
 is performed and the drift time value returned.
 Input is the angle of the track (alphaTrack:90 degree for perpendicular impact),which
 has to be recalculated to the angle of minimum drift distance (alphaDrDist:0 degree for
 perpendicular impact).
   y ^
     |  |------------*----|              cathod  plane
     |  | cell        *   |
     |  |            / *  |
     |  |           /90 * |
     |  | driftDist/     *|
     |  |         / |     *
   --|--|--------*^-|-----|*--------->   sense/potential plane
     |  |           |     | *        x
     |  |      alphaDrDist|  *
        |                 |/  *          alphaDriftDist=90-alphaTrack
        |      alphaTrack /    *
        |-----------------|     * track  cathod plane

 angles must be between 0 and 90 degree, all other angles have to be shifted
 before calling the function.
void calcTime(Int_t , Int_t , Double_t , Double_t , Double_t* , Double_t* )
 This function calculates the drift time for a given distance
 to sense wire.A Interpolation between the two closest angle steps
 is performed and the drift time value returned.
 Input is the angle of the track (alphaTrack:90 degree for perpendicular impact),which
 has to be recalculated to the angle of minimum drift distance (alphaDrDist:0 degree for
 perpendicular impact).
   y ^
     |  |------------*----|              cathod  plane
     |  | cell        *   |
     |  |            / *  |
     |  |           /90 * |
     |  | driftDist/     *|
     |  |         / |     *
   --|--|--------*^-|-----|*--------->   sense/potential plane
     |  |           |     | *        x
     |  |      alphaDrDist|  *
        |                 |/  *          alphaDriftDist=90-alphaTrack
        |      alphaTrack /    *
        |-----------------|     * track  cathod plane

 angles must be between 0 and 90 degree, all other angles have to be shifted
 before calling the function.
 Time1 and Error of Time1 (no random smearing) are returned to Float pointers
Float_t calcTime(Int_t s,Int_t m,Float_t a,Float_t dist)
 This function calculates the drift time for a given distance
 to sense wire.A Interpolation between the two closest angle steps
 is performed and the drift time value returned.
 Input is the angle of the track (alphaTrack:90 degree for perpendicular impact),which
 has to be recalculated to the angle of minimum drift distance (alphaDrDist:0 degree for
 perpendicular impact).
   y ^
     |  |------------*----|              cathod  plane
     |  | cell        *   |
     |  |            / *  |
     |  |           /90 * |
     |  | driftDist/     *|
     |  |         / |     *
   --|--|--------*^-|-----|*--------->   sense/potential plane
     |  |           |     | *        x
     |  |      alphaDrDist|  *
        |                 |/  *          alphaDriftDist=90-alphaTrack
        |      alphaTrack /    *
        |-----------------|     * track  cathod plane

 angles must be between 0 and 90 degree, all other angles have to be shifted
 before calling the function.
Float_t calcTimeErr(Int_t s,Int_t m,Float_t a,Float_t dist)
 This function calculates the Error of drift time1 for a given distance
 to sense wire.A Interpolation between the two closest angle steps
 is performed and the drift time value returned.
 Input is the angle of the track (alphaTrack:90 degree for perpendicular impact),which
 has to be recalculated to the angle of minimum drift distance (alphaDrDist:0 degree for
 perpendicular impact).
   y ^
     |  |------------*----|              cathod  plane
     |  | cell        *   |
     |  |            / *  |
     |  |           /90 * |
     |  | driftDist/     *|
     |  |         / |     *
   --|--|--------*^-|-----|*--------->   sense/potential plane
     |  |           |     | *        x
     |  |      alphaDrDist|  *
        |                 |/  *          alphaDriftDist=90-alphaTrack
        |      alphaTrack /    *
        |-----------------|     * track  cathod plane

 angles must be between 0 and 90 degree, all other angles have to be shifted
 before calling the function.
Float_t calcTime2(Int_t , Int_t , Float_t , Float_t )
 This function calculates the drift time2 for a given distance
 to sense wire.A Interpolation between the two closest angle steps
 is performed and the drift time value returned.
 Input is the angle of the track (alphaTrack:90 degree for perpendicular impact),which
 has to be recalculated to the angle of minimum drift distance (alphaDrDist:0 degree for
 perpendicular impact).
   y ^
     |  |------------*----|              cathod  plane
     |  | cell        *   |
     |  |            / *  |
     |  |           /90 * |
     |  | driftDist/     *|
     |  |         / |     *
   --|--|--------*^-|-----|*--------->   sense/potential plane
     |  |           |     | *        x
     |  |      alphaDrDist|  *
        |                 |/  *          alphaDriftDist=90-alphaTrack
        |      alphaTrack /    *
        |-----------------|     * track  cathod plane

 angles must be between 0 and 90 degree, all other angles have to be shifted
 before calling the function.
Float_t calcTime2Err(Int_t , Int_t , Float_t , Float_t )
 This function calculates the Error drift time2 for a given distance
 to sense wire.A Interpolation between the two closest angle steps
 is performed and the drift time value returned.
 Input is the angle of the track (alphaTrack:90 degree for perpendicular impact),which
 has to be recalculated to the angle of minimum drift distance (alphaDrDist:0 degree for
 perpendicular impact).
   y ^
     |  |------------*----|              cathod  plane
     |  | cell        *   |
     |  |            / *  |
     |  |           /90 * |
     |  | driftDist/     *|
     |  |         / |     *
   --|--|--------*^-|-----|*--------->   sense/potential plane
     |  |           |     | *        x
     |  |      alphaDrDist|  *
        |                 |/  *          alphaDriftDist=90-alphaTrack
        |      alphaTrack /    *
        |-----------------|     * track  cathod plane

 angles must be between 0 and 90 degree, all other angles have to be shifted
 before calling the function.
Float_t calcDriftVelocity(Int_t , Int_t , Float_t , Float_t )
 This function calculates the drift velocity for a given distance
 to sense wire and impact angle. Vd [mu/ns] = deltaT1/deltaDist
Float_t calcResolution(Int_t , Int_t , Float_t , Float_t )
 This function calculates the reslution in nm for a given distance
 to sense wire and impact angle. Res[nm]=timeErr/Vd.
void calcTimeDigitizer(Int_t , Int_t , Float_t , Float_t , Float_t* , Float_t* )
 This function calculates the drift time for a given distance
 to sense wire.A Interpolation between the two closest angle steps
 is performed and the drift time value returned.
 Input is the angle of the track (alphaTrack:90 degree for perpendicular impact),which
 has to be recalculated to the angle of minimum drift distance (alphaDrDist:0 degree for
 perpendicular impact).
   y ^
     |  |------------*----|              cathod  plane
     |  | cell        *   |
     |  |            / *  |
     |  |           /90 * |
     |  | driftDist/     *|
     |  |         / |     *
   --|--|--------*^-|-----|*--------->   sense/potential plane
     |  |           |     | *        x
     |  |      alphaDrDist|  *
        |                 |/  *          alphaDriftDist=90-alphaTrack
        |      alphaTrack /    *
        |-----------------|     * track  cathod plane

 angles must be between 0 and 90 degree, all other angles have to be shifted
 before calling the function.
void calcTime2Digitizer(Int_t , Int_t , Float_t , Float_t , Float_t* , Float_t* )
 This function calculates the drift time for a given distance
 to sense wire.A Interpolation between the two closest angle steps
 is performed and the drift time value returned.
 Input is the angle of the track (alphaTrack:90 degree for perpendicular impact),which
 has to be recalculated to the angle of minimum drift distance (alphaDrDist:0 degree for
 perpendicular impact).
   y ^
     |  |------------*----|              cathod  plane
     |  | cell        *   |
     |  |            / *  |
     |  |           /90 * |
     |  | driftDist/     *|
     |  |         / |     *
   --|--|--------*^-|-----|*--------->   sense/potential plane
     |  |           |     | *        x
     |  |      alphaDrDist|  *
        |                 |/  *          alphaDriftDist=90-alphaTrack
        |      alphaTrack /    *
        |-----------------|     * track  cathod plane

 angles must be between 0 and 90 degree, all other angles have to be shifted
 before calling the function.
void transformToDistance(Int_t , Int_t , Int_t , Float_t , HMdcCal2Par* )
 fills arrays of MdcCal2Par (time) from arrays of MdcCal2ParSim (distance)
void plot(Int_t , Int_t )
 plots data into TGraphErrors for time1 and time2 including errors
void plot2D(Int_t , Int_t , Int_t )
 Plots data into 2d-Hists
 type = 0 ->time1
 type = 1 ->Error time1
 type = 2 ->time2
 type = 3 ->Error time2
Int_t write(HParIo* )
 writes the container to an output
void readline(const Char_t* , Int_t* )
 decodes one line read from ascii file I/O and calls HMdcCal2ParAngleSim::fillTime1(...)
void putAsciiHeader(TString& )
 puts the ascii header to the string used in HMdcParAsciiFileIo
Bool_t writeline(Char_t* , Int_t , Int_t , Int_t )
 writes one line to the buffer used by ascii file I/O
void clear()
 clears the container
void printParam()
 prints the container
void Streamer(TBuffer& b)
 Stream an object of class HMdcCal2ParSim.
HMdcCal2ParAngleSim& operator[](Int_t i)
Int_t getSize()
{return array->GetEntries();}
HMdcCal2ParSim(const Char_t* name = "MdcCal2ParSim", const Char_t* title = "cal2 calibration parameters for Mdc [distance->time]", const Char_t* context = "MdcCal2ParSimProduction", Int_t n = 6)
void setContainerComment(TString mycomment)
{comment=mycomment;}
TString getContainerComment()
{return comment;}
void printContainerComment()
{printf(comment.Data());}
Int_t getNumberOfLines()
{return 40;}
Int_t getNumberOfBins()
{return 100;}
Float_t getSlopeOutside()
{return slopeOutside;}
void setScalerTime1Err(Float_t m0 = 0, Float_t m1 = 0, Float_t m2 = 0, Float_t m3 = 0)
void setConstantTime1Err(Float_t m0 = 0, Float_t m1 = 0, Float_t m2 = 0, Float_t m3 = 0)

Last change: Sat May 22 12:59:55 2010
Last generated: 2010-05-22 12:59

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.