ROOT logo
AliRoot » MFT » AliMFT

class AliMFT: public AliDetector

 * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
 *                                                                        *
 * Author: The ALICE Off-line Project.                                    *
 * Contributors are mentioned in the code where appropriate.              *
 *                                                                        *
 * Permission to use, copy, modify and distribute this software and its   *
 * documentation strictly for non-commercial purposes is hereby granted   *
 * without fee, provided that the above copyright notice appears in all   *
 * copies and that both the copyright notice and this permission notice   *
 * appear in the supporting documentation. The authors make no claims     *
 * about the suitability of this software for any purpose. It is          *
 * provided "as is" without express or implied warranty.                  *

Function Members (Methods)

public:
AliMFT()
AliMFT(const Char_t* name, const Char_t* title)
AliMFT(const Char_t* name, const Char_t* title, Char_t* nameGeomFile)
virtual~AliMFT()
voidTObject::AbstractMethod(const char* method) const
voidAddAlignableVolumes()
virtual voidAddAlignableVolumes() const
virtual voidAliModule::AddDigit(Int_t*, Int_t*)
virtual voidAliModule::AddHit(Int_t, Int_t*, Float_t*)
virtual AliTrackReference*AliModule::AddTrackReference(Int_t label, Int_t id = -999)
virtual voidAliModule::AliGetMaterial(Int_t imat, char* name, Float_t& a, Float_t& z, Float_t& dens, Float_t& radl, Float_t& absl) const
virtual voidAliModule::AliMaterial(Int_t imat, const char* name, Float_t a, Float_t z, Float_t dens, Float_t radl, Float_t absl, Float_t* buf = 0, Int_t nwbuf = 0) const
virtual voidAliModule::AliMatrix(Int_t& nmat, Float_t theta1, Float_t phi1, Float_t theta2, Float_t phi2, Float_t theta3, Float_t phi3) const
virtual voidAliModule::AliMedium(Int_t numed, const char* name, Int_t nmat, Int_t isvol, Int_t ifield, Float_t fieldm, Float_t tmaxfd, Float_t stemax, Float_t deemax, Float_t epsil, Float_t stmin, Float_t* ubuf = 0, Int_t nbuf = 0) const
virtual voidAliModule::AliMixture(Int_t imat, const char* name, Float_t* a, Float_t* z, Float_t dens, Int_t nlmat, Float_t* wmat) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidAliDetector::Browse(TBrowser* b)
virtual voidAliModule::BuildGeometry()
virtual voidAliModule::CheckQA()
static TClass*Class()
virtual const char*TObject::ClassName() const
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
virtual AliDigitizer*CreateDigitizer(AliDigitizationInput* digInp) const
voidCreateDigits()
virtual voidCreateGeometry()
voidCreateHits()
virtual voidCreateMaterials()
voidCreateRecPoints()
voidCreateSDigits()
virtual AliTriggerDetector*AliModule::CreateTriggerDetector() const
TGeoVolumeAssembly*CreateVol()
virtual voidAliModule::DefineOpticalProperties()
virtual voidTObject::Delete(Option_t* option = "")MENU
virtual TClonesArray*AliDetector::Digits() const
virtual voidAliModule::Digits2Raw()
virtual voidAliModule::Digits2Reco()
virtual voidAliModule::DisableStepManager()
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 voidAliDetector::DrawModule() const
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
virtual voidAliModule::FinishEvent()
virtual voidAliModule::FinishPrimary()
virtual voidAliDetector::FinishRun()
virtual AliHit*AliDetector::FirstHit(Int_t track)
Double_tGetChargeDispersion()
static Float_tAliModule::GetDensityFactor()
AliDigitizationInput*AliModule::GetDigitizationInput() const
TObjArray*GetDigitsList() const
TClonesArray*GetDigitsList(Int_t plane) const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
const Char_t*GetFileNameForPileUpEvents()
const Char_t*GetFileNameForUnderlyingEvent()
virtual const char*TObject::GetIconName() const
virtual TArrayI*AliModule::GetIdtmed() const
virtual Int_tAliDetector::GetIshunt() const
virtual AliLoader*AliDetector::GetLoader() const
virtual const char*TNamed::GetName() const
virtual intAliDetector::GetNdigits() const
virtual intAliDetector::GetNhits() const
Int_tGetNPlanes() const
Int_tGetNSlices() const
Int_tGetNStepForChargeDispersion()
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
Short_tGetPileUpEventID(Short_t i)
TObjArray*GetRecPointsList() const
TClonesArray*GetRecPointsList(Int_t plane) const
TObjArray*GetSDigitsList() const
TClonesArray*GetSDigitsList(Int_t plane) const
AliMFTSegmentation*GetSegmentation() const
Double_tGetSingleStepForChargeDispersion()
virtual Float_tAliDetector::GetTimeGate() const
virtual const char*TNamed::GetTitle() const
Short_tGetUnderlyingEventID()
virtual UInt_tTObject::GetUniqueID() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTNamed::Hash() const
virtual Int_t&AliModule::HiMedium()
virtual TClonesArray*AliDetector::Hits() const
virtual voidAliModule::Hits2Digits()
virtual voidHits2SDigits()
voidHits2SDigitsLocal(TClonesArray* hits, const TObjArray* pSDig, Int_t track)
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 voidAliModule::Init()
virtual voidTObject::Inspect() constMENU
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tAliModule::IsActive() const
virtual Bool_tAliDetector::IsDetector() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tAliModule::IsFolder() const
virtual Bool_tAliDetector::IsModule() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTNamed::IsSortable() const
virtual Int_tIsVersion() const
Bool_tTObject::IsZombie() const
virtual voidAliModule::LoadPoints(Int_t)
virtual Int_t&AliModule::LoMedium()
virtual voidTNamed::ls(Option_t* option = "") const
virtual voidMakeBranch(Option_t* option = "")
virtual TBranch*AliDetector::MakeBranchInTree(TTree* tree, const char* cname, void* address, Int_t size = 32000, const char* file = 0)
virtual TBranch*AliDetector::MakeBranchInTree(TTree* tree, const char* cname, const char* name, void* address, Int_t size = 32000, Int_t splitlevel = 99, const char* file = 0)
virtual AliLoader*AliDetector::MakeLoader(const char* topfoldername)
virtual voidAliDetector::MakeTree(Option_t* option)
voidTObject::MayNotUse(const char* method) const
virtual AliHit*AliDetector::NextHit()
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 voidAliModule::Paint(Option_t*)
virtual TObjArray*AliModule::Points() const
virtual voidTObject::Pop()
virtual voidAliModule::PostTrack()
virtual voidAliModule::PreTrack()
virtual voidTNamed::Print(Option_t* option = "") const
virtual voidAliDetector::Publish(const char* dir, void* c, const char* name = 0) const
virtual voidAliModule::QADataMaker(const char*)
virtual voidAliModule::Raw2Digits()
virtual Bool_tAliModule::Raw2SDigits(AliRawReader*)
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
virtual voidAliDetector::RemapTrackHitIDs(Int_t*)
voidTObject::ResetBit(UInt_t f)
virtual voidResetDigits()
virtual voidAliDetector::ResetHits()
voidResetRecPoints()
virtual voidResetSDigits()
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(basic_ostream<char,char_traits<char> >& out, Option_t* option = "")
virtual voidAliModule::SDigits2Digits()
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidAliDetector::SetBufferSize(Int_t bufsize = 8000)
voidSetChargeDispersion(Double_t chargeDispersion)
static voidAliModule::SetDensityFactor(Float_t density)
voidSetDensitySupportOverSi(Double_t density)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
voidSetFileNameForPileUpEvents(TString fileName)
voidSetFileNameForUnderlyingEvent(TString fileName)
voidSetGeometry()
virtual voidAliDetector::SetIshunt(Int_t ishunt)
voidAliDetector::SetLoader(AliLoader* loader)
virtual voidTNamed::SetName(const char* name)MENU
virtual voidTNamed::SetNameTitle(const char* name, const char* title)
voidSetNSlices(Int_t nSlices)
voidSetNStepForChargeDispersion(Int_t nStepForChargeDispersion)
static voidTObject::SetObjectStat(Bool_t stat)
voidSetPileUpEventID(Short_t i, Short_t eventID)
voidAliModule::SetRunLoader(AliRunLoader* runLoader)
virtual voidAliDetector::SetTimeGate(Float_t gate)
virtual voidTNamed::SetTitle(const char* title = "")MENU
virtual voidSetTreeAddress()
voidSetUnderlyingEventID(Short_t eventID)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
virtual Int_tTNamed::Sizeof() const
virtual voidStepManager()
virtual Bool_tAliModule::StepManagerIsEnabled() const
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
TTree*AliModule::TreeTR()
virtual voidAliModule::UpdateInternalGeometry()
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
virtual Float_tAliModule::ZMax() const
virtual Float_tAliModule::ZMin() const
protected:
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()
private:
AliMFT(const AliMFT& mft)
AliMFT&operator=(const AliMFT& mft)

