ATLAS Offline Software
Public Member Functions | Private Attributes | List of all members
CoraCoolExample Class Reference
Collaboration diagram for CoraCoolExample:

Public Member Functions

 CoraCoolExample (const std::string &dbstring, const std::string &options, const std::string &folder, const int nfolder, const int nobj, const int nchan, const int niov, const int iov1, const int iovinc) ATLAS_CTORDTOR_NOT_THREAD_SAFE
 
int execute ()
 
bool write ()
 
bool read ()
 
bool checkAPI ()
 
coral::AttributeList makeAttrList (const CoraCoolFolderPtr fld, const int obj, const int chan, const int iov)
 

Private Attributes

const std::string m_dbstring
 
std::vector< std::string > m_foldername
 
const int m_nobj
 
const int m_nchan
 
const int m_niov
 
const int m_iov1
 
const int m_iovinc
 
bool m_read
 
bool m_write
 
bool m_check
 
bool m_delete
 
bool m_blob
 
bool m_writeref
 
bool m_writeadj
 
bool m_readonly
 
bool m_bulk
 
std::vector< std::string > m_coraltable
 
CoraCoolDatabasePtr m_coradb
 
cool::IDatabasePtr m_cooldb
 
cool::RecordSpecification m_payloadspec
 
cool::RecordSpecification m_fkspec
 
int m_blobsize
 

Detailed Description

Definition at line 24 of file CoraCoolExample.cxx.

Constructor & Destructor Documentation

◆ CoraCoolExample()

CoraCoolExample::CoraCoolExample ( const std::string &  dbstring,
const std::string &  options,
const std::string &  folder,
const int  nfolder,
const int  nobj,
const int  nchan,
const int  niov,
const int  iov1,
const int  iovinc 
)

Definition at line 65 of file CoraCoolExample.cxx.

