ROOT logo
AliRoot » ITS » AliITSRawStreamSDDCompressed

class AliITSRawStreamSDDCompressed: public AliITSRawStream


Class to decode compressed SDD Raw Data format
The 32 bits for a data word are defined as follows:
31 control bit (0=data word, 1= control word)
30 -
29  |
28  |-> 4 bits to identify the Carlos (0-11) inside the DDL
27 -
26 detecor side (0= left, =right)
25 -
24  |
23  |
22  |
21  |-> 8 bits to identify the anode number (0-255)
20  |
19  |
18 -
17 -
16  |
15  |
14  |
13  |-> 8 bits to identify the time bin (0-255)
12  |
11  |
10 -
9 -
8  |
7  |
6  |
5  |
4  |-> 10 bit for the ADC counts
3  |
2  |
1  |
0 -

Plus 3 types of control words
identified by the the 4 most significant bits (31-28)
1) Jitter word     = 1000
2) JTAG answer     = 1100
3) End of module data (needed by the Cluster Finder)   = 1111

Origin: F.Prino, Torino, prino@to.infn.it


Function Members (Methods)

public:
AliITSRawStreamSDDCompressed(AliRawReader* rawReader)
AliITSRawStreamSDDCompressed(const AliITSRawStreamSDDCompressed& rs)
virtual~AliITSRawStreamSDDCompressed()
voidTObject::AbstractMethod(const char* method) const
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
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 Int_tGetAnode() const
virtual Int_tGetCarlosId() const
virtual Int_tGetChannel() const
Int_tAliITSRawStream::GetCoord1() const
Int_tAliITSRawStream::GetCoord2() const
virtual UInt_tGetDataWord() const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
virtual Int_tGetJitter() const
Int_tAliITSRawStream::GetModuleID() const
Int_tGetModuleNumber(UInt_t iDDL, UInt_t iModule) 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_tAliITSRawStream::GetPrevModuleID() const
Int_tAliITSRawStream::GetSignal() const
virtual Int_tGetTime() 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_tAliITSRawStream::IsCompletedDDL() const
virtual Bool_tAliITSRawStream::IsCompletedModule() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tAliITSRawStream::IsNewModule() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Bool_tNext()
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)
AliITSRawStreamSDDCompressed&operator=(const AliITSRawStreamSDDCompressed& rs)
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 = "")
virtual voidSetADCEncoded(Bool_t fl = kTRUE)
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidSetDDLModuleMap(AliITSDDLModuleMapSDD* ddlsdd)
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 voidSetZeroSuppLowThreshold(Int_t iMod, Int_t iSid, Int_t th)
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 Int_tDecompAmbra(Int_t value) const
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()

Data Members

public:
enum { kSDDModules
kSPDModules
kDDLsNumber
kModulesPerDDL
kCarlosWords
kFifoWords
};
enum ESDDRawStreamError { kDataError
kDataFormatErr
};
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
protected:
Bool_tfADCEncodedflag for data format
Int_tfCarlosIdcarlos ID
Int_tfChannelcurrent channel
Bool_tAliITSRawStream::fCompletedDDLset to kTRUE when all data from a DDL (SDD) are read
Bool_tAliITSRawStream::fCompletedModuleset to kTRUE when all data from a module (SDD) are read
Int_tAliITSRawStream::fCoord1current 1st coordinate
Int_tAliITSRawStream::fCoord2current 2nd coordinate
Int_tfDDLcurrent ddl number
AliITSDDLModuleMapSDD*fDDLModuleMapmapping DDL/module -> module number
UInt_tfDatadata read for file
Int_tfJitterjitter between L0 and pascal stop (x25ns)
Int_tfLowThresholdArray[260][2]array with low thresholds for all modules
Int_tAliITSRawStream::fModuleIDindex of current module
Int_tAliITSRawStream::fPrevModuleIDindex of previous module
AliRawReader*AliITSRawStream::fRawReaderobject for reading the raw data
Int_tAliITSRawStream::fSignalsignal in ADC counts

Class Charts

Inheritance Chart:
TObject
AliITSRawStream
AliITSRawStreamSDDCompressed

Function documentation

AliITSRawStreamSDDCompressed(AliRawReader* rawReader)
 create an object to read ITS SDD raw digits
AliITSRawStreamSDDCompressed(const AliITSRawStreamSDDCompressed& rs)
 copy constructor
AliITSRawStreamSDDCompressed& operator=(const AliITSRawStreamSDDCompressed& rs)
 assignment operator
~AliITSRawStreamSDDCompressed()
Int_t DecompAmbra(Int_t value) const
 AMBRA decompression (from 8 to 10 bit)
Bool_t Next()
 read the next raw digit
 returns kFALSE if there is no digit left
 returns kTRUE and fCompletedModule=kFALSE and fCompletedDDL=kFALSE when a digit is found
 returns kTRUE and fCompletedModule=kTRUE  and fCompletedDDL=kFALSE when a module is completed (=3x3FFFFFFF footer words)
 returns kTRUE and fCompletedModule=kFALSE and fCompletedDDL=kTRUE  when a DDL is completed (=jitter word)
Int_t GetAnode() const
{return fCoord1;}
Int_t GetTime() const
{return fCoord2;}
Int_t GetChannel() const
{return fChannel;}
Int_t GetJitter() const
{return fJitter;}
Int_t GetCarlosId() const
{return fCarlosId;}
UInt_t GetDataWord() const
{return fData;}
void SetADCEncoded(Bool_t fl = kTRUE)
void SetDDLModuleMap(AliITSDDLModuleMapSDD* ddlsdd)
void SetZeroSuppLowThreshold(Int_t iMod, Int_t iSid, Int_t th)
{fLowThresholdArray[iMod][iSid]=th;}
Int_t GetModuleNumber(UInt_t iDDL, UInt_t iModule) const