Data Members

public:
enum EMedia { kAir
kSi
kReadout
kSupport
kCarbon
kAlu
kWater
kSiO2
kInox
};
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
protected:
Bool_tAliModule::fActiveDetector activity flag
Int_tAliDetector::fBufferSize!buffer size for Tree detector branches
Double_tfChargeDispersion
Int_tAliDetector::fCurIterHit!Counter for the hit iterator
Int_tAliModule::fCurrentIterTrackRef!for track refernce iterator routines
Double_tfDensitySupportOverSi
AliDigitizationInput*AliModule::fDigInput! input for sdigits -> digits
TClonesArray*AliDetector::fDigits!List of digits for this detector
TObjArray*fDigitsPerPlane![fNPlanes] list of digits [per plane]
Bool_tAliModule::fEnableStepManager enabling flag
TStringfFileNameForPileUpEvents
TStringfFileNameForUnderyingEvent
Int_tAliModule::fHiMedium!Maximum tracking medium ID for this Module
TClonesArray*AliDetector::fHits!List of hits for one track only
TArrayI*AliModule::fIdmate!List of material numbers
TArrayI*AliModule::fIdtmed!List of tracking medium numbers
Int_tAliDetector::fIshunt1 if the hit is attached to the primary
Int_tAliModule::fLoMedium!Minimum tracking medium ID for this Module
AliLoader*AliDetector::fLoader! pointer to getter for this module skowron
Int_tAliDetector::fMaxIterHit!Limit for the hit iterator
Int_tAliModule::fMaxIterTrackRef!for track refernce iterator routines
static const Int_tfNMaxPlanesmax number of MFT planes
Short_tfNPileUpEvents
Int_tfNPlanes# of MFT planes
Int_tfNSlices# of slices per MFT plane
Int_tfNStepForChargeDispersion
TStringTNamed::fNameobject identifier
TStringfNameGeomFile
Int_tAliDetector::fNdigits!Number of digits
Int_tAliDetector::fNhits!Number of hits
Short_tfPileUpEventsIDs[5]
TObjArray*fRecPointsPerPlane![fNPlanes] list of recPoints [per plane]
AliRunLoader*AliModule::fRunLoader!local pointer to run loader
TObjArray*fSDigitsPerPlane![fNPlanes] list of sdigits [per plane]
AliMFTSegmentation*fSegmentation
TClonesArray*fSideDigits! list of digits fired by the charge dispersion coming from the main hit
Double_tfSingleStepForChargeDispersion
Float_tAliDetector::fTimeGateTime gate in seconds
TStringTNamed::fTitleobject title
Short_tfUnderlyingEventID
Int_tfVersion
static Float_tAliModule::fgDensityFactor! factor that is multiplied to all material densities (ONLY for systematic studies)