71  :
73  m_nobj(nobj), m_nchan(nchan), m_niov(niov),m_iov1(iov1),m_iovinc(iovinc) {
74 
75  std::cout << "Option string: " << options << std::endl;
76  std::cout << "Objects per channel=" << m_nobj << " Channels=" << m_nchan
77  << " IOVs=" << m_niov << std::endl;
78  std::cout << "IOVstart=" << m_iov1 << " inc " << m_iovinc << std::endl;
79 
80  // define folders
81  m_foldername.clear();
82  if (nfolder<2) {
83  m_foldername.push_back(folder);
84  } else if (nfolder<1000) {
85  std::cout << "Defining multiple folders" << std::endl;
86  for (int i=1;i<=nfolder;++i) {
87  std::ostringstream o;
88  o << folder << "_" << i;
89  std::cout << "Foldername " << o.str() << std::endl;
90  m_foldername.push_back(o.str());
91  }
92  } else {
93  std::cout << "Attempt to define too many folders " << std::endl;
94  }
95  // parse options
96  m_read=(options.find('r')!=std::string::npos);
97  m_write=(options.find('w')!=std::string::npos);
98  m_check=(options.find('c')!=std::string::npos);
99  m_delete=(options.find('d')!=std::string::npos);
100  m_blob=(options.find('b')!=std::string::npos);
101  m_writeref=(options.find('a')!=std::string::npos);
102  m_writeadj=(options.find('p')!=std::string::npos);
103  m_bulk=(options.find('j')!=std::string::npos);
104  m_readonly=(!(m_write || m_check));
105 
106  if (m_writeref) std::cout <<
107  "Second reference will be included for each object" << std::endl;
108  if (m_writeadj) std::cout <<
109  "Additional rows will be added for each object" << std::endl;
110  if (m_bulk) std::cout << "Writing will use bulk updates" << std::endl;
111 
112  // print dbstring without password if present
113  const unsigned int idx=m_dbstring.find("password");
114  std::cout << "Initialise database for " << m_dbstring.substr(0,idx) <<
115  " readonly " << m_readonly << std::endl;
116 
117  // access the CoraCool database service
118  // this ensures readonly connections will be shared
119  // the SEAL context is created by the CoraCoolDatabaseSvcFactory
120  // which takes care of loading all the required libraries
121 
122  CoraCoolDatabaseSvc& corasvc=CoraCoolDatabaseSvcFactory::databaseService();
123 
124  std::cout << "Done the CoraCool initialisation" << std::endl;
125 
126  // open the CORAL database connection which implicitly opens
127  // the corresponding COOL connection
128  // you can also pass in the COOL connection explicitly
129  std::cout << "Opening CORAL database" << std::endl;
130  try {
132  std::cout << "Database connections open OK" << std::endl;
133  }
134  catch (std::exception&e) {
135  std::cout << "Problem opening CORAL database: " << e.what() << std::endl;
136  }
137  std::cout << "Done the database opening" << std::endl;
138 
139  // list the COOL folders found in the database
140  cool::IDatabasePtr cooldb=m_coradb->coolDatabase();
141  const std::vector<std::string>& folders=cooldb->listAllNodes();
142  std::cout << "COOL database has " << folders.size() << " folders defined"
143  << std::endl;
144  for (std::vector<std::string>::const_iterator itr=folders.begin();
145  itr!=folders.end();++itr) std::cout << *itr << std::endl;
146 
147  // create the AttributeListSpecification for the payload
148  // primary / foreign keys
149  m_payloadspec.extend("PrimKey",cool::StorageType::Int32);
150  m_payloadspec.extend("ForeignKey",cool::StorageType::Int32);
151  // integers to check the data integrity on readback - keep details of the
152  // object origin
153  m_payloadspec.extend("IntObj",cool::StorageType::Int32);
154  m_payloadspec.extend("IntChan",cool::StorageType::Int32);
155  m_payloadspec.extend("IntIOV",cool::StorageType::Int32);
156  // other data members
157  m_payloadspec.extend("UInt1",cool::StorageType::UInt32);
158  m_payloadspec.extend("Float1",cool::StorageType::Float);
159  m_payloadspec.extend("Double1",cool::StorageType::Double);
160  m_payloadspec.extend("LongLong1",cool::StorageType::Int64);
161  m_payloadspec.extend("ULongLong1",cool::StorageType::UInt63);
162  m_payloadspec.extend("String1",cool::StorageType::String4k);
163  // optional declaration of CORAL Blob type object
164  m_blobsize = 0;
165  if (m_blob) {
166  m_payloadspec.extend("Blob1",cool::StorageType::Blob64k);
167  m_blobsize=1000;
168  std::cout << "Including blob of size " << m_blobsize << " in data " <<
169  std::endl;
170  }
171  // create COOL FK spec
172  m_fkspec.extend("CoolKey",cool::StorageType::Int32);
173 
174  // set payload table names from foldername leaf name
175  m_coraltable.clear();
176  for (std::vector<std::string>::const_iterator itr=m_foldername.begin();
177  itr!=m_foldername.end();++itr) {
178  std::string::size_type iofs=itr->rfind("/");
179  if (iofs!=std::string::npos) {
180  m_coraltable.push_back(itr->substr(iofs+1));
181  } else {
182  m_coraltable.push_back(*itr);
183  }
184  }
185 }

Member Function Documentation

◆ checkAPI()

bool CoraCoolExample::checkAPI ( )

Definition at line 414 of file CoraCoolExample.cxx.

414  {
415  // this routine is suppposed to check all calls of the CoraCool API
416  std::cout << "Check API not implemented yet" << std::endl;
417  return true;
418 }

◆ execute()

int CoraCoolExample::execute ( )

Definition at line 222 of file CoraCoolExample.cxx.

222  {
223  int retcode=0;
224  if (m_write) {
225  if (write()==false) {
226  std::cout << "CoraCoolExample FAILURE from write" << std::endl;
227  retcode+=1;
228  }
229  }
230  if (m_read) {
231  if (read()==false) {
232  std::cout << "CoraCoolExample FAILURE from read" << std::endl;
233  retcode+=2;
234  }
235  }
236  if (m_check) {
237  if (checkAPI()==false) retcode+=4;
238  }
239  return retcode;
240 }

◆ makeAttrList()

coral::AttributeList CoraCoolExample::makeAttrList ( const CoraCoolFolderPtr  fld,
const int  obj,
const int  chan,
const int  iov 
)

Definition at line 187 of file CoraCoolExample.cxx.

