ATLAS Offline Software
Public Types | Public Member Functions | Protected Member Functions | Protected Attributes | Private Member Functions | Static Private Member Functions | Private Attributes | List of all members
CaloCondBlobDat< T > Class Template Reference

Generic template class for storing a number of "T"s for each channel/gain. More...

#include <CaloCondBlobDat.h>

Inheritance diagram for CaloCondBlobDat< T >:
Collaboration diagram for CaloCondBlobDat< T >:

Public Types

typedef std::vector< std::vector< T > > DefType
 Object to hold default data used for initialization. More...
 

Public Member Functions

virtual ~CaloCondBlobDat ()
 Dtor. More...
 
getData (const unsigned int channel, const unsigned int adc, const unsigned int idx) const
 Returns a single T belonging to a channel/gain. More...
 
getData (const unsigned int channel) const
 Returns a single T belonging to a channel/gain. More...
 
void init (const DefType &def, uint32_t nChans, uint16_t objVers, const std::string &author="", const std::string &comment="", uint64_t timeStamp=0)
 Initializing function. More...
 
void setData (unsigned int channel, unsigned int adc, unsigned int idx, T data)
 Sets a single T belonging to a channel/gain. More...
 
void setData (unsigned int channel, unsigned int adc, const std::vector< T > &data)
 Sets a number of Ts stored in the input vector. More...
 
virtual void dump () const
 Prints out the content of the blob to std::out. More...
 
virtual void dump (std::ostream &stm) const
 Prints out the content of the blob. More...
 
virtual uint16_t getType () const
 Returns CaloCondDrawer::BASE. More...
 
long getBlobSize () const
 Returns the BLOB size. More...
 
uint16_t getObjType () const
 Returns the BLOB object type. More...
 
uint16_t getObjVersion () const
 Returns the BLOB object version. More...
 
uint32_t getObjSizeUint32 () const
 Returns the size of a data object in units of uint32_t. More...
 
uint32_t getObjSizeByte () const
 Returns the size of a data object in units of bytes. More...
 
uint32_t getNObjs () const
 Returns the number of data objects stored int the BLOB. More...
 
uint32_t getNChans () const
 Returns the number of channels stored in the BLOB. More...
 
uint32_t getNGains () const
 Returns the number of gains stored for each channel. More...
 
uint32_t getCommentSizeUint32 () const
 Returns the space occupied by the comment fields in units of uint32_t. More...
 
uint32_t getCommentSizeChar () const
 Returns the space occupied by the comment fields in units of chars. More...
 
unsigned int getHdrSize () const
 Returns the size of the header in units of uint32_t. More...
 
std::string getAuthor () const
 Returns the comment author. More...
 
std::string getComment () const
 Returns the actual comment. More...
 
uint64_t getTimeStamp () const
 Returns the unix timestamp of the comment (seconds since 1.1.1970) More...
 
std::string getDate () const
 Returns the date of the comment as string (derived from timestamp) More...
 
std::string getFullComment () const
 Returns a formated string build from all comment fields. More...
 
const void * getAddress (unsigned int iEle) const
 Returns start address of iEle-th basic unit. More...
 
void * getAddress (unsigned int iEle)
 

Protected Member Functions

 CaloCondBlobDat (const coral::Blob &blob)
 Ctor. More...
 
 CaloCondBlobDat (coral::Blob &blob)
 Ctor. More...
 
const T * getAddress (const unsigned int channel, const unsigned int adc) const
 Returns a pointer to the first value for the specified channel/gain. More...
 
T * getAddress (const unsigned int channel, const unsigned int adc)
 
uint32_t createBlob (uint16_t objType, uint16_t objVersion, uint32_t objSizeUint32, uint32_t nObjs, uint32_t nChans, uint16_t nGains, const std::string &author="", const std::string &comment="", uint64_t timeStamp=0)
 (re-)creation of the referenced BLOB object. More...
 
void dumpHeader (std::ostream &stm) const
 Prints the BLOB header summary information. More...
 

Protected Attributes

const void * m_pDataStart
 

Private Member Functions

const uint32_t * getBlobStart () const
 Returns the BLOB start address as uint32_t pointer. More...
 
uint32_t * getBlobStart ()
 Returns the BLOB start address as uint32_t pointer. More...
 

Static Private Member Functions

static uint32_t packGainAndNchans (const uint32_t gain, const uint32_t nChans)
 
static uint32_t unpacknGains (const uint32_t gainAndnChans)
 
static uint32_t unpacknChans (const uint32_t gainAndnChans)
 

Private Attributes

coral::Blob * m_blob_nc
 Non-const reference to the BLOB. More...
 
const coral::Blob * m_blob
 Const reference to the BLOB (always there) More...
 
