ATLAS Offline Software
Loading...
Searching...
No Matches
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.

Public Member Functions

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

Protected Member Functions

 CaloCondBlobDat (const coral::Blob &blob)
 Ctor.
 CaloCondBlobDat (coral::Blob &blob)
 Ctor.
const T * getAddress (const unsigned int channel, const unsigned int adc) const
 Returns a pointer to the first value for the specified channel/gain.
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.
void dumpHeader (std::ostream &stm) const
 Prints the BLOB header summary information.

Protected Attributes

const void * m_pDataStart

Private Member Functions

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

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.
const coral::Blob * m_blob
 Const reference to the BLOB (always there)
bool m_isBlobOwner
 Do I own the BLOB?
unsigned m_sizeOfObj
 Chache of some frequently-used numbers.
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.

CaloCondBlobBase(const CaloCondBlobBase &other)
Copy Ctor.
Generic template class for storing a number of "T"s for each channel/gain.

◆ 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));
126 CxxUtils::set_unaligned<uint64_t> (pChar, timeStamp);
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}
const uint32_t * getBlobStart() const
Returns the BLOB start address as uint32_t pointer.
static uint32_t packGainAndNchans(const uint32_t gain, const uint32_t nChans)
unsigned m_sizeOfObj
Chache of some frequently-used numbers.
coral::Blob * m_blob_nc
Non-const reference to the BLOB.
unsigned int getHdrSize() const
Returns the size of the header in units of uint32_t.
const void * m_pDataStart
void set_unaligned< uint64_t >(uint8_t *ATH_RESTRICT &p, uint64_t val)
setEventNumber timeStamp
setWord1 uint16_t
setEventNumber uint32_t

◆ 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); }
virtual void dump() const
Prints out the content of the blob to std::out.

◆ 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}
uint32_t getNGains() const
Returns the number of gains stored for each channel.
uint32_t getObjSizeUint32() const
Returns the size of a data object in units of uint32_t.
void dumpHeader(std::ostream &stm) const
Prints the BLOB header summary information.
uint32_t getNChans() const
Returns the number of channels stored in the BLOB.
T getData(const unsigned int channel, const unsigned int adc, const unsigned int idx) const
Returns a single T belonging to a channel/gain.

◆ 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;
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}
uint16_t getObjType() const
Returns the BLOB object type.
std::string getDate() const
Returns the date of the comment as string (derived from timestamp)
uint64_t getTimeStamp() const
Returns the unix timestamp of the comment (seconds since 1.1.1970)
std::string getAuthor() const
Returns the comment author.
uint32_t getCommentSizeUint32() const
Returns the space occupied by the comment fields in units of uint32_t.
uint32_t getNObjs() const
Returns the number of data objects stored int the BLOB.
std::string getComment() const
Returns the actual comment.
uint32_t getObjSizeByte() const
Returns the size of a data object in units of bytes.
uint16_t getObjVersion() const
Returns the BLOB object version.
static std::string getClassName(CaloCondType::TYPE type)
Returns the class name.

◆ getAddress() [1/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() [2/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}

◆ getAddress() [3/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}
const void * getAddress(unsigned int iEle) const
Returns start address of iEle-th basic unit.

◆ getAddress() [4/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}

◆ 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(); }
const coral::Blob * m_blob
Const reference to the BLOB (always there)

◆ 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}
uint32_t getCommentSizeChar() const
Returns the space occupied by the comment fields in units of chars.

◆ 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 {
143return (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{
137 else{throw CaloCond::IndexOutOfRange("CaloCondBlobDat::getData",idx,getObjVersion());}
138}
const T * getAddress(const unsigned int channel, const unsigned int adc) const
Returns a pointer to the first value for the specified channel/gain.

◆ 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}
uint64_t get_unaligned64(const uint8_t *ATH_RESTRICT &p)
Read an 8-byte little-endian value from a possibly unaligned pointer.

◆ 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;}
@ BASE
Enum for CaloCondBlobBase class.

◆ 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();
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){
127 }
128 }
129}
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.
virtual uint16_t getType() const
Returns CaloCondDrawer::BASE.
void setData(unsigned int channel, unsigned int adc, unsigned int idx, T data)
Sets a single T belonging to a channel/gain.

◆ 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,
T 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: