ROOT logo
AliRoot » PHOS » AliPHOSPulseGenerator

class AliPHOSPulseGenerator: public TObject

Function Members (Methods)

public:
AliPHOSPulseGenerator(Double_t a = 0, Double_t t0 = 0)
virtual~AliPHOSPulseGenerator()
voidTObject::AbstractMethod(const char* method) const
voidAddBaseline(Double_t baselineLevel)
voidAddNoise(Double_t sigma)
voidAddNoise(Double_t* sigma, Double_t cutoff)
voidAddPretriggerSamples(Int_t nPresamples)
virtual voidTObject::AppendPad(Option_t* option = "")
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
voidDigitize()
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidDraw(Option_t* opt = "all")
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_tGetDigitize()
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
Int_tGetRawFormatOrder() const
static Int_tGetRawFormatTimeBins()
static Double_tGetRawFormatTimeMax()
Double_tGetRawFormatTimePeak() const
Double_tGetRawFormatTimeTrigger() const
voidGetSamples(Int_t* adcHG, Int_t* adcLG) 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_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
Bool_tMakeSamples()
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 voidPrint(Option_t*) const
static Double_tRawResponseFunction(Double_t* x, Double_t* par)
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidReset()
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 = "")
voidSetAmplitude(Double_t a)
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
voidSetDigitise(Bool_t flag)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
voidSetHG2LGRatio(Double_t r = 16.)
static voidTObject::SetObjectStat(Bool_t stat)
voidSetTimeStep(Double_t step = 100.e-9)
voidSetTZero(Double_t t0)
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()

Data Members

private:
Double_tfAmplitudesignal amplitude in GeV
Double_t*fDataHGsamples array for high gain
Double_t*fDataLGsamples array for low gain
Bool_tfDigitizetrue is samples should be rounded to integers
Double_tfHG2LGratioHG/LG ratio for given channel
Double_tfTZerosignal start time in ns
static Int_tfgOrderorder of the gamma function
static Double_tfgTimeMaxmaximum sampled time
static Double_tfgTimePeakpeaking time
static Double_tfgTimeTriggertime of the trigger for the RO signal
static const Int_tfkTimeBinsnumber of sampling bins

Class Charts

Inheritance Chart:
TObject
AliPHOSPulseGenerator

Function documentation

AliPHOSPulseGenerator(Double_t a = 0, Double_t t0 = 0)
 Contruct a pulsegenrator object and initializes all necessary parameters
 @param a digit amplitude in GeV
 @param t0 time delay in nanoseconds of signal relative the first sample.
 This value should be between 0 and Ts, where Ts is the sample interval
~AliPHOSPulseGenerator()
 Destructor: delete arrays of samples
void Reset()
 Reset all sample amplitudes to 0
void AddBaseline(Double_t baselineLevel)
 Adds a baseline offset to the signal
 @param baselineLevel The basline level to add
void AddNoise(Double_t sigma)
 Adds Gaussian uncorrelated to the sample array
 @param sigma the noise amplitude in entities of ADC levels
void AddNoise(Double_t* sigma, Double_t cutoff)
Adds correlated Gaussian noise with cutof frequency "cutoff"
 @param sigma noise amplitude in entities of ADC levels
 @param -30DB cutoff frequency of the noise in entities of sampling frequency
void AddPretriggerSamples(Int_t nPresamples)
 Adds pretrigger samples to the sample arrays and replace them
 with concatinated and truncated arrays
void Digitize()
 Emulates ADC: rounds up to nearest integer value all amplitudes
Double_t RawResponseFunction(Double_t* x, Double_t* par)
 Shape of the electronics raw reponse:
 It is a semi-gaussian, 2nd order Gamma function of the general form
 v(t) = A *(t/tp)**n * exp(-n * t/tp-n) with
 tp : peaking time  fgTimePeak
 n  : order of the function
Bool_t MakeSamples()
 for a start time fTZero and an amplitude fAmplitude given by digit,
 calculates the raw sampled response AliPHOSPulseGenerator::RawResponseFunction
void GetSamples(Int_t* adcHG, Int_t* adcLG) const
 Return integer sample arrays adcHG and adcLG
void Print(Option_t* ) const
 Prints sampled amplitudes to stdout
void Draw(Option_t* opt = "all")
 Draw graphs with high and low gain samples
 Option_t* opt="all": draw both HG and LG in one canvas
               "HG" : draw HG only
               "LG" : draw LG only
AliPHOSPulseGenerator(Double_t a = 0, Double_t t0 = 0)
Bool_t GetDigitize()
{return fDigitize;}
void SetDigitise(Bool_t flag)
{fDigitize = flag;}
void SetAmplitude(Double_t a)
{fAmplitude = a ; Reset();}
void SetTZero(Double_t t0)
{fTZero = t0 ; Reset();}
void SetHG2LGRatio(Double_t r = 16.)
{fHG2LGratio = r ;}
void SetTimeStep(Double_t step = 100.e-9)
{fgTimeTrigger=step ;}
Int_t GetRawFormatOrder() const
 Raw Read Out
{ return fgOrder ; }
Int_t GetRawFormatTimeBins()
{ return fkTimeBins ; }
Double_t GetRawFormatTimeMax()
Double_t GetRawFormatTimePeak() const
{ return fgTimePeak ; }
Double_t GetRawFormatTimeTrigger() const
{ return fgTimeTrigger ; }