CMS 3D CMS Logo

EcalTPGLinearizationConstXMLTranslator.cc
Go to the documentation of this file.
1 #include <iostream>
2 #include <sstream>
3 #include <fstream>
4 
7 
12 
13 using namespace XERCES_CPP_NAMESPACE;
14 using namespace xuti;
15 using namespace std;
16 
18  const EcalCondHeader& header,
21 
22  std::fstream fs(filename.c_str(), ios::out);
23  fs << dumpXML(header, record);
24 
26 
27  return 0;
28 }
29 
32  unique_ptr<DOMImplementation> impl(DOMImplementationRegistry::getDOMImplementation(cms::xerces::uStr("LS").ptr()));
33 
34  DOMLSSerializer* writer = impl->createLSSerializer();
35  if (writer->getDomConfig()->canSetParameter(XMLUni::fgDOMWRTFormatPrettyPrint, true))
36  writer->getDomConfig()->setParameter(XMLUni::fgDOMWRTFormatPrettyPrint, true);
37 
38  DOMDocumentType* doctype = impl->createDocumentType(cms::xerces::uStr("XML").ptr(), nullptr, nullptr);
39  DOMDocument* doc = impl->createDocument(nullptr, cms::xerces::uStr(Linearization_tag.c_str()).ptr(), doctype);
40  DOMElement* root = doc->getDocumentElement();
41 
43 
44  // open also a flat text file
45  std::ofstream fout;
46  fout.open("Linearization.txt");
47 
48  for (int cellid = EBDetId::MIN_HASH; cellid < EBDetId::kSizeForDenseIndexing; ++cellid) {
49  uint32_t rawid = EBDetId::unhashIndex(cellid);
50 
51  DOMElement* cellnode = writeCell(root, rawid);
52 
53  float m12 = (record)[rawid].mult_x12;
54  float s12 = (record)[rawid].shift_x12;
55  float m6 = (record)[rawid].mult_x6;
56  float s6 = (record)[rawid].shift_x6;
57  float m1 = (record)[rawid].mult_x1;
58  float s1 = (record)[rawid].shift_x1;
59 
66  fout << rawid << " " << m12 << " " << m6 << " " << m1 << " " << s12 << " " << s6 << " " << s1 << "\n";
67  }
68 
69  for (int cellid = 0; cellid < EEDetId::kSizeForDenseIndexing; ++cellid) {
70  if (!EEDetId::validHashIndex(cellid))
71  continue;
72 
73  uint32_t rawid = EEDetId::unhashIndex(cellid);
74 
75  DOMElement* cellnode = writeCell(root, rawid);
76 
77  float m12 = (record)[rawid].mult_x12;
78  float s12 = (record)[rawid].shift_x12;
79  float m6 = (record)[rawid].mult_x6;
80  float s6 = (record)[rawid].shift_x6;
81  float m1 = (record)[rawid].mult_x1;
82  float s1 = (record)[rawid].shift_x1;
83 
90  fout << rawid << " " << m12 << " " << m6 << " " << m1 << " " << s12 << " " << s6 << " " << s1 << "\n";
91  }
92  fout.close();
94  doc->release();
95  doctype->release();
96  writer->release();
97 
98  return dump;
99 }
static constexpr int kSizeForDenseIndexing
Definition: EEDetId.h:328
const std::string Linearization_m1_tag("mult1")
static std::string dumpXML(const EcalCondHeader &header, const EcalTPGLinearizationConst &record)
def dumpXML(db, tag, since, filename='dump.xml')
const std::string Linearization_s12_tag("shift12")
void xercesTerminate()
Definition: Xerces.cc:23
void xercesInitialize()
Definition: Xerces.cc:18
static EEDetId unhashIndex(int hi)
Definition: EEDetId.cc:65
const std::string Linearization_m12_tag("mult12")
void WriteNodeWithValue(xercesc::DOMNode *parentNode, const std::string &tag, const T &value)
write a node with
static bool validHashIndex(int i)
Definition: EEDetId.h:239
const std::string Linearization_m6_tag("mult6")
std::string toString(XMLCh const *toTranscode)
const std::string Linearization_s6_tag("shift6")
static constexpr int kSizeForDenseIndexing
Definition: EBDetId.h:155
static const int MIN_HASH
Definition: EBDetId.h:149
void writeHeader(xercesc::DOMNode *parentNode, const EcalCondHeader &header)
write
ZStr< XMLCh > uStr(char const *str)
const std::string Linearization_s1_tag("shift1")
static int writeXML(const std::string &filename, const EcalCondHeader &header, const EcalTPGLinearizationConst &record)
static EBDetId unhashIndex(int hi)
get a DetId from a compact index for arrays
Definition: EBDetId.h:110
const std::string Linearization_tag("EcalTPGLinearizationConts")
xercesc::DOMElement * writeCell(xercesc::DOMNode *node, const DetId &detid)
Append a Cell node with attributes to.