189  {
190  // create a payload object according to the specification generated
191  // previously
192  coral::AttributeList data=fld->emptyAttrList();
193  // setup iov, modulo number of IOVs generated (to deal with referenced objs)
194  int iov2=iov;
196  // set keys to zero - will be overwritten
197  data["PrimKey"].data<int>()=0;
198  data["ForeignKey"].data<int>()=0;
199  // set next 3 depending on object identity, so can check on read back
200  data["IntObj"].data<int>()=obj;
201  data["IntChan"].data<int>()=chan;
202  data["IntIOV"].data<int>()=iov2;
203  // other data
204  data["Float1"].data<float>()=0.5+obj+chan+iov2;
205  data["Double1"].data<double>()=0.6+obj+chan+iov2;
206  data["UInt1"].data<unsigned int>()=iov2+chan+obj;
207  // use SEAL platform independent-types to access 64 bit ints
208  // works on 32 and 64 bit machines
209  data["LongLong1"].data<cool::Int64>()=iov2*100000+chan*1000+obj;
210  data["ULongLong1"].data<cool::UInt63>()=iov2+chan+2*obj;
211  data["String1"].data<std::string>()="A test string of data";
212  // setting up data for a blob object
213  if (m_blob) {
214  coral::Blob& blob=data["Blob1"].data<coral::Blob>();
215  blob.resize(m_blobsize);
216  unsigned char* p=static_cast<unsigned char*>(blob.startingAddress());
217  for (int i=0;i<m_blobsize;++i,++p) *p=(i+iov2+chan+obj) % 256;
218  }
219  return data;
220 }

◆ read()

bool CoraCoolExample::read ( )

Definition at line 329 of file CoraCoolExample.cxx.

329  {
330  // loop over folders
331  int nerr=0;
332  for (std::vector<std::string>::const_iterator fitr=m_foldername.begin();
333  fitr!=m_foldername.end();++fitr) {
334  std::cout << "Read back data from folder " << *fitr << std::endl;
336  try {
337  folder=m_coradb->getFolder(*fitr);
338  }
339  catch (cool::Exception& e) {
340  std::cout << "Exception during getFolder: " << e.what() << std::endl;
341  return false;
342  }
343  int nobj=0;
344  // printout specification of folder
345  const cool::IRecordSpecification& spec=
346  folder->payloadSpecification();
347  for (unsigned int i=0;i<spec.size();++i) {
348  std::cout << "Payload column: " << spec[i].name() << " type: " <<
349  spec[i].storageType().name() << std::endl;
350  }
351  int nrep=1;
352  if (m_writeref) nrep=2;
353  for (int iiov=0;iiov<m_niov*nrep;++iiov) {
354  int iovx=iiov*m_iovinc+m_iov1;
355  // bulk read at a point in time - get all channels valid at this time
356  CoraCoolObjectIterPtr itr=folder->browseObjects(iovx,cool::ChannelSelection::all());
357  while (itr->hasNext()) {
358  CoraCoolObjectPtr obj=itr->next();
359  // check the returned object against what was stored in the write method
360  int iobj=0;
361  for (CoraCoolObject::const_iterator payitr=obj->begin();
362  payitr!=obj->end();++payitr,++iobj) {
363  // construct the expected object to compare
364  int iobj2=(*payitr)["IntObj"].data<int>();
366  obj->channelId(),iovx);
367  // check all fields except the first two (primary and foreign keys)
368  // which are reassigned by CoraCool
369  bool match=(expect.size()==payitr->size() && expect.size()>2);
370  if (match) {
371  for (unsigned int i=2;i<expect.size();++i) {
372  std::string dtype=expect[i].specification().typeName();
373  bool failmatch=false;
374  if (dtype=="int" || dtype=="unsigned int" || dtype=="long long" ||
375  dtype=="std::string") {
376  failmatch=(expect[i]!=(*payitr)[i]);
377  } else if (dtype=="float") {
378  failmatch=(fabsf(expect[i].data<float>()-
379  (*payitr)[i].data<float>())>1.E-3);
380  } else if (dtype=="double") {
381  failmatch=(fabs(expect[i].data<double>()-
382  (*payitr)[i].data<double>())>1.E-3);
383  } else if (dtype=="blob") {
384  // coral defines comparison operator for blobs internally
385  failmatch=(expect[i]!=(*payitr)[i]);
386  }
387  if (failmatch) {
388  match=false;
389  std::cout << expect[i].specification().name() << " does not match" << std::endl;
390  }
391  }
392  }
393  if (!match) {
394  std::cout << "Objects do not match for object/channel/iov "
395  << iobj << "/" << obj->channelId() << "/" << iiov <<
396  std::endl;
397  std::cout << "Read from DB: ";
398  (*payitr).toOutputStream(std::cout);
399  std::cout << std::endl << "Expected object: ";
400  expect.toOutputStream(std::cout);
401  std::cout << std::endl;
402  ++nerr;
403  }
404  }
405  ++nobj;
406  }
407  }
408  std::cout << "Read a total of " << nobj << " objects from CoraCool folder "
409  << *fitr << " with " << nerr << " errors" << std::endl;
410  }
411  return (nerr==0);
412 }