bool m_isBlobOwner
 Do I own the BLOB? More...
 
unsigned m_sizeOfObj
 Chache of some frequently-used numbers. More...
 
unsigned m_nChans
 
unsigned m_nGains
 

Detailed Description

template<class T>
class CaloCondBlobDat< T >

Generic template class for storing a number of "T"s for each channel/gain.

Author
Nils Gollub nils..nosp@m.goll.nosp@m.ub@ce.nosp@m.rn.c.nosp@m.h

This class implements the infrastructure to store a (variable) number of Ts for each channel/gain. Only types that are a multiple of uint32_t can be stored, i.e. float, uint32_t, uint64_t, etc... The number of Ts to store is encoded in the objSize header variable. The object version header variable has no meaning for this class (since schema evolution does not make sense here) and is always set to 0.

Definition at line 30 of file CaloCondBlobDat.h.

Member Typedef Documentation

◆ DefType

template<class T >
typedef std::vector<std::vector<T> > CaloCondBlobDat< T >::DefType

Object to hold default data used for initialization.

The length of the outer and inner vector determines respectively the number of gains and values per gain to be stored. The indexing is thus DefType[iGain][iValue].

Definition at line 37 of file CaloCondBlobDat.h.

Constructor & Destructor Documentation

◆ ~CaloCondBlobDat()

template<class T >
virtual CaloCondBlobDat< T >::~CaloCondBlobDat ( )
inlinevirtual

Dtor.

Definition at line 40 of file CaloCondBlobDat.h.

40 {}

◆ CaloCondBlobDat() [1/2]

template<class T >
CaloCondBlobDat< T >::CaloCondBlobDat ( const coral::Blob &  blob)
inlineprotected

Ctor.

Definition at line 96 of file CaloCondBlobDat.h.

◆ CaloCondBlobDat() [2/2]

template<class T >
CaloCondBlobDat< T >::CaloCondBlobDat ( coral::Blob &  blob)
inlineprotected

Ctor.

Definition at line 98 of file CaloCondBlobDat.h.

Member Function Documentation

◆ createBlob()

uint32_t CaloCondBlobBase::createBlob ( uint16_t  objType,
uint16_t  objVersion,
uint32_t  objSizeUint32,
uint32_t  nObjs,
uint32_t  nChans,
uint16_t  nGains,
const std::string &  author = "",
const std::string &  comment = "",
uint64_t  timeStamp = 0 
)
protectedinherited

(re-)creation of the referenced BLOB object.

Parameters
objTypeObject type
objVersionObject version
objSizeUint32Size of a data object (in uint32_t)
nObjsTotal number of data objects
nChansnumber of stored channels
nGainsnumber of stored gains
authorcomment author
commentactual comment
timeStampunix time stamp (if 0, current time is used)

Definition at line 84 of file CaloCondBlobBase.cxx.

93 {
94 
95  //=== blob data length including header in bytes
96  const uint32_t dataSizeByte = (getHdrSize()+objSizeUint32*nObjs) * sizeof(uint32_t);
97 
98  //=== calculate comment length, including two ASCII NULLs to end text fields
99  uint32_t commentSizeChar(0);
100  if(!author.empty() || !comment.empty() || timeStamp){
101  commentSizeChar += author.size()+comment.size()+sizeof(uint64_t) + 2;
102  //=== force comment length to end on 4 byte boundary
103  commentSizeChar += (commentSizeChar % sizeof(uint32_t)) ?
104  (sizeof(uint32_t)-(commentSizeChar % sizeof(uint32_t))) : 0;
105  }
106 
107  //=== create blob
108  const uint32_t blobSizeInBytes = dataSizeByte+commentSizeChar;
109  m_blob_nc->resize(blobSizeInBytes);
110 
111  //=== fill header
112  reinterpret_cast<uint16_t*>(getBlobStart())[0] = objType;
113  reinterpret_cast<uint16_t*>(getBlobStart())[1] = objVersion;
114  getBlobStart()[1] = objSizeUint32;
115  m_sizeOfObj=objSizeUint32;
116  getBlobStart()[2] = nObjs;
117  getBlobStart()[3] = packGainAndNchans(nGains,nChans);
118  m_nChans=nChans;
119  m_nGains=nGains;
120  getBlobStart()[4] = commentSizeChar/sizeof(uint32_t);
121 
122  //==== fill comment fields
123  if(commentSizeChar){
124  if(!timeStamp) timeStamp = ::time(nullptr);
125  uint8_t* pChar = reinterpret_cast<uint8_t*> (getBlobStart()+dataSizeByte/sizeof(uint32_t));
127  std::string::const_iterator iStr = author.begin();
128  for(; iStr!=author.end(); ++iStr){ *pChar = *iStr; ++pChar; }
129  *pChar = 0;
130  for(iStr=comment.begin(); iStr!=comment.end(); ++iStr){ *(++pChar) = *iStr; }
131  *(++pChar) = 0;
132  }
133 
134  m_pDataStart=static_cast<const void*>(getBlobStart()+getHdrSize());
135  return (blobSizeInBytes/sizeof(uint32_t));
136 }

◆ dump() [1/2]

template<class T >
virtual void CaloCondBlobDat< T >::dump ( ) const
inlinevirtual

Prints out the content of the blob to std::out.

Reimplemented from CaloCondBlobBase.

Definition at line 89 of file CaloCondBlobDat.h.

89 { dump(std::cout); }

◆ dump() [2/2]

template<class T >
void CaloCondBlobDat< T >::dump ( std::ostream &  stm) const
virtual

Prints out the content of the blob.

Parameters
stmThe stream to print to

Reimplemented from CaloCondBlobBase.

Definition at line 203 of file CaloCondBlobDat.h.

204 {
206  for(unsigned int channel=0; channel<getNChans(); ++channel){
207  for(unsigned int adc=0; adc<getNGains(); ++adc){
208  stm << channel<<"/"<<adc<<":\t";
209  for(unsigned int idx=0; idx<getObjSizeUint32(); ++idx){
210  stm << getData(channel,adc,idx) << "\t";
211  }
212  stm << std::endl;
213  }
214  }
215 }

◆ dumpHeader()

void CaloCondBlobBase::dumpHeader ( std::ostream &  stm) const
protectedinherited

Prints the BLOB header summary information.

Parameters
stmoutput stream to use

Definition at line 229 of file CaloCondBlobBase.cxx.

230 {
231  stm << "This is a " << CaloCondType::getClassName(getObjType()) << std::endl;
232  stm << "ObjType : " << getObjType() << std::endl;
233  stm << "ObjVersion : " << getObjVersion() << std::endl;
234  stm << "ObjSize [bytes]: " << getObjSizeByte() << std::endl;
235  stm << "NObjs : " << getNObjs() << std::endl;
236  stm << "NChannels : " << getNChans() << std::endl;
237  stm << "NGains : " << getNGains() << std::endl;
238  if(!getCommentSizeUint32()){
239  stm << "=== No comment available ===" << std::endl;
240  }
241  else{
242  stm << "Author : " << getAuthor() << std::endl;
243  stm << "Date : " << getDate() << " ("<< getTimeStamp() << ")" << std::endl;
244  stm << "Comment: : " << getComment() << std::endl;
245  }
246 }

◆ getAddress() [1/4]

template<class T >
T * CaloCondBlobDat< T >::getAddress ( const unsigned int  channel,
const unsigned int  adc 
)
protected

Definition at line 186 of file CaloCondBlobDat.h.

187 {
188  //=== check for out of bounds
189  if(channel >= getNChans()){
190  throw CaloCond::IndexOutOfRange("CaloCondBlobDat::getAddress(channel)",channel,getNChans());
191  }
192  if(adc>=getNGains()){
193  throw CaloCond::IndexOutOfRange("CaloCondBlobDat::getAddress(gain)",adc,getNGains());
194  }
195 
196  const unsigned int idx = channel*getNGains() + adc;
197  return static_cast<T*>(CaloCondBlobBase::getAddress(idx));
198 }

◆ getAddress() [2/4]

template<class T >
const T * CaloCondBlobDat< T >::getAddress ( const unsigned int  channel,
const unsigned int  adc 
) const
protected

Returns a pointer to the first value for the specified channel/gain.

Parameters
channelThe channel number; if >= getNChans() it is reset to 0 without warning (default policy)
adcThe gain index; if >= getNGains() it is reset to 0 without warning (default policy)

Definition at line 169 of file CaloCondBlobDat.h.

170 {
171  //=== check for out of bounds
172  if(channel >= getNChans()){
173  throw CaloCond::IndexOutOfRange("CaloCondBlobDat::getAddress(channel)",channel,getNChans());
174  }
175  if(adc>=getNGains()){
176  throw CaloCond::IndexOutOfRange("CaloCondBlobDat::getAddress(gain)",adc,getNGains());
177  }
178 
179  const unsigned int idx = channel*getNGains() + adc;
180  return static_cast<const T*>(CaloCondBlobBase::getAddress(idx));
181 }

◆ getAddress() [3/4]

void * CaloCondBlobBase::getAddress ( unsigned int  iEle)
inlineinherited

Definition at line 272 of file CaloCondBlobBase.h.