Class Charts

Inheritance Chart:
TNamed
AliModule
AliDetector
AliMFT

Function documentation

AliMFT()
AliMFT(const Char_t* name, const Char_t* title)
AliMFT(const Char_t* name, const Char_t* title, Char_t* nameGeomFile)
~AliMFT()
void CreateMaterials()
void CreateGeometry()
void AddAlignableVolumes()
void StepManager()
TGeoVolumeAssembly* CreateVol()
void Hits2SDigits()
void Hits2SDigitsLocal(TClonesArray* hits, const TObjArray* pSDig, Int_t track)
void MakeBranch(Option_t* option = "")
void SetTreeAddress()
void SetGeometry()
void CreateHits()
void CreateSDigits()
void CreateDigits()
void CreateRecPoints()
AliMFT()
Int_t IsVersion() const
{ return fVersion; }
void AddAlignableVolumes()
TObjArray* GetSDigitsList() const
{ return fSDigitsPerPlane; }
TClonesArray* GetSDigitsList(Int_t plane) const
{ return fSDigitsPerPlane ? (TClonesArray*) fSDigitsPerPlane->At(plane):0; }
TObjArray* GetDigitsList() const
{return fDigitsPerPlane;}
TClonesArray* GetDigitsList(Int_t plane) const
{return fDigitsPerPlane ? (TClonesArray*) fDigitsPerPlane->At(plane):0; }
TObjArray* GetRecPointsList() const
TClonesArray* GetRecPointsList(Int_t plane) const
{return fRecPointsPerPlane ? (TClonesArray*) fRecPointsPerPlane->At(plane):0; }
void ResetSDigits()
{ if(fSDigitsPerPlane) for(int iPlane=0; iPlane<fNPlanes; iPlane++) ((TClonesArray*) fSDigitsPerPlane ->At(iPlane))->Clear(); }
void ResetDigits()
{ if(fDigitsPerPlane) for(int iPlane=0; iPlane<fNPlanes; iPlane++) ((TClonesArray*) fDigitsPerPlane ->At(iPlane))->Clear(); }
void ResetRecPoints()
{ if(fRecPointsPerPlane) for(int iPlane=0; iPlane<fNPlanes; iPlane++) ((TClonesArray*) fRecPointsPerPlane->At(iPlane))->Clear(); }
AliDigitizer* CreateDigitizer(AliDigitizationInput* digInp) const
{ return new AliMFTDigitizer(digInp); }
AliMFTSegmentation* GetSegmentation() const
{ return fSegmentation; }
void SetNSlices(Int_t nSlices)
{ fNSlices = nSlices; }
Int_t GetNSlices() const
{ return fNSlices; }
Int_t GetNPlanes() const
{ return fNPlanes; }
void SetChargeDispersion(Double_t chargeDispersion)
{ fChargeDispersion = chargeDispersion; }
Double_t GetChargeDispersion()
{ return fChargeDispersion; }
void SetNStepForChargeDispersion(Int_t nStepForChargeDispersion)
{ fNStepForChargeDispersion = nStepForChargeDispersion; }
Int_t GetNStepForChargeDispersion()
Double_t GetSingleStepForChargeDispersion()
void SetDensitySupportOverSi(Double_t density)
{ if (density>1e-6) fDensitySupportOverSi=density; else fDensitySupportOverSi=1e-6; }
void SetFileNameForUnderlyingEvent(TString fileName)
for underlying and pile-up events
{ if (fileName.EndsWith("MFT.RecPoints.root")) fFileNameForUnderyingEvent += fileName; }
void SetFileNameForPileUpEvents(TString fileName)
{ if (fileName.EndsWith("MFT.RecPoints.root")) fFileNameForPileUpEvents += fileName; }
void SetUnderlyingEventID(Short_t eventID)
{ fUnderlyingEventID = eventID; }
void SetPileUpEventID(Short_t i, Short_t eventID)
{ if (i>=0 && i<AliMFTConstants::fNMaxPileUpEvents) fPileUpEventsIDs[i] = eventID; }
const Char_t* GetFileNameForUnderlyingEvent()
const Char_t* GetFileNameForPileUpEvents()
Short_t GetUnderlyingEventID()
{ return fUnderlyingEventID; }
Short_t GetPileUpEventID(Short_t i)
{ if (i>=0 && i<AliMFTConstants::fNMaxPileUpEvents) return fPileUpEventsIDs[i]; else return -1; }
AliMFT & operator=(const AliMFT& mft)