◆ write()

bool CoraCoolExample::write ( )

Definition at line 242 of file CoraCoolExample.cxx.

242  {
244  // loop over all folders
245  std::vector<std::string>::const_iterator ctitr=m_coraltable.begin();
246  for (std::vector<std::string>::const_iterator fitr=m_foldername.begin();
247  fitr!=m_foldername.end();++fitr,++ctitr) {
248  // check if previous attempt needs to be deleted
249  // does the folder exist already?
250  if (m_delete && m_coradb->existsFolder(*fitr)) {
251  try {
252  std::cout << "Deleting existing folder " << *fitr << std::endl;
253  m_coradb->deleteFolder(*fitr);
254  std::cout << "Folder deleted" << std::endl;
255  }
256  catch (cool::Exception& e) {
257  std::cout << "Problem deleting folder: " << e.what() << std::endl;
258  return false;
259  }
260  }
261  if (!m_coradb->existsFolder(*fitr)) {
262  // create the test folder
263  std::cout << "Creating folder with name " << *fitr << std::endl;
264  // description string to allow folder to be read in Athena
265  std::string desc="<timeStamp>run-event</timeStamp><addrHeader><address_header service_type=\"71\" clid=\"55403898\" /></addrHeader><typeName>CondAttrListVec</typeName>";
266  try {
267  folder=m_coradb->createFolder(
268  *fitr,*ctitr,m_fkspec,m_payloadspec,
269  "ForeignKey","PrimKey",desc,
270  cool::FolderVersioning::SINGLE_VERSION,true);
271  std::cout << "Folder " << *fitr << " created" << std::endl;
272  }
273  catch (cool::Exception& e) {
274  std::cout << "Problem creating folder: " << e.what() << std::endl;
275  return false;
276  }
277  } else {
278  folder=m_coradb->getFolder(*fitr);
279  }
280 
281  // now write data
282  int nobj=0;
283  for (int iiov=0;iiov<m_niov;++iiov) {
284  // bulk operation is inside loop to avoid problems with SV multichannel
285  // insert
286  if (m_bulk) folder->setupStorageBuffer();
287  int iovx=iiov*m_iovinc+m_iov1;
288  for (int ichan=0;ichan<m_nchan;++ichan) {
289  // prepare data
290  std::vector<coral::AttributeList> datavec;
291  for (int iobj=0;iobj<m_nobj;++iobj) {
293  datavec.push_back(adata);
294  }
295  try {
296  int fkey=folder->storeObject(iovx,iovx+m_iovinc,datavec.begin(),
297  datavec.end(),ichan);
298  ++nobj;
299  if (m_writeadj) {
300  // add aditional rows
301  std::vector<coral::AttributeList> datavec2;
302  for (int iobj=0;iobj<m_nobj;++iobj) {
303  coral::AttributeList adata=
304  makeAttrList(folder,iobj+m_nobj,ichan,iovx);
305  adata["ForeignKey"].data<int>()=fkey;
306  datavec2.push_back(adata);
307  }
308  folder->addPayload(datavec2.begin(),datavec2.end());
309  }
310  if (m_writeref) {
311  // add additional IOV for later run, also referencing this data
312  int iov2=iovx+m_iovinc*m_niov;
313  folder->referenceObject(iov2,iov2+m_iovinc,fkey,ichan);
314  }
315  }
316  catch (cool::Exception& e) {
317  std::cout << "Problem writing data: " << e.what() << std::endl;
318  return false;
319  }
320  }
321  if (m_bulk) folder->flushStorageBuffer();
322  }
323  std::cout << "Written " << nobj << " objects to folder " << *fitr <<
324  std::endl;
325  }
326  return true;
327 }

Member Data Documentation

◆ m_blob

bool CoraCoolExample::m_blob
private

Definition at line 50 of file CoraCoolExample.cxx.

◆ m_blobsize

int CoraCoolExample::m_blobsize
private

Definition at line 62 of file CoraCoolExample.cxx.

◆ m_bulk

bool CoraCoolExample::m_bulk
private

Definition at line 54 of file CoraCoolExample.cxx.

