ROOT logo
AliRoot » MUON » AliMUONDigitCalibrator

class AliMUONDigitCalibrator: public TObject

 \class AliMUONDigitCalibrator
 Class used to calibrate digits (either real or simulated ones).

 The calibration consists of subtracting the pedestal
 and multiplying by a gain, so that
 Signal = (ADC-pedestal)*gain

 Please note also that for the moment, if a digit lies on a dead channel
 we remove this digit from the list of digits.
 FIXME: this has to be revisited. By using the AliMUONDigit::fFlags we
 should in principle flag a digit as bad w/o removing it, but this
 then requires some changes in the cluster finder to deal with this extra
 information correctly (e.g. to set a quality for the cluster if it contains
 bad digits).

 \author Laurent Aphecetche

Function Members (Methods)

public:
AliMUONDigitCalibrator(Int_t runNumber)
AliMUONDigitCalibrator(const AliMUONCalibrationData& calib, const AliMUONRecoParam* recoParams)
AliMUONDigitCalibrator(const AliMUONCalibrationData& calib, int b)
virtual~AliMUONDigitCalibrator()
voidTObject::AbstractMethod(const char* method) const
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
virtual voidCalibrate(AliMUONVDigitStore& digitStore)
Float_tCalibrateDigit(Int_t detElemId, Int_t manuId, Int_t manuChannel, Float_t adc, Float_t nsigmas = -1, Bool_t* isSaturated = 0x0) const
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
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
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_tIsValidDigit(Int_t detElemId, Int_t manuId, Int_t manuChannel, Int_t* statusMap = 0x0) const
Bool_tTObject::IsZombie() 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)
Int_tPadStatus(Int_t detElemId, Int_t manuId, Int_t manuChannel) const
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)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector&)
Int_tStatusMap(Int_t detElemId, Int_t manuId, Int_t manuChannel) 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
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:
AliMUONDigitCalibrator(const AliMUONDigitCalibrator& other)
voidCtor(const AliMUONCalibrationData& calib, const AliMUONRecoParam* recoParams, Bool_t deferredInitialization = kTRUE)
AliMUONDigitCalibrator&operator=(const AliMUONDigitCalibrator& other)

Data Members

private:
Int_tfApplyGains!< whether we should apply gains or not, capa or not...
AliMUONVStore*fCapacitances!< capa values
Double_tfChargeSigmaCut!< number of sigmas to cut on
AliMUONVStore*fGains!< gain values
AliMUONLogger*fLogger!< to log repeated messages
UInt_tfMask!< mask used to cut bad channels
Double_tfNumberOfBadPads!< # of times we've rejected a bad pad
Double_tfNumberOfPads!< # of pads we've seen
AliMUONVStore*fPedestals!< pedestal values
AliMUONPadStatusMaker*fStatusMaker!< to build pad statuses
AliMUONPadStatusMapMaker*fStatusMapMaker!< to build status map
static const Int_tfgkGain!< apply gain and capa (from OCDB)
static const Int_tfgkGainConstantCapa!< apply gain (from OCDB) with constant capa
static const Int_tfgkInjectionGain!< apply injection gain (from OCDB)
static const Int_tfgkNoGain!< do not apply gain calib at all

Class Charts

Inheritance Chart:
TObject
AliMUONDigitCalibrator

Function documentation

AliMUONDigitCalibrator(Int_t runNumber)
 ctor
AliMUONDigitCalibrator(const AliMUONCalibrationData& calib, const AliMUONRecoParam* recoParams)
 ctor
AliMUONDigitCalibrator(const AliMUONCalibrationData& calib, int b)
 ctor
Ctor(const AliMUONCalibrationData& calib, const AliMUONRecoParam* recoParams, Bool_t deferredInitialization = kTRUE)
 designated ctor
~AliMUONDigitCalibrator()
 dtor.
Calibrate(AliMUONVDigitStore& digitStore)
 Calibrate the digits contained in digitStore
CalibrateDigit(Int_t detElemId, Int_t manuId, Int_t manuChannel, Float_t adc, Float_t nsigmas = -1, Bool_t* isSaturated = 0x0) const
 Calibrate one digit
 Return the digit charge, in fC
IsValidDigit(Int_t detElemId, Int_t manuId, Int_t manuChannel, Int_t* statusMap = 0x0) const
 Check if a given pad is ok or not.
PadStatus(Int_t detElemId, Int_t manuId, Int_t manuChannel) const
 Return the status of the given pad
StatusMap(Int_t detElemId, Int_t manuId, Int_t manuChannel) const
 Return the status map of the given pad
AliMUONDigitCalibrator(Int_t runNumber)
AliMUONDigitCalibrator& operator=(const AliMUONDigitCalibrator& other)
 Not implemented