ROOT logo
AliRoot » TPC » SIM » AliTPCTrackHitsV2

class AliTPCTrackHitsV2: public TObject


Time Projection Chamber  track hits object

  Origin: Marian Ivanov , GSI Darmstadt

 AliTPCTrackHitsV2
   Container for Track Hits - based on standard TClonesArray -
   fArray of AliTPCTrackHitsParamV2
   In AliTPCTrackHitsParamV2 - parameterization of the track segment  is stored
   for each of the track segment - relative position ( distance between  hits) and
   charge of the hits is stored - comparing to classical TClonesArray of AliTPChit -
   comperssion factor of 5-7 (depending on the required precision) -
   In future release AliTPCTrackHitsV2 - will replace old AliTPCTrackHits - which were not
   based on standard ROOT containers
   Basic function:
      // during building Container
   AddHitKartez(Int_t volumeID, Int_t trackID, Double_t x, Double_t y, Double_t z,Int_t q)
   void SetHitPrecision(Double_t prec) {fPrecision=prec;}
   void SetStepPrecision(Double_t prec) {fStep=prec;}
   Bool_t  FlushHitStack(Bool_t force=kTRUE);
      //at the end necessary to have Container in consistent state

     // looping over Container
   Bool_t  First(), Bool_t Next() - iterators - return status of the operation
   AliTPChit * GetHit(); - return current hit

Function Members (Methods)

public:
AliTPCTrackHitsV2()
AliTPCTrackHitsV2(const AliTPCTrackHitsV2& hit)
virtual~AliTPCTrackHitsV2()
voidTObject::AbstractMethod(const char* method) const
voidAddHit(Int_t volumeID, Int_t trackID, Double_t r, Double_t z, Double_t fi, Int_t q, Float_t time)
voidAddHitKartez(Int_t volumeID, Int_t trackID, Double_t x, Double_t y, Double_t z, Int_t q, Float_t time)
voidAddVolume(Int_t volume)
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidClear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
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 TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
Bool_tFirst()
Bool_tFlushHitStack(Bool_t force = kTRUE)
voidFlushHitStack2(Int_t index1, Int_t index2)
TClonesArray*GetArray()
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
Int_tGetEntriesFast() const
AliHit*GetHit() const
virtual const char*TObject::GetIconName() const
static Double_tGetKPrecision()
static Double_tGetKPrecision2()
virtual const char*TObject::GetName() const
Int_tGetNVolumes() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
AliTrackHitsParamV2*GetParam()
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
Int_t*GetVolumes()
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::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 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_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
Bool_tNext()
virtual Bool_tTObject::Notify()
voidTObject::Obsolete(const char* method, const char* asOfVers, const char* removedFromVers) const
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)
AliTPCTrackHitsV2&operator=(const AliTPCTrackHitsV2& hit)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
virtual voidTObject::Print(Option_t* option = "") const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(basic_ostream<char,char_traits<char> >& out, Option_t* option = "")
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
voidSetHitPrecision(Double_t prec)
voidSetMaxDistance(UInt_t distance)
static voidTObject::SetObjectStat(Bool_t stat)
voidSetStepPrecision(Double_t prec)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
virtual voidStreamer(TBuffer&)
voidStreamerNVirtual(TBuffer& ClassDef_StreamerNVirtual_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_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
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()
private:
virtual voidCopy(TObject&) const

Data Members

protected:
TClonesArray*fArrayarray of compressed hits
AliTPCCurrentHitV2*fCurrentHit!information about current hit
AliHit*fHit! current hit information
UInt_tfMaxDistancemaximal distance between two connected hits
Int_tfNVolumesnumber of volumes in track
Double_tfPrecisionrequired precision
Int_tfSizetotal number of hits in track
Double_tfStepunit step size
AliTPCTempHitInfoV2*fTempInfo!information about track
Int_t*fVolumes[fNVolumes] list of volumes
static Int_tfgCounter1First internal counter
static Int_tfgCounter2Second internal counter
static const Double_tfgkPrecisionprecision
static const Double_tfgkPrecision2precision
static const Double_tfgkTimePrecisionhit time precision

Class Charts

Inheritance Chart:
TObject
AliTPCTrackHitsV2

Function documentation

AliTPCTrackHitsV2()
default constructor

~AliTPCTrackHitsV2()
default destructor

  if (fTrackHitsInfo) delete fTrackHitsInfo;
void Clear(Option_t* = "")
 clear object

void AddHitKartez(Int_t volumeID, Int_t trackID, Double_t x, Double_t y, Double_t z, Int_t q, Float_t time)
 add hit to the container - it add hit at the end - input in global coordinata

void AddHit(Int_t volumeID, Int_t trackID, Double_t r, Double_t z, Double_t fi, Int_t q, Float_t time)
 Adding one hit

Bool_t FlushHitStack(Bool_t force = kTRUE)
 write fHitsPosAndQ information from the stack to te arrays

void FlushHitStack2(Int_t index1, Int_t index2)
 second iteration flush stack
 call only for hits where first iteration were not succesfully interpolated

void AddVolume(Int_t volume)
add volumes to tthe list of volumes

Bool_t First()
set Current hit for the first hit

Bool_t Next()
 Hit iterator

AliHit * GetHit() const
 Return one hit

AliTrackHitsParamV2 * GetParam()
 Return current parameters

void Copy(TObject& ) const
{Error("Copy","Not Implemented");}
AliTPCTrackHitsV2()
operator=(const AliTPCTrackHitsV2& hit)
TClonesArray * GetArray()
{return fArray;}
Int_t GetEntriesFast() const
{ return fSize;}
void SetHitPrecision(Double_t prec)
{fPrecision=prec;}
void SetStepPrecision(Double_t prec)
{fStep=prec;}
void SetMaxDistance(UInt_t distance)
{fMaxDistance = distance;}
Int_t * GetVolumes()
{ return fVolumes;}
Int_t GetNVolumes() const
{return fNVolumes;}
Double_t GetKPrecision()
{return fgkPrecision;}
Double_t GetKPrecision2()
{return fgkPrecision2;}