◆ m_check

bool CoraCoolExample::m_check
private

Definition at line 48 of file CoraCoolExample.cxx.

◆ m_cooldb

cool::IDatabasePtr CoraCoolExample::m_cooldb
private

Definition at line 58 of file CoraCoolExample.cxx.

◆ m_coradb

CoraCoolDatabasePtr CoraCoolExample::m_coradb
private

Definition at line 57 of file CoraCoolExample.cxx.

◆ m_coraltable

std::vector<std::string> CoraCoolExample::m_coraltable
private

Definition at line 55 of file CoraCoolExample.cxx.

◆ m_dbstring

const std::string CoraCoolExample::m_dbstring
private

Definition at line 39 of file CoraCoolExample.cxx.

◆ m_delete

bool CoraCoolExample::m_delete
private

Definition at line 49 of file CoraCoolExample.cxx.

◆ m_fkspec

cool::RecordSpecification CoraCoolExample::m_fkspec
private

Definition at line 61 of file CoraCoolExample.cxx.

◆ m_foldername

std::vector<std::string> CoraCoolExample::m_foldername
private

Definition at line 40 of file CoraCoolExample.cxx.

◆ m_iov1

const int CoraCoolExample::m_iov1
private

Definition at line 44 of file CoraCoolExample.cxx.

◆ m_iovinc

const int CoraCoolExample::m_iovinc
private

Definition at line 45 of file CoraCoolExample.cxx.

◆ m_nchan

const int CoraCoolExample::m_nchan
private

Definition at line 42 of file CoraCoolExample.cxx.

◆ m_niov

const int CoraCoolExample::m_niov
private

Definition at line 43 of file CoraCoolExample.cxx.

◆ m_nobj

const int CoraCoolExample::m_nobj
private

Definition at line 41 of file CoraCoolExample.cxx.

◆ m_payloadspec

cool::RecordSpecification CoraCoolExample::m_payloadspec
private

Definition at line 60 of file CoraCoolExample.cxx.

◆ m_read

bool CoraCoolExample::m_read
private

Definition at line 46 of file CoraCoolExample.cxx.

◆ m_readonly

bool CoraCoolExample::m_readonly
private

Definition at line 53 of file CoraCoolExample.cxx.

◆ m_write

bool CoraCoolExample::m_write
private

Definition at line 47 of file CoraCoolExample.cxx.

◆ m_writeadj

bool CoraCoolExample::m_writeadj
private

Definition at line 52 of file CoraCoolExample.cxx.

◆ m_writeref

bool CoraCoolExample::m_writeref
private

Definition at line 51 of file CoraCoolExample.cxx.