273 {
274  if(iEle>=getNObjs()){
275  throw CaloCond::IndexOutOfRange("CaloCondBlobBase::getAddress", iEle, getNObjs());
276  }
277  return static_cast<void*>
278  ( getBlobStart() + getHdrSize() + getObjSizeUint32()*iEle );
279 }

◆ getAddress() [4/4]

const void * CaloCondBlobBase::getAddress ( unsigned int  iEle) const
inlineinherited

Returns start address of iEle-th basic unit.

Parameters
iElesequential basic unit number

Definition at line 260 of file CaloCondBlobBase.h.

261 {
262  if(iEle>=getNObjs()){
263  throw CaloCond::IndexOutOfRange("CaloCondBlobBase::getAddress", iEle, getNObjs());
264  }
265  return static_cast<const void*>
266  ( getBlobStart() + getHdrSize() + getObjSizeUint32()*iEle );
267 }

◆ getAuthor()

std::string CaloCondBlobBase::getAuthor ( ) const
inherited

Returns the comment author.

Definition at line 176 of file CaloCondBlobBase.cxx.

177 {
178  if(!getCommentSizeUint32()) return std::string("");
179  const char* iBeg =
180  reinterpret_cast<const char*>(getBlobStart()+getHdrSize() +
182  sizeof(uint64_t)/sizeof(uint32_t));
183  return std::string(iBeg);
184 }

◆ getBlobSize()

long CaloCondBlobBase::getBlobSize ( ) const
inlineinherited

Returns the BLOB size.

Definition at line 66 of file CaloCondBlobBase.h.

66 {return m_blob->size(); }

◆ getBlobStart() [1/2]

uint32_t * CaloCondBlobBase::getBlobStart ( )
inlineprivateinherited

Returns the BLOB start address as uint32_t pointer.

Definition at line 186 of file CaloCondBlobBase.h.

187 {
188  return static_cast<uint32_t*>(m_blob_nc->startingAddress());
189 }

◆ getBlobStart() [2/2]

const uint32_t * CaloCondBlobBase::getBlobStart ( ) const
inlineprivateinherited

Returns the BLOB start address as uint32_t pointer.

Definition at line 178 of file CaloCondBlobBase.h.

179 {
180  return static_cast<const uint32_t*>(m_blob->startingAddress());
181 }

◆ getComment()

std::string CaloCondBlobBase::getComment ( ) const
inherited

Returns the actual comment.

Definition at line 190 of file CaloCondBlobBase.cxx.

191 {
192  if(!getCommentSizeUint32()) return std::string("");
193  const char* iBeg =
194  reinterpret_cast<const char*>(getBlobStart()+getHdrSize() +
196  sizeof(uint64_t)/sizeof(uint32_t));
197  const char* iEnd = iBeg + getCommentSizeChar();
198  iBeg = std::find(iBeg,iEnd,0);
199  return std::string(++iBeg);
200 }

◆ getCommentSizeChar()

uint32_t CaloCondBlobBase::getCommentSizeChar ( ) const
inlineinherited

Returns the space occupied by the comment fields in units of chars.

Definition at line 84 of file CaloCondBlobBase.h.

84 {return getCommentSizeUint32()*sizeof(uint32_t);}

◆ getCommentSizeUint32()

uint32_t CaloCondBlobBase::getCommentSizeUint32 ( ) const
inlineinherited

Returns the space occupied by the comment fields in units of uint32_t.

Definition at line 250 of file CaloCondBlobBase.h.

251 {
252  if(uint64_t(m_blob->size())<getHdrSize()*sizeof(uint32_t))
253  throw CaloCond::InvalidBlob("CaloCondBlobBase::getCommentSizeUint32");
254  return static_cast<const uint32_t*>(m_blob->startingAddress())[4];
255 }

◆ getData() [1/2]

template<class T >
T CaloCondBlobDat< T >::getData ( const unsigned int  channel) const

Returns a single T belonging to a channel/gain.

Parameters
channelThe channel number

Definition at line 142 of file CaloCondBlobDat.h.

142  {
143 return (static_cast<const T*>(m_pDataStart))[channel];
144 }

◆ getData() [2/2]

template<class T >
T CaloCondBlobDat< T >::getData ( const unsigned int  channel,
const unsigned int  adc,
const unsigned int  idx 
) const

Returns a single T belonging to a channel/gain.

Parameters
channelThe channel number
adcThe gain index
idxThe index of the requested value

Definition at line 134 of file CaloCondBlobDat.h.

135 {
136  if(idx<getObjSizeUint32()){return getAddress(channel,adc)[idx];}
137  else{throw CaloCond::IndexOutOfRange("CaloCondBlobDat::getData",idx,getObjVersion());}
138 }

◆ getDate()

