ROOT logo
AliRoot » STEER » STEER » AliTrackFitterKalman

class AliTrackFitterKalman: public AliTrackFitter


                      Kalman-Filter-like fit
   to a straight-line crossing a set of arbitrarily oriented planes.
   The resulting line is given by the equation:
                  (x-x0)/vx = (y-y0)/1 = (z-z0)/vz
   Parameters of the fit are:
        x0,y0,z0 (a point on the line) and
        vx,1,vz  (a vector collinear with the line)

   LIMITATION:  The line must not be perpendicular to the Y axis.

          Origin: Iouri Belikov, CERN, Jouri.Belikov@cern.ch


Function Members (Methods)

public:
AliTrackFitterKalman()
AliTrackFitterKalman(AliTrackPointArray* array, Bool_t owner = kTRUE)
virtual~AliTrackFitterKalman()
voidTObject::AbstractMethod(const char* method) const
virtual Bool_tAddPoint(const AliTrackPoint* p)
virtual voidTObject::AppendPad(Option_t* option = "")
virtual Bool_tBegin(Int_t first, Int_t last)
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
Bool_tAliTrackFitter::FindVolId(const TArrayI* array, UShort_t volid) const
virtual Bool_tAliTrackFitter::Fit(const TArrayI* volIds, const TArrayI* volIdsFit = 0x0, AliGeomManager::ELayerID layerRangeMin = AliGeomManager::kFirstLayer, AliGeomManager::ELayerID layerRangeMax = AliGeomManager::kLastLayer)
Float_tAliTrackFitter::GetChi2() const
const TMatrixDSym&AliTrackFitter::GetCovariance() const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
Int_tAliTrackFitter::GetMinNPoints() const
virtual const char*TObject::GetName() const
Int_tAliTrackFitter::GetNdf() const
Float_tAliTrackFitter::GetNormChi2() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
const Double_t*AliTrackFitter::GetParam() const
virtual Bool_tGetPCA(const AliTrackPoint& p, AliTrackPoint& p2) const
virtual const char*TObject::GetTitle() const
voidAliTrackFitter::GetTrackResiduals(AliTrackPointArray*& pVolId, AliTrackPointArray*& pTrack) const
virtual UInt_tTObject::GetUniqueID() const
const Float_t*AliTrackFitter::GetX() const
const Float_t*AliTrackFitter::GetY() const
const Float_t*AliTrackFitter::GetZ() 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
virtual voidTObject::ls(Option_t* option = "") const
Bool_tMakeSeed(const AliTrackPoint* p, const AliTrackPoint* p2)
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)
virtual voidAliTrackFitter::Reset()
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)
voidSetMaxChi2(Double_t chi2)
voidAliTrackFitter::SetMinNPoints(Int_t n)
static voidTObject::SetObjectStat(Bool_t stat)
voidSetSeed(const Double_t* par, const Double_t* cov)
virtual voidAliTrackFitter::SetTrackPointArray(AliTrackPointArray* array, Bool_t owner = kTRUE)
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 Bool_tUpdate()
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

protected:
Float_tAliTrackFitter::fChi2Chi squared of the fit
TMatrixDSym*AliTrackFitter::fCovTrack cov matrix
Bool_tAliTrackFitter::fIsOwnerIs the object owner of the space points array
Int_tAliTrackFitter::fMinNPointsMinimum allowed number of points
Int_tAliTrackFitter::fNdfNumber of degrees of freedom
AliTrackPointArray*AliTrackFitter::fPTrackPointer to the array with track extrapolation points in volId
AliTrackPointArray*AliTrackFitter::fPVolIdPointer to the array with space-points in volId
Double_tAliTrackFitter::fParams[6]Track parameters
AliTrackPointArray*AliTrackFitter::fPointsPointer to the array with track space points
private:
Double_tfMaxChi2A point is added if chi2 < fMaxChi2
static const Double_tfgkMaxChi2Default maximal allowed chi2

Class Charts

Inheritance Chart:
TObject
AliTrackFitter
AliTrackFitterKalman

Function documentation

Bool_t Begin(Int_t first, Int_t last)
 Make a seed out of the track points with the indices "first" and "last".
 This is the "default" seed.

Bool_t AddPoint(const AliTrackPoint* p)
 Add a point to the fit

Double_t GetPredictedChi2(const AliTrackPoint* p) const
 Calculate the predicted chi2 increment.

Bool_t Propagate(const AliTrackPoint* p)
 Propagate the track towards the measured point "p"

Bool_t Update(const AliTrackPoint* p, Double_t chi2)
 Update the track params using the measured point "p"

Bool_t GetPCA(const AliTrackPoint& p, AliTrackPoint& p2) const
 Get the intersection point "i" between the track and the plane
 the point "p" belongs to.

SetSeed(const Double_t* par, const Double_t* cov)
 Set the initial approximation for the track parameters

AliTrackFitterKalman()
{}
AliTrackFitterKalman(AliTrackPointArray* array, Bool_t owner = kTRUE)
virtual ~AliTrackFitterKalman()
{}
void SetMaxChi2(Double_t chi2)
{fMaxChi2=chi2;}
Bool_t MakeSeed(const AliTrackPoint* p, const AliTrackPoint* p2)
Bool_t Update()
{return kTRUE;}
AliTrackFitterKalman(const AliTrackFitterKalman& kalman)
AliTrackFitterKalman & operator=(const AliTrackFitterKalman& kalman)