The documentation for this class was generated from the following file:
AllowedVariables::e
e
Definition: AsgElectronSelectorTool.cxx:37
data
char data[hepevt_bytes_allocation_ATLAS]
Definition: HepEvt.cxx:11
PlotCalibFromCool.iov1
iov1
Definition: PlotCalibFromCool.py:382
dqt_zlumi_alleff_HIST.iov
iov
Definition: dqt_zlumi_alleff_HIST.py:119
CoraCoolExample::m_payloadspec
cool::RecordSpecification m_payloadspec
Definition: CoraCoolExample.cxx:60
CoraCoolExample::m_iovinc
const int m_iovinc
Definition: CoraCoolExample.cxx:45
CoraCoolExample::m_blob
bool m_blob
Definition: CoraCoolExample.cxx:50
PlotCalibFromCool.dtype
dtype
Definition: PlotCalibFromCool.py:495
CaloCondBlobAlgs_fillNoiseFromASCII.spec
spec
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:47
CoraCoolExample::m_bulk
bool m_bulk
Definition: CoraCoolExample.cxx:54
createCoolChannelIdFile.dbstring
dbstring
Definition: createCoolChannelIdFile.py:31
CoraCoolExample::m_readonly
bool m_readonly
Definition: CoraCoolExample.cxx:53
CoraCoolExample::m_dbstring
const std::string m_dbstring
Definition: CoraCoolExample.cxx:39
PlotCalibFromCool.nchan
nchan
Definition: PlotCalibFromCool.py:564
python.subdetectors.tile.Blob
Blob
Definition: tile.py:17
CoraCoolDatabaseSvc
Definition: CoraCoolDatabaseSvc.h:25
CoraCoolExample::m_coradb
CoraCoolDatabasePtr m_coradb
Definition: CoraCoolExample.cxx:57
python.PyKernel.AttributeList
AttributeList
Definition: PyKernel.py:36
CoraCoolExample::m_writeref
bool m_writeref
Definition: CoraCoolExample.cxx:51
CoraCoolExample::m_iov1
const int m_iov1
Definition: CoraCoolExample.cxx:44
CoraCoolObject::const_iterator
AttrListVec::const_iterator const_iterator
Definition: CoraCoolObject.h:23
CoraCoolExample::m_check
bool m_check
Definition: CoraCoolExample.cxx:48
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
CoraCoolExample::m_fkspec
cool::RecordSpecification m_fkspec
Definition: CoraCoolExample.cxx:61
CaloCondBlobAlgs_fillNoiseFromASCII.desc
desc
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:54
CoraCoolExample::m_read
bool m_read
Definition: CoraCoolExample.cxx:46
lumiFormat.i
int i
Definition: lumiFormat.py:85
CoraCoolExample::m_nobj
const int m_nobj
Definition: CoraCoolExample.cxx:41
CoraCoolExample::m_writeadj
bool m_writeadj
Definition: CoraCoolExample.cxx:52
ReadCellNoiseFromCool.chan
chan
Definition: ReadCellNoiseFromCool.py:52
calibdata.exception
exception
Definition: calibdata.py:496
python.AtlRunQueryLib.options
options
Definition: AtlRunQueryLib.py:379
CoraCoolExample::m_foldername
std::vector< std::string > m_foldername
Definition: CoraCoolExample.cxx:40
CoraCoolExample::m_delete
bool m_delete
Definition: CoraCoolExample.cxx:49
CoraCoolFolderPtr
boost::shared_ptr< CoraCoolFolder > CoraCoolFolderPtr
Definition: CoraCoolTypes.h:15
LArConditions2Ntuple.fld
string fld
Definition: LArConditions2Ntuple.py:302
CoraCoolDatabaseSvc::openDatabase
CoraCoolDatabasePtr openDatabase(const std::string &dbconn, cool::IDatabasePtr cooldb, bool readonly=false)
Definition: CoraCoolDatabaseSvc.cxx:23
defineDB.ichan
int ichan
Definition: JetTagCalibration/share/defineDB.py:28
CoraCoolExample::m_nchan
const int m_nchan
Definition: CoraCoolExample.cxx:42
Cut::all
@ all
Definition: SUSYToolsAlg.cxx:67
CoraCoolExample::m_coraltable
std::vector< std::string > m_coraltable
Definition: CoraCoolExample.cxx:55
CoraCoolExample::m_niov
const int m_niov
Definition: CoraCoolExample.cxx:43
PlotCalibFromCool.iov2
iov2
Definition: PlotCalibFromCool.py:384
CoraCoolObjectIterPtr
boost::shared_ptr< CoraCoolObjectIter > CoraCoolObjectIterPtr
Definition: CoraCoolTypes.h:21
makeDTCalibBlob_pickPhase.folders
folders
Definition: makeDTCalibBlob_pickPhase.py:346
CoraCoolObjectPtr
boost::shared_ptr< CoraCoolObject > CoraCoolObjectPtr
Definition: CoraCoolTypes.h:18
LArNewCalib_DelayDump_OFC_Cali.idx
idx
Definition: LArNewCalib_DelayDump_OFC_Cali.py:69
CaloCondBlobAlgs_fillNoiseFromASCII.folder
folder
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:56
CoraCoolExample::makeAttrList
coral::AttributeList makeAttrList(const CoraCoolFolderPtr fld, const int obj, const int chan, const int iov)
Definition: CoraCoolExample.cxx:187
CoraCoolExample::m_write
bool m_write
Definition: CoraCoolExample.cxx:47
CoraCoolExample::read
bool read()
Definition: CoraCoolExample.cxx:329
python.PyAthena.obj
obj
Definition: PyAthena.py:132
CoraCoolExample::m_blobsize
int m_blobsize
Definition: CoraCoolExample.cxx:62
CoraCoolExample::write
bool write()
Definition: CoraCoolExample.cxx:242
CoraCoolExample::checkAPI
bool checkAPI()
Definition: CoraCoolExample.cxx:414
CaloCondBlobAlgs_fillNoiseFromASCII.blob
blob
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:96
match
bool match(std::string s1, std::string s2)
match the individual directories of two strings
Definition: hcg.cxx:356