std::string CaloCondBlobBase::getDate ( ) const
inherited

Returns the date of the comment as string (derived from timestamp)

Definition at line 205 of file CaloCondBlobBase.cxx.

206 {
207  if(!getCommentSizeUint32()) return std::string("");
208  ::time_t timeStamp = getTimeStamp();
209  char buf[26];
210  char* iBeg = ::ctime_r(&timeStamp, buf);
211  char* iEnd = iBeg;
212  while(*iEnd!='\n'){++iEnd;}
213  return std::string(iBeg,iEnd-iBeg);
214 }

◆ getFullComment()

std::string CaloCondBlobBase::getFullComment ( ) const
inherited

Returns a formated string build from all comment fields.

Definition at line 219 of file CaloCondBlobBase.cxx.

220 {
221  if(!getCommentSizeUint32()) return std::string("");
222  return getAuthor()+" ("+getDate()+"): "+getComment();
223 }

◆ getHdrSize()

unsigned int CaloCondBlobBase::getHdrSize ( ) const
inlineinherited

Returns the size of the header in units of uint32_t.

Definition at line 86 of file CaloCondBlobBase.h.

86 {return 5;}

◆ getNChans()

uint32_t CaloCondBlobBase::getNChans ( ) const
inlineinherited

Returns the number of channels stored in the BLOB.

Definition at line 232 of file CaloCondBlobBase.h.

233 {
234  return m_nChans;
235 }

◆ getNGains()

uint32_t CaloCondBlobBase::getNGains ( ) const
inlineinherited

Returns the number of gains stored for each channel.

Definition at line 240 of file CaloCondBlobBase.h.

241 {
242  return m_nGains;
243 
244 
245 }

◆ getNObjs()

uint32_t CaloCondBlobBase::getNObjs ( ) const
inlineinherited

Returns the number of data objects stored int the BLOB.

Definition at line 222 of file CaloCondBlobBase.h.

223 {
224  if(uint64_t(m_blob->size())<getHdrSize()*sizeof(uint32_t))
225  throw CaloCond::InvalidBlob("CaloCondBlobBase::getNObjs");
226  return static_cast<const uint32_t*>(m_blob->startingAddress())[2];
227 }

◆ getObjSizeByte()

uint32_t CaloCondBlobBase::getObjSizeByte ( ) const
inlineinherited

Returns the size of a data object in units of bytes.

Definition at line 74 of file CaloCondBlobBase.h.

74 {return getObjSizeUint32()*sizeof(uint32_t);}

◆ getObjSizeUint32()

uint32_t CaloCondBlobBase::getObjSizeUint32 ( ) const
inlineinherited

Returns the size of a data object in units of uint32_t.

Definition at line 214 of file CaloCondBlobBase.h.

215 {
216  return m_sizeOfObj;
217 }

◆ getObjType()

uint16_t CaloCondBlobBase::getObjType ( ) const
inlineinherited

Returns the BLOB object type.

Definition at line 194 of file CaloCondBlobBase.h.

195 {
196  if(uint64_t(m_blob->size())<getHdrSize()*sizeof(uint32_t))
197  throw CaloCond::InvalidBlob("CaloCondBlobBase::getObjType");
198  return static_cast<const uint16_t*>(m_blob->startingAddress())[0];
199 }

◆ getObjVersion()

uint16_t CaloCondBlobBase::getObjVersion ( ) const
inlineinherited

Returns the BLOB object version.

Definition at line 204 of file CaloCondBlobBase.h.

205 {
206  if(uint64_t(m_blob->size())<getHdrSize()*sizeof(uint32_t))
207  throw CaloCond::InvalidBlob("CaloCondBlobBase::getObjVersion");
208  return static_cast<const uint16_t*>(m_blob->startingAddress())[1];
209 }

◆ getTimeStamp()

uint64_t CaloCondBlobBase::getTimeStamp ( ) const
inlineinherited

Returns the unix timestamp of the comment (seconds since 1.1.1970)

Definition at line 284 of file CaloCondBlobBase.h.

