ROOT logo
AliRoot » TPC » BASE » AliTPCTransform

class AliTPCTransform: public AliTransform

          Implementation of the TPC transformation class

   Origin: Marian Ivanov   Marian.Ivanov@cern.ch
           Magnus Mager

   Class for tranformation of the coordinate frame
   Transformation
    local coordinate frame (sector, padrow, pad, timebine) ==>
    rotated global (tracking) cooridnate frame (sector, lx,ly,lz)

    Unisochronity  - (substract time0 - pad by pad)
    Drift velocity - Currently common drift velocity - functionality of AliTPCParam
    ExB effect     -

    Time of flight correction -
                   - Depends on the vertex position
                   - by default

    Usage:
          AliTPCclusterer::AddCluster
          AliTPCtracker::Transform


Function Members (Methods)

public:
AliTPCTransform()
AliTPCTransform(const AliTPCTransform& transform)
virtual~AliTPCTransform()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
voidApplyTransformations(Double_t* xyz, Int_t volID)
virtual voidTObject::Browse(TBrowser* b)
static TClass*Class()
virtual const char*TObject::ClassName() const
virtual voidTObject::Clear(Option_t* = "")
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
virtual voidTObject::Copy(TObject& object) 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
voidGetCosAndSin(Int_t sector, Double_t& cos, Double_t& sin) const
const AliTPCRecoParam*GetCurrentRecoParam() const
AliTPCRecoParam*GetCurrentRecoParamNonConst() const
UInt_tGetCurrentRunNumber() const
UInt_tGetCurrentTimeStamp() const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
virtual const char*TObject::GetName() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
voidGlobal2RotatedGlobal(Int_t sector, Double_t* x) const
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
voidLocal2RotatedGlobal(Int_t sec, Double_t* x) const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
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)
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)
voidRotatedGlobal2Global(Int_t sector, Double_t* x) const
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)
voidSetCurrentRecoParam(AliTPCRecoParam* param)
voidSetCurrentRun(Int_t run)
voidSetCurrentTimeStamp(Int_t timeStamp)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
static voidTObject::SetObjectStat(Bool_t stat)
voidSetPrimVertex(Double_t* vtx)
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 voidTransform(Double_t* x, Int_t* i, UInt_t time, Int_t coordinateType)
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()

Data Members

private:
Double_tfCoss[18]cache the transformation
AliTPCRecoParam*fCurrentRecoParam! current reconstruction parameters
Int_tfCurrentRun! current run
UInt_tfCurrentTimeStamp! current time stamp
Double_tfPrimVtx[3]position of the primary vertex - needed for TOF correction
Double_tfSins[18]cache the transformation

Class Charts

Inheritance Chart:
TObject
AliTransform
AliTPCTransform

Function documentation

AliTPCTransform()
 Speed it up a bit!

AliTPCTransform(const AliTPCTransform& transform)
 Speed it up a bit!

~AliTPCTransform()
 Destructor

void SetPrimVertex(Double_t* vtx)


void Transform(Double_t* x, Int_t* i, UInt_t time, Int_t coordinateType)
 input: x[0] - pad row
        x[1] - pad
        x[2] - time in us
        i[0] - sector
 output: x[0] - x (all in the rotated global coordinate frame)
         x[1] - y
         x[2] - z

  primvtx     - position of the primary vertex
                used for the TOF correction
                TOF of particle calculated assuming the speed-of-light and
                line approximation

void Local2RotatedGlobal(Int_t sec, Double_t* x) const

 Tranform coordinate from
 row, pad, time to x,y,z

 Drift Velocity
 Current implementation - common drift velocity - for full chamber
 TODO: use a map or parametrisation!



void RotatedGlobal2Global(Int_t sector, Double_t* x) const
 transform possition rotated global to the global

void Global2RotatedGlobal(Int_t sector, Double_t* x) const
 tranform possition Global2RotatedGlobal

void GetCosAndSin(Int_t sector, Double_t& cos, Double_t& sin) const
void ApplyTransformations(Double_t* xyz, Int_t volID)
 Modify global position
 xyz    - global xyz position
 volID  - volID of detector (sector number)


UInt_t GetCurrentTimeStamp() const
const AliTPCRecoParam * GetCurrentRecoParam() const
AliTPCRecoParam * GetCurrentRecoParamNonConst() const
UInt_t GetCurrentRunNumber() const
 set current values

{ return fCurrentRun;}
void SetCurrentRecoParam(AliTPCRecoParam* param)
void SetCurrentRun(Int_t run)
void SetCurrentTimeStamp(Int_t timeStamp)
{fCurrentTimeStamp=timeStamp;}
AliTPCTransform& operator=(const AliTPCTransform& )