285 {
286  if(!getCommentSizeUint32()) return 0;
287  auto p = reinterpret_cast<const uint8_t*>(getBlobStart()+getHdrSize() +
289  return CxxUtils::get_unaligned64 (p);
290 }

◆ getType()

virtual uint16_t CaloCondBlobBase::getType ( ) const
inlinevirtualinherited

Returns CaloCondDrawer::BASE.

Reimplemented in CaloCondBlobFlt.

Definition at line 53 of file CaloCondBlobBase.h.

53 {return CaloCondType::BASE;}

◆ init()

template<class T >
void CaloCondBlobDat< T >::init ( const DefType def,
uint32_t  nChans,
uint16_t  objVers,
const std::string &  author = "",
const std::string &  comment = "",
uint64_t  timeStamp = 0 
)

Initializing function.

Parameters
defA reference to a DefType object, specifying the inital layout and values
nChansNumber of channels to create
objTypeType of the object
objVersVersion of the object
authorString containing the author user id
commentString containing the actual comment
timeStampUnix time stamp (if 0, current time is used)

Definition at line 111 of file CaloCondBlobDat.h.

117 {
118  uint32_t objSize = def.begin()->size() * sizeof(T)/sizeof(uint32_t);
119  uint16_t nGains = def.size();
120  uint32_t nObjs = nChans*nGains;
121  createBlob(getType(), objVers, objSize, nObjs, nChans, nGains, author, comment, timeStamp);
122 
123  //=== fill the blob with default
124  for(unsigned int channel=0; channel<nChans; ++channel){
125  for(unsigned int adc=0; adc<nGains; ++adc){
126  setData(channel, adc, def[adc]);
127  }
128  }
129 }

◆ packGainAndNchans()

uint32_t CaloCondBlobBase::packGainAndNchans ( const uint32_t  gain,
const uint32_t  nChans 
)
staticprivateinherited

Definition at line 139 of file CaloCondBlobBase.cxx.

139  {
140 
141  if (gain>0x7F)
142  throw CaloCond::InvalidBlob("CaloCondBlobBase::packGainAndNchans: Gain too large");
143 
144  if (nChans>0xFFFFFF)
145  throw CaloCond::InvalidBlob("CaloCondBlobBase::packGainAndNchans: Number of channels too large");
146 
147  return 0x80000000 | (gain << 24) | nChans;
148 }

◆ setData() [1/2]

template<class T >
void CaloCondBlobDat< T >::setData ( unsigned int  channel,
unsigned int  adc,
const std::vector< T > &  data 
)

Sets a number of Ts stored in the input vector.

Parameters
channelThe channel number
adcThe gain index
dataA vector containing the values to be set

Definition at line 159 of file CaloCondBlobDat.h.

160 {
161  for(typename std::vector<T>::const_iterator i=data.begin(); i!=data.end(); ++i){
162  setData(channel,adc,i-data.begin(),*i);
163  }
164 }

◆ setData() [2/2]

template<class T >
void CaloCondBlobDat< T >::setData ( unsigned int  channel,
unsigned int  adc,
unsigned int  idx,
data 
)

Sets a single T belonging to a channel/gain.

Parameters
channelThe channel number
adcThe gain index
idxThe index of the value to set
dataThe data value to set

Definition at line 150 of file CaloCondBlobDat.h.

151 {
153  else{throw CaloCond::IndexOutOfRange("CaloCondBlobDat::setData",idx,getObjVersion());}
154 }

◆ unpacknChans()

uint32_t CaloCondBlobBase::unpacknChans ( const uint32_t  gainAndnChans)
staticprivateinherited

Definition at line 160 of file CaloCondBlobBase.cxx.

160  {
161  if (gainAndnChans & 0x80000000) { //new version: 24 bytes for the nChans, 7 for the gain
162  //std::cout << "CaloCondBlobBase: Reading nChans from new version" << std::endl;
163  return gainAndnChans & 0xFFFFFF;
164  }
165  else //Old version: 16 bits for nChans
166  //std::cout << "CaloCondBlobBase: Reading nChangs from old version" << std::endl;
167  return gainAndnChans & 0xFFFF;
168 }

◆ unpacknGains()

uint32_t CaloCondBlobBase::unpacknGains ( const uint32_t  gainAndnChans)
staticprivateinherited

Definition at line 150 of file CaloCondBlobBase.cxx.

150  {
151  if (gainAndnChans & 0x80000000) { //new version: 24 bytes for the nChans, 7 for the gain
152  //std::cout << "CaloCondBlobBase: Reading gain from new version" << std::endl;
153  return (gainAndnChans>>24) & 0x7F;
154  }
155  else //Old version: 16 bigs for gain
156  //std::cout << "CaloCondBlobBase: Reading gain from old version" << std::endl;
157  return (gainAndnChans>>16) & 0xFFFF;
158 }

Member Data Documentation

◆ m_blob

const coral::Blob* CaloCondBlobBase::m_blob
privateinherited

Const reference to the BLOB (always there)

Definition at line 161 of file CaloCondBlobBase.h.

◆ m_blob_nc

coral::Blob* CaloCondBlobBase::m_blob_nc
privateinherited

Non-const reference to the BLOB.

(Only present if we were created with a non-const blob.)

Definition at line 158 of file CaloCondBlobBase.h.

◆ m_isBlobOwner

bool CaloCondBlobBase::m_isBlobOwner
privateinherited

Do I own the BLOB?

Definition at line 164 of file CaloCondBlobBase.h.

◆ m_nChans

unsigned CaloCondBlobBase::m_nChans
privateinherited

Definition at line 168 of file CaloCondBlobBase.h.

◆ m_nGains

unsigned CaloCondBlobBase::m_nGains
privateinherited

Definition at line 169 of file CaloCondBlobBase.h.

◆ m_pDataStart

const void* CaloCondBlobBase::m_pDataStart
protectedinherited

Definition at line 171 of file CaloCondBlobBase.h.

◆ m_sizeOfObj

unsigned CaloCondBlobBase::m_sizeOfObj
privateinherited

Chache of some frequently-used numbers.

Definition at line 167 of file CaloCondBlobBase.h.


The documentation for this class was generated from the following file:
CaloCondBlobBase::getCommentSizeUint32
uint32_t getCommentSizeUint32() const
Returns the space occupied by the comment fields in units of uint32_t.
Definition: CaloCondBlobBase.h:250
CaloCondBlobDat::setData
void setData(unsigned int channel, unsigned int adc, unsigned int idx, T data)
Sets a single T belonging to a channel/gain.
Definition: CaloCondBlobDat.h:150
CaloCondBlobBase::packGainAndNchans
static uint32_t packGainAndNchans(const uint32_t gain, const uint32_t nChans)
Definition: CaloCondBlobBase.cxx:139
data
char data[hepevt_bytes_allocation_ATLAS]
Definition: HepEvt.cxx:11
CaloCondBlobBase::getObjSizeUint32
uint32_t getObjSizeUint32() const
Returns the size of a data object in units of uint32_t.
Definition: CaloCondBlobBase.h:214
CaloCondBlobDat::getData
T getData(const unsigned int channel, const unsigned int adc, const unsigned int idx) const
Returns a single T belonging to a channel/gain.
Definition: CaloCondBlobDat.h:134
CaloCondBlobBase::getAuthor
std::string getAuthor() const
Returns the comment author.
Definition: CaloCondBlobBase.cxx:176
plotting.yearwise_efficiency.channel
channel
Definition: yearwise_efficiency.py:24
xAOD::uint8_t
uint8_t
Definition: Muon_v1.cxx:558
find
std::string find(const std::string &s)
return a remapped string
Definition: hcg.cxx:135
CxxUtils::set_unaligned< uint64_t >
void set_unaligned< uint64_t >(uint8_t *ATH_RESTRICT &p, uint64_t val)
Definition: set_unaligned.h:181
xAOD::uint32_t
setEventNumber uint32_t
Definition: EventInfo_v1.cxx:127
CaloCondBlobBase::m_nGains
unsigned m_nGains
Definition: CaloCondBlobBase.h:169
CaloCondBlobBase::m_blob_nc
coral::Blob * m_blob_nc
Non-const reference to the BLOB.
Definition: CaloCondBlobBase.h:158
CaloCondBlobBase::getAddress
const void * getAddress(unsigned int iEle) const
Returns start address of iEle-th basic unit.
Definition: CaloCondBlobBase.h:260
CaloCondBlobDat::getAddress
const T * getAddress(const unsigned int channel, const unsigned int adc) const
Returns a pointer to the first value for the specified channel/gain.
Definition: CaloCondBlobDat.h:169
CaloCondBlobAlgs_fillNoiseFromASCII.gain
gain
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:109
CxxUtils::get_unaligned64
uint64_t get_unaligned64(const uint8_t *ATH_RESTRICT &p)
Read an 8-byte little-endian value from a possibly unaligned pointer.
Definition: get_unaligned.h:103
CaloCondBlobBase::m_pDataStart
const void * m_pDataStart
Definition: CaloCondBlobBase.h:171
CaloCondBlobBase::getType
virtual uint16_t getType() const
Returns CaloCondDrawer::BASE.
Definition: CaloCondBlobBase.h:53
CaloCondBlobBase::createBlob
uint32_t createBlob(uint16_t objType, uint16_t objVersion, uint32_t objSizeUint32, uint32_t nObjs, uint32_t nChans, uint16_t nGains, const std::string &author="", const std::string &comment="", uint64_t timeStamp=0)
(re-)creation of the referenced BLOB object.
Definition: CaloCondBlobBase.cxx:84
CaloCondBlobBase::getObjType
uint16_t getObjType() const
Returns the BLOB object type.
Definition: CaloCondBlobBase.h:194
CaloCondBlobBase::getDate
std::string getDate() const
Returns the date of the comment as string (derived from timestamp)
Definition: CaloCondBlobBase.cxx:205
TileCalibBlobPython_writeOfc.objVersion
objVersion
Definition: TileCalibBlobPython_writeOfc.py:71
CaloCondBlobBase::CaloCondBlobBase
CaloCondBlobBase(const CaloCondBlobBase &other)
Copy Ctor.
Definition: CaloCondBlobBase.cxx:51
CaloCondBlobBase::getHdrSize
unsigned int getHdrSize() const
Returns the size of the header in units of uint32_t.
Definition: CaloCondBlobBase.h:86
CaloCondBlobBase::getCommentSizeChar
uint32_t getCommentSizeChar() const
Returns the space occupied by the comment fields in units of chars.
Definition: CaloCondBlobBase.h:84
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:209
CaloCondBlobBase::getBlobStart
const uint32_t * getBlobStart() const
Returns the BLOB start address as uint32_t pointer.
Definition: CaloCondBlobBase.h:178
xAOD::uint16_t
setWord1 uint16_t
Definition: eFexEMRoI_v1.cxx:93
lumiFormat.i
int i
Definition: lumiFormat.py:85
python.DecayParser.buf
buf
print ("=> [%s]"cmd)
Definition: DecayParser.py:26
CaloCondBlobBase::getObjVersion
uint16_t getObjVersion() const
Returns the BLOB object version.
Definition: CaloCondBlobBase.h:204
CaloCondType::BASE
@ BASE
Enum for CaloCondBlobBase class.
Definition: CaloCondType.h:28
CaloCondBlobBase::getComment
std::string getComment() const
Returns the actual comment.
Definition: CaloCondBlobBase.cxx:190
xAOD::uint64_t
uint64_t
Definition: EventInfo_v1.cxx:123
CaloCondBlobBase::m_nChans
unsigned m_nChans
Definition: CaloCondBlobBase.h:168
CaloCondBlobBase::dumpHeader
void dumpHeader(std::ostream &stm) const
Prints the BLOB header summary information.
Definition: CaloCondBlobBase.cxx:229
CaloCond::InvalidBlob
Thrown if coral::Blob does not conform with expected structure.
Definition: Calorimeter/CaloCondBlobObjs/CaloCondBlobObjs/Exception.h:50
CaloCondBlobAlgs_fillNoiseFromASCII.comment
string comment
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:26
CaloCond::IndexOutOfRange
Thrown if an index is out of range.
Definition: Calorimeter/CaloCondBlobObjs/CaloCondBlobObjs/Exception.h:124
CaloCondType::getClassName
static std::string getClassName(CaloCondType::TYPE type)
Returns the class name.
Definition: CaloCondType.cxx:10
CaloCondBlobBase::getNObjs
uint32_t getNObjs() const
Returns the number of data objects stored int the BLOB.
Definition: CaloCondBlobBase.h:222
CaloCondBlobBase::getNGains
uint32_t getNGains() const
Returns the number of gains stored for each channel.
Definition: CaloCondBlobBase.h:240
xAOD::timeStamp
setEventNumber timeStamp
Definition: EventInfo_v1.cxx:128
CaloCondBlobBase::m_blob
const coral::Blob * m_blob
Const reference to the BLOB (always there)
Definition: CaloCondBlobBase.h:161
CaloCondBlobBase::getObjSizeByte
uint32_t getObjSizeByte() const
Returns the size of a data object in units of bytes.
Definition: CaloCondBlobBase.h:74
CaloSwCorrections.time
def time(flags, cells_name, *args, **kw)
Definition: CaloSwCorrections.py:242
ReadFloatFromCool.adc
adc
Definition: ReadFloatFromCool.py:48
CaloCondBlobDat::dump
virtual void dump() const
Prints out the content of the blob to std::out.
Definition: CaloCondBlobDat.h:89
CaloCondBlobBase::m_sizeOfObj
unsigned m_sizeOfObj
Chache of some frequently-used numbers.
Definition: CaloCondBlobBase.h:167
CaloCondBlobAlgs_fillNoiseFromASCII.author
string author
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:25
LArNewCalib_DelayDump_OFC_Cali.idx
idx
Definition: LArNewCalib_DelayDump_OFC_Cali.py:69
CaloCondBlobBase::getTimeStamp
uint64_t getTimeStamp() const
Returns the unix timestamp of the comment (seconds since 1.1.1970)
Definition: CaloCondBlobBase.h:284
TSU::T
unsigned long long T
Definition: L1TopoDataTypes.h:35
CaloCondBlobAlgs_fillNoiseFromASCII.blob
blob
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:95
CaloCondBlobBase::getNChans
uint32_t getNChans() const
Returns the number of channels stored in the BLOB.
Definition: CaloCondBlobBase.h:232