Loading [MathJax]/extensions/tex2jax.js
ATLAS Offline Software
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
Public Member Functions | Private Types | Private Member Functions | Private Attributes | List of all members
Analysis::CDIReader Class Reference

#include <CDIReader.h>

Collaboration diagram for Analysis::CDIReader:

Public Member Functions

 CDIReader (const std::string &cdipath, bool verbose=false)
 normal constructor. More...
 
 ~CDIReader ()=default
 
void printTaggers ()
 
void printJetCollections ()
 
void printWorkingPoints ()
 
void printLabels ()
 
void printDSIDs ()
 
bool checkConfig (const std::string &tagger, const std::string &jetcoll, const std::string &wp, bool verbose=false)
 
Labels getDSIDs (const std::string &tagger="", const std::string &jetcollection="", const std::string &workingpoint="")
 
Labels getLabels (const std::string &tagger="", const std::string &jetcollection="", const std::string &workingpoint="")
 
Labels getWorkingPoints (const std::string &tagger, const std::string &jetcollection)
 
Labels getJetCollections (const std::string &tagger)
 
Labels getTaggers ()
 

Private Types

typedef std::vector< std::string > Labels
 
typedef std::map< std::string, LabelsData
 
typedef std::map< std::string, DataWPoint
 
typedef std::map< std::string, WPointJetColl
 
typedef std::map< std::string, JetCollMeta
 

Private Member Functions

void printMetadata (int tagger=-1, int jetcoll=-1, int wpoint=-1, int label=-1)
 
void crawlCDI (TDirectoryFile *parentDir, int depth=0, const std::string &metamap="")
 
void record_metadata (const std::string &datum, int depth=0)
 
void record_metadata_map (const Data &data, const std::string &path)
 
bool isWPdirectory (TList *list)
 
std::string trim (const std::string &str, const std::string &whitespace=" \t")
 
std::vector< std::string > split (const std::string &str, char token=';')
 

Private Attributes

bool m_initialized = false
 flag whether the initialization has been carried out More...
 
bool m_use_json = false
 
std::string m_cdipath = ""
 
std::unique_ptr< TFile > m_CDIFile
 
std::set< std::string > m_taggers {}
 
std::set< std::string > m_jetcollections {}
 
std::set< std::string > m_workingpoints {}
 
std::set< std::string > m_labels {}
 
std::set< std::string > m_DSIDs {}
 
Labels m_label_vec
 
Meta m_metadata
 

Detailed Description

Definition at line 39 of file CDIReader.h.

Member Typedef Documentation

◆ Data

typedef std::map<std::string, Labels> Analysis::CDIReader::Data
private

Definition at line 42 of file CDIReader.h.

◆ JetColl

typedef std::map<std::string, WPoint> Analysis::CDIReader::JetColl
private

Definition at line 44 of file CDIReader.h.

◆ Labels

typedef std::vector<std::string> Analysis::CDIReader::Labels
private

Definition at line 41 of file CDIReader.h.

◆ Meta

typedef std::map<std::string, JetColl> Analysis::CDIReader::Meta
private

Definition at line 45 of file CDIReader.h.

◆ WPoint

typedef std::map<std::string, Data> Analysis::CDIReader::WPoint
private

Definition at line 43 of file CDIReader.h.

Constructor & Destructor Documentation

◆ CDIReader()

Analysis::CDIReader::CDIReader ( const std::string &  cdipath,
bool  verbose = false 
)

normal constructor.

The second argument, if true, will attempt to retrieve a 'recommended' set of uncertainties to be excluded from EV decomposition

Definition at line 15 of file CDIReader.cxx.

15  : m_use_json(false), m_cdipath(cdipath), m_CDIFile(TFile::Open(m_cdipath.c_str(), "READ"))
16 {
17  TObjString* s;
18  m_CDIFile->GetObject("VersionInfo/BuildNumber", s);
19  if (s && verbose){
20  std::cout << " CDI file build number: " << s->GetName() << std::endl;
21  }
22  TList* taggerkeys = m_CDIFile->GetListOfKeys();
23  for (const auto tagger : *taggerkeys){
24  const char* taggername = tagger->GetName();
25  if(strcmp(taggername, "VersionInfo") != 0){
26  // now we have the top-level tagger name, we want to add this to our overall meta data
27  TDirectoryFile* taggerDir = (TDirectoryFile*)m_CDIFile->Get(taggername);
28  record_metadata(taggername, 0);
29  crawlCDI(taggerDir, 0, taggername);
30  }
31  }
32 }

◆ ~CDIReader()

Analysis::CDIReader::~CDIReader ( )
default

Member Function Documentation

◆ checkConfig()

bool Analysis::CDIReader::checkConfig ( const std::string &  tagger,
const std::string &  jetcoll,
const std::string &  wp,
bool  verbose = false 
)

Definition at line 194 of file CDIReader.cxx.

194  {
195  // this method checks if your config is correct or not
196  // returns true if correct, false if not
197  // if not correct, it will also print a helpful message
198  bool configured = false;
199  // get the number that would correspond to the index of the tagger/jetcoll/wp
200  // if these were each stored in a vector of strings, sorted alphanumerically
201  // which happens already by default in the (ordered) map
202  int tagger_ind = 0;
203  int jetcoll_ind = 0;
204  int wp_ind = 0;
205 
206  if(m_metadata.count(tagger) > 0){
207  // get the tagger index
208  for(const auto& tag : m_metadata){
209  tagger_ind += 1;
210  if(tag.first == tagger) break;
211  }
212  if(m_metadata[tagger].count(jetcoll) > 0){
213  // get the jet collection index
214  for(const auto& jet : m_metadata[tagger]){
215  jetcoll_ind += 1;
216  if(jet.first == jetcoll) break;
217  }
218  if(m_metadata[tagger][jetcoll].count(wp) > 0){
219  // get the working point index
220  for(const auto& wpoint : m_metadata[tagger][jetcoll]){
221  wp_ind += 1;
222  if(wpoint.first == wp) break;
223  }
224  if (verbose) std::cout << " Your configuration looks good! Available labels are : " << std::endl;
225  if (verbose) printMetadata(tagger_ind, jetcoll_ind, wp_ind, -1);
226  // construct vector of labels
227  for(const std::string& flavour_label : m_metadata[tagger][jetcoll][wp]["labels"]){
228  m_label_vec.push_back(flavour_label);
229  }
230  // sort the vector of labels
231  std::sort(m_label_vec.begin(), m_label_vec.end());
232  configured = true;
233  } else {
234  if (verbose) std::cout << "Couldn't find \"" << wp << "\" for " << tagger << " / " << jetcoll << " in this CDI file!" << std::endl;
235  if (verbose) std::cout << "Here are your options :" << std::endl;
236  if (verbose) printMetadata(tagger_ind, jetcoll_ind, -1, 0);
237  }
238  } else {
239  if (verbose) std::cout << "Couldn't find \"" << jetcoll << "\" under " << tagger << " in this CDI file!" << std::endl;
240  if (verbose) std::cout << "Here are your options :" << std::endl;
241  if (verbose) printMetadata(tagger_ind, -1, 0, 0);
242  }
243  } else {
244  if (verbose) std::cout << "Couldn't find \"" << tagger << "\" in this CDI file" << std::endl;
245  if (verbose) std::cout << "Here are your options :" << std::endl;
246  if (verbose) printMetadata(-1,0,0,0);
247  }
248 
249  if(m_use_json){
250  // let's make a json object from the nlohmann package and save it to file
251  json json_metadata(m_metadata);
252  // get cwd to save in
253  std::filesystem::path cwd = std::filesystem::current_path();
254  std::filesystem::path filepath = cwd / "CDI.json";
255  std::ofstream output(filepath);
256  output << std::setw(4) << json_metadata << std::endl;
257  }
258 
259  m_initialized = configured;
260  return configured;
261 }

◆ crawlCDI()

void Analysis::CDIReader::crawlCDI ( TDirectoryFile *  parentDir,
int  depth = 0,
const std::string &  metamap = "" 
)
private

Definition at line 35 of file CDIReader.cxx.

35  {
36 
37  TList* keys = parentDir->GetListOfKeys(); // get directories
38  if(isWPdirectory(keys)){
39  // now that we are at the level of the individual label directories
40  // interact with them, and extract the data they store
41 
42  TList* labelkeys = parentDir->GetListOfKeys();
43  Data theseData; // labels, systematics, DSIDS, etc.
44  Labels theseLabels;
45  std::set<std::string> DSID_set; // record all DSID names in the flavour configuration
46  std::set<std::string> systematics_set; // record all uncertainties met in flavour configuration
47 
48  Labels path = split(metamap);
49  std::string taggername = path.at(0);
50  std::string jetcollname = path.at(1);
51  std::string workingpointname = path.at(2);
52 
53  // For each "label" stored in the working point directory,
54  // we need to access the contents of the label directory
55  // and construct the metadata map
56  for(const auto label : *labelkeys){
57  std::string labelname = label->GetName();
58  if(labelname == "cutvalue" || labelname.find("fraction") != std::string::npos) continue;
59  m_labels.insert(labelname);
60  theseLabels.push_back(labelname);
61 
62  // now enter the directory to access uncertainty info for this flavour
63  TDirectoryFile* flavourDir = (TDirectoryFile*)parentDir->Get(labelname.c_str());
64  if(flavourDir){
65  Labels uncertainties; // flavour specific uncertainties
66  TList* DSIDkeys = flavourDir->GetListOfKeys(); // this is the list of all the items in the flavour (DSID etc)
67  for(const auto CDHistCont : *DSIDkeys){
68  std::string DSIDname = CDHistCont->GetName();
69  DSID_set.insert(DSIDname);
70  m_DSIDs.insert(DSIDname);
71  if(DSIDname == "default_SF"){ // let's access the systematic uncertainties
72  // construct the total path
73  std::string dir = taggername + "/" + jetcollname + "/" + workingpointname + "/" + labelname + "/default_SF";
75  m_CDIFile->GetObject(dir.c_str(), cont);
76  if(!cont){
77  std::cout << "No default_SF CalibrationDataHistogramContainer?" << std::endl;
78  } else {
79  uncertainties = cont->listUncertainties();
80  for(std::string s : uncertainties){
81  systematics_set.insert(s);
82  }
83  }
84  // add the flavour specific uncertainties here
85  std::string flav_spec_unc_name = labelname + "_syst";
86  theseData[flav_spec_unc_name] = uncertainties;
87  }
88  }
89  } else {
90  std::cout << "No flavour directory?" << std::endl;
91  }
92  }
93  // sort and add the labels to the Data object
94  std::sort(theseLabels.begin(), theseLabels.end());
95  theseData["labels"] = theseLabels;
96  // convert DSID set to vector of strings
97  Labels theseDSIDs(DSID_set.size());
98  std::copy(DSID_set.begin(), DSID_set.end(), theseDSIDs.begin());
99  theseData["DSIDs"] = theseDSIDs;
100  // convert systematic set to vector of strings
101  Labels theseSystematics(systematics_set.size());
102  std::copy(systematics_set.begin(), systematics_set.end(), theseSystematics.begin());
103  theseData["systematics"] = theseSystematics;
104  // Construct this branch of the metadata map
105  // and record the Data object
106  record_metadata_map(theseData, metamap);
107  } else {
108  for(const auto coll: *keys){
109  std::string collname = coll->GetName();
110  if ( collname.find("cutvalue") != std::string::npos || collname.find("fraction") != std::string::npos) continue;
111  // track the metadata as you traverse
112  record_metadata(collname, depth+1);
113  TDirectoryFile* collDir = (TDirectoryFile*)parentDir->Get(collname.c_str());
114  if(collDir && collname != "VersionInfo"){
115  std::string nextmap = metamap + ";" + collname;
116  crawlCDI(collDir, depth+1, nextmap); // traverse further
117  } else {
118  std::cout << "No collection directory?" << std::endl;
119  }
120  }
121  }
122 }

◆ getDSIDs()

std::vector< std::string > Analysis::CDIReader::getDSIDs ( const std::string &  tagger = "",
const std::string &  jetcollection = "",
const std::string &  workingpoint = "" 
)

Definition at line 264 of file CDIReader.cxx.

264  {
265  if(!m_initialized){
266  std::cout << " CDIReader :: You need to validate your configuration before working with (flavour) labels!" << std::endl;
267  }
268  Labels DSIDs;
269  if (tagger.empty() || jetcollection.empty() || workingpoint.empty()){
270  // unless specified, return the vector of all known DSIDs from this CDI file
271  Labels DSID_vec(m_DSIDs.size());
272  std::copy(m_DSIDs.begin(), m_DSIDs.end(), DSID_vec.begin());
273  DSIDs = DSID_vec;
274  //} else if(std::find(m_taggers.begin(), m_taggers.end(), tagger) == m_taggers.end()){
275  } else if(m_taggers.find(tagger) == m_taggers.end()){
276  std::cout << " The tagger [" << tagger << "] doesn't exist in this CDI file!" << std::endl;
277  //} else if(std::find(m_jetcollections.begin(), m_jetcollections.end(), jetcollection) == m_jetcollections.end()){
278  } else if(m_jetcollections.find(jetcollection) == m_jetcollections.end()){
279  std::cout << " The jet collection [" << jetcollection << "] doesn't exist in " << tagger << " this CDI file!" << std::endl;
280  //} else if(std::find(m_workingpoints.begin(), m_workingpoints.end(), workingpoint) == m_workingpoints.end()){
281  } else if(m_workingpoints.find(workingpoint) == m_workingpoints.end()){
282  std::cout << " The working point [" << workingpoint << "] doesn't exist in " << tagger << "/" << jetcollection << " this CDI file!" << std::endl;
283  } else {
284  for (const std::string& DSID : m_metadata[tagger][jetcollection][workingpoint]["DSIDs"]){
285  DSIDs.push_back(DSID);
286  }
287  }
288  return DSIDs;
289 }

◆ getJetCollections()

std::vector< std::string > Analysis::CDIReader::getJetCollections ( const std::string &  tagger)

Definition at line 313 of file CDIReader.cxx.

313  {
314  Labels jetcolls;
315  if (tagger.empty()){
316  // unless specified, return the vector of all jet collections
317  jetcolls.assign(m_jetcollections.begin(), m_jetcollections.end());
318  } else if (m_taggers.find(tagger) == m_taggers.end()) {
319  std::cout << " The tagger [" << tagger << "] doesn't exist in this CDI file!" << std::endl;
320  } else {
321  // return the jetcollections of this tagger
322  for(const auto& jet : m_metadata[tagger]){
323  jetcolls.push_back(jet.first);
324  }
325  }
326  return jetcolls;
327 }

◆ getLabels()

std::vector< std::string > Analysis::CDIReader::getLabels ( const std::string &  tagger = "",
const std::string &  jetcollection = "",
const std::string &  workingpoint = "" 
)

Definition at line 291 of file CDIReader.cxx.

291  {
292  if(!m_initialized){
293  std::cout << " CDIReader :: You need to validate your configuration before working with (flavour) labels!" << std::endl;
294  }
295  Labels labels;
296  if (tagger.empty() || jetcollection.empty() || workingpoint.empty()){
297  // unless specified, return the vector of all flavour labels
299  } else if(m_taggers.find(tagger) == m_taggers.end()){
300  std::cout << " The tagger [" << tagger << "] doesn't exist in this CDI file!" << std::endl;
301  } else if(m_jetcollections.find(jetcollection) == m_jetcollections.end()){
302  std::cout << " The jet collection [" << jetcollection << "] doesn't exist in " << tagger << " this CDI file!" << std::endl;
303  } else if(m_workingpoints.find(workingpoint) == m_workingpoints.end()){
304  std::cout << " The working point [" << workingpoint << "] doesn't exist in " << tagger << "/" << jetcollection << " this CDI file!" << std::endl;
305  } else {
306  for (const std::string& label : m_metadata[tagger][jetcollection][workingpoint]["labels"]){
307  labels.push_back(label);
308  }
309  }
310  return labels;
311 }

◆ getTaggers()

std::vector< std::string > Analysis::CDIReader::getTaggers ( )

Definition at line 347 of file CDIReader.cxx.

347  {
348  Labels taggers;
349  taggers.assign(m_taggers.begin(), m_taggers.end());
350  return taggers;
351 }

◆ getWorkingPoints()

std::vector< std::string > Analysis::CDIReader::getWorkingPoints ( const std::string &  tagger,
const std::string &  jetcollection 
)

Definition at line 330 of file CDIReader.cxx.

330  {
331  Labels wps;
332  if (tagger.empty() || jetcollection.empty()){
333  // unless specified, return the vector of all working points
334  wps.assign(m_workingpoints.begin(), m_workingpoints.end());
335  } else if(m_taggers.find(tagger) == m_taggers.end()){
336  std::cout << " The tagger [" << tagger << "] doesn't exist in this CDI file!" << std::endl;
337  } else if(m_jetcollections.find(jetcollection) == m_jetcollections.end()){
338  std::cout << " The jet collection [" << jetcollection << "] doesn't exist in " << tagger << " this CDI file!" << std::endl;
339  } else {
340  for(const auto& wp : m_metadata[tagger][jetcollection]){
341  wps.push_back(wp.first);
342  }
343  }
344  return wps;
345 }

◆ isWPdirectory()

bool Analysis::CDIReader::isWPdirectory ( TList *  list)
inlineprivate

Definition at line 143 of file CDIReader.h.

143  {
144  // check the directory (TList) contents
145  for(const auto label : *list){
146  const char* labelname = label->GetName();
147  if(strcmp(labelname, "B") == 0 || strcmp(labelname, "C") == 0
148  || strcmp(labelname, "Light") == 0 || strcmp(labelname, "T") == 0
149  || strcmp(labelname, "Z_BB") == 0 || strcmp(labelname, "QCD_BB") == 0
150  || strcmp(labelname, "Top_BX") == 0) return true;
151  }
152  return false;
153  }

◆ printDSIDs()

void Analysis::CDIReader::printDSIDs ( )
inline

Definition at line 81 of file CDIReader.h.

81  {
82  Labels DSIDs = getDSIDs(); // without arguments, will return the vector of DSIDs
83  std::cout << "number of DSIDs: " << DSIDs.size() << std::endl;
84  for(const std::string& el : DSIDs){
85  std::cout << el << ", ";
86  } std::cout << std::endl;
87  };

◆ printJetCollections()

void Analysis::CDIReader::printJetCollections ( )
inline

Definition at line 60 of file CDIReader.h.

60  {
61  std::cout << "number of jet collections: " << m_jetcollections.size() << std::endl;
62  for(const std::string& el : m_jetcollections){
63  std::cout << el << ", ";
64  } std::cout << std::endl;
65  }

◆ printLabels()

void Analysis::CDIReader::printLabels ( )
inline

Definition at line 74 of file CDIReader.h.

74  {
75  std::cout << "number of labels: " << m_labels.size() << std::endl;
76  for(const std::string& el : m_labels){
77  std::cout << el << ", ";
78  } std::cout << std::endl;
79  }

◆ printMetadata()

void Analysis::CDIReader::printMetadata ( int  tagger = -1,
int  jetcoll = -1,
int  wpoint = -1,
int  label = -1 
)
private

Definition at line 127 of file CDIReader.cxx.

127  {
128  /*
129  This method prints subsets of the available metadata collected from the CDI file.
130 
131  The CDI data is organized in a hierarchical directory structure, where taggers contain jet-collections, and jet-collections
132  contain working points, etc.
133 
134  This method prints wildcard data such as:
135  - tagger / *
136  - tagger / jetcoll/ *
137  - tagger / jetcoll/ wpoint / *
138  - tagger / jetcoll / wpoint / label
139 
140  The method operates on simple integer inputs, to indicate what to print out:
141  - Positive integer values for tagger, jetcoll, wpoint, and label (up to the number of available items of each)
142  will print out information specific to that particular entry (e.g. tagger == 1 will print tagger #1 specific info)
143  - Negative integer values indicate a wildcard, and will print out all available items of this type.
144  - Zero indicates to print nothing for that category.
145  */
146  int current_tagger = (tagger < 0) ? -1 : 0;
147  int current_jetcoll = (jetcoll < 0) ? -1 : 0;
148  int current_wpoint = (wpoint < 0) ? -1 : 0;
149  int current_label = (label < 0) ? -1 : 0;
150 
151  for (const auto& [tag, jets] : m_metadata){
152  if(current_tagger != -1) current_tagger += 1;
153  if(tagger != current_tagger || tagger == 0) continue;
154 
155  std::cout << "| " << tag << std::endl; // print only the tagger you're interested in
156 
157  for (const auto& [jet, wps] : jets){
158  if(current_jetcoll != -1) current_jetcoll += 1;
159  if(jetcoll != current_jetcoll || jetcoll == 0) continue;
160 
161  std::cout << "|\\__ " << jet << std::endl;
162 
163  int num_wps = wps.size();
164  int num_wp_seen = 0;
165  for(const auto& [wp, labels] : wps){
166  if(current_wpoint != -1) current_wpoint += 1;
167  if(wpoint != current_wpoint || wpoint == 0) continue;
168  num_wp_seen += 1;
169  if(num_wp_seen != num_wps){
170  std::cout << "| |\\__" << wp << std::endl;
171  } else {
172  std::cout << "| \\__" << wp << std::endl;
173  }
174 
175  int label_index = 0;
176  Data d = labels;
177  for(const std::string& l : d["labels"]){
178  if(current_label != -1) current_label += 1;
179  if(label != current_label || label == 0) continue;
180  if(num_wp_seen != num_wps && label_index == 0){
181  std::cout << "| | \\___" << " (" << label_index << ") " << l << std::endl;
182  } else if(label_index != 0 && num_wp_seen != num_wps) {
183  std::cout << "| | \\___" << " (" << label_index << ") " << l << std::endl;
184  } else {
185  std::cout << "| \\___" << " (" << label_index << ") " << l << std::endl;
186  }
187  label_index += 1;
188  }
189  }
190  }
191  }
192 }

◆ printTaggers()

void Analysis::CDIReader::printTaggers ( )
inline

Definition at line 53 of file CDIReader.h.

53  {
54  std::cout << "number of taggers: " << m_taggers.size() << std::endl;
55  for(const std::string& el : m_taggers){
56  std::cout << el << ", ";
57  } std::cout << std::endl;
58  }

◆ printWorkingPoints()

void Analysis::CDIReader::printWorkingPoints ( )
inline

Definition at line 67 of file CDIReader.h.

67  {
68  std::cout << "number of working points: " << m_workingpoints.size() << std::endl;
69  for(const std::string& el : m_workingpoints){
70  std::cout << el << ", ";
71  } std::cout << std::endl;
72  }

◆ record_metadata()

void Analysis::CDIReader::record_metadata ( const std::string &  datum,
int  depth = 0 
)
inlineprivate

Definition at line 113 of file CDIReader.h.

113  {
114  switch(depth){
115  case 0:
116  m_taggers.insert(datum);
117  break;
118  case 1:
119  m_jetcollections.insert(datum);
120  break;
121  case 2:
122  m_workingpoints.insert(datum);
123  break;
124  case 3:
125  m_labels.insert(datum);
126  break;
127  default:
128  std::cout << " record_metadata :: depth is " << depth << std::endl;
129  }
130  }

◆ record_metadata_map()

void Analysis::CDIReader::record_metadata_map ( const Data data,
const std::string &  path 
)
inlineprivate

Definition at line 132 of file CDIReader.h.

132  {
133  Labels metamap_path = split(path); // <"tagger", "jetcoll", "wp", "label">
134  int size = metamap_path.size();
135  if(size == 3){
136  m_metadata[metamap_path.at(0)][metamap_path.at(1)][metamap_path.at(2)] = data;
137  } else {
138  std::cout << " record_metadata_map :: the directory structure doesn't match what we expect!" << std::endl;
139  }
140  }

◆ split()

std::vector<std::string> Analysis::CDIReader::split ( const std::string &  str,
char  token = ';' 
)
inlineprivate

Definition at line 167 of file CDIReader.h.

167  {
168  std::vector<std::string> result;
169  if (str.size() > 0) {
170  std::string::size_type end;
171  std::string tmp(str);
172  do {
173  end = tmp.find(token);
174  std::string entry = trim(tmp.substr(0,end));
175  if (entry.size() > 0) result.push_back(entry);
176  if (end != std::string::npos) tmp = tmp.substr(end+1);
177  } while (end != std::string::npos);
178  }
179  return result;
180  }

◆ trim()

std::string Analysis::CDIReader::trim ( const std::string &  str,
const std::string &  whitespace = " \t" 
)
inlineprivate

Definition at line 156 of file CDIReader.h.

156  {
157  const auto strBegin = str.find_first_not_of(whitespace);
158  if (strBegin == std::string::npos){
159  return ""; // no content
160  }
161  const auto strEnd = str.find_last_not_of(whitespace);
162  const auto strRange = strEnd - strBegin + 1;
163  return str.substr(strBegin, strRange);
164  }

Member Data Documentation

◆ m_CDIFile

std::unique_ptr<TFile> Analysis::CDIReader::m_CDIFile
private

Definition at line 104 of file CDIReader.h.

◆ m_cdipath

std::string Analysis::CDIReader::m_cdipath = ""
private

Definition at line 103 of file CDIReader.h.

◆ m_DSIDs

std::set<std::string> Analysis::CDIReader::m_DSIDs {}
private

Definition at line 109 of file CDIReader.h.

◆ m_initialized

bool Analysis::CDIReader::m_initialized = false
private

flag whether the initialization has been carried out

Definition at line 100 of file CDIReader.h.

◆ m_jetcollections

std::set<std::string> Analysis::CDIReader::m_jetcollections {}
private

Definition at line 106 of file CDIReader.h.

◆ m_label_vec

Labels Analysis::CDIReader::m_label_vec
private

Definition at line 182 of file CDIReader.h.

◆ m_labels

std::set<std::string> Analysis::CDIReader::m_labels {}
private

Definition at line 108 of file CDIReader.h.

◆ m_metadata

Meta Analysis::CDIReader::m_metadata
private

Definition at line 183 of file CDIReader.h.

◆ m_taggers

std::set<std::string> Analysis::CDIReader::m_taggers {}
private

Definition at line 105 of file CDIReader.h.

◆ m_use_json

bool Analysis::CDIReader::m_use_json = false
private

Definition at line 101 of file CDIReader.h.

◆ m_workingpoints

std::set<std::string> Analysis::CDIReader::m_workingpoints {}
private

Definition at line 107 of file CDIReader.h.


The documentation for this class was generated from the following files:
Analysis::CDIReader::m_use_json
bool m_use_json
Definition: CDIReader.h:101
TrigJetMonitorAlgorithm.jetcoll
jetcoll
Definition: TrigJetMonitorAlgorithm.py:1219
data
char data[hepevt_bytes_allocation_ATLAS]
Definition: HepEvt.cxx:11
Analysis::CDIReader::m_taggers
std::set< std::string > m_taggers
Definition: CDIReader.h:105
Analysis::CDIReader::m_metadata
Meta m_metadata
Definition: CDIReader.h:183
egammaParameters::depth
@ depth
pointing depth of the shower as calculated in egammaqgcld
Definition: egammaParamDefs.h:276
python.SystemOfUnits.s
int s
Definition: SystemOfUnits.py:131
get_generator_info.result
result
Definition: get_generator_info.py:21
athena.path
path
python interpreter configuration --------------------------------------—
Definition: athena.py:128
Analysis::CDIReader::m_jetcollections
std::set< std::string > m_jetcollections
Definition: CDIReader.h:106
json
nlohmann::json json
Definition: HistogramDef.cxx:9
hist_file_dump.d
d
Definition: hist_file_dump.py:143
Analysis::CDIReader::isWPdirectory
bool isWPdirectory(TList *list)
Definition: CDIReader.h:143
Analysis::CDIReader::Labels
std::vector< std::string > Labels
Definition: CDIReader.h:41
Analysis::CDIReader::getDSIDs
Labels getDSIDs(const std::string &tagger="", const std::string &jetcollection="", const std::string &workingpoint="")
Definition: CDIReader.cxx:264
Analysis::CDIReader::m_DSIDs
std::set< std::string > m_DSIDs
Definition: CDIReader.h:109
defineDB.jets
jets
Definition: JetTagCalibration/share/defineDB.py:24
ParseInputs.flavourDir
flavourDir
Definition: Final2012/ParseInputs.py:46
UploadAMITag.l
list l
Definition: UploadAMITag.larcaf.py:158
XMLtoHeader.count
count
Definition: XMLtoHeader.py:85
mergePhysValFiles.end
end
Definition: DataQuality/DataQualityUtils/scripts/mergePhysValFiles.py:93
Analysis::CDIReader::split
std::vector< std::string > split(const std::string &str, char token=';')
Definition: CDIReader.h:167
python.setupRTTAlg.size
int size
Definition: setupRTTAlg.py:39
beamspotnt.labels
list labels
Definition: bin/beamspotnt.py:1447
jet
Definition: JetCalibTools_PlotJESFactors.cxx:23
Analysis::CalibrationDataContainer::listUncertainties
std::vector< std::string > listUncertainties() const
retrieve the list of "uncertainties" accessible to this object.
Definition: CalibrationDataContainer.cxx:120
Analysis::CDIReader::crawlCDI
void crawlCDI(TDirectoryFile *parentDir, int depth=0, const std::string &metamap="")
Definition: CDIReader.cxx:35
add-xsec-uncert-quadrature-N.label
label
Definition: add-xsec-uncert-quadrature-N.py:104
Analysis::CDIReader::m_cdipath
std::string m_cdipath
Definition: CDIReader.h:103
ftag::defaults::tagger
const std::string tagger
Definition: ToolDefaults.h:11
plotIsoValidation.el
el
Definition: plotIsoValidation.py:197
histSizes.list
def list(name, path='/')
Definition: histSizes.py:38
GetAllXsec.DSID
tuple DSID
Definition: GetAllXsec.py:53
DeMoUpdate.tmp
string tmp
Definition: DeMoUpdate.py:1167
PlotSFuncertainty.wp
wp
Definition: PlotSFuncertainty.py:112
Analysis::CDIReader::m_CDIFile
std::unique_ptr< TFile > m_CDIFile
Definition: CDIReader.h:104
beamspotman.dir
string dir
Definition: beamspotman.py:623
merge.output
output
Definition: merge.py:17
GetAllXsec.entry
list entry
Definition: GetAllXsec.py:132
Analysis::CDIReader::m_workingpoints
std::set< std::string > m_workingpoints
Definition: CDIReader.h:107
Analysis::CalibrationDataHistogramContainer
Definition: CalibrationDataContainer.h:247
Analysis::CDIReader::trim
std::string trim(const std::string &str, const std::string &whitespace=" \t")
Definition: CDIReader.h:156
cwd
std::string cwd
Definition: listroot.cxx:38
Analysis::CDIReader::m_label_vec
Labels m_label_vec
Definition: CDIReader.h:182
Analysis::CDIReader::printMetadata
void printMetadata(int tagger=-1, int jetcoll=-1, int wpoint=-1, int label=-1)
Definition: CDIReader.cxx:127
Analysis::CDIReader::m_initialized
bool m_initialized
flag whether the initialization has been carried out
Definition: CDIReader.h:100
Analysis::CDIReader::record_metadata
void record_metadata(const std::string &datum, int depth=0)
Definition: CDIReader.h:113
Analysis::CDIReader::Data
std::map< std::string, Labels > Data
Definition: CDIReader.h:42
std::sort
void sort(typename std::reverse_iterator< DataModel_detail::iterator< DVL > > beg, typename std::reverse_iterator< DataModel_detail::iterator< DVL > > end, const Compare &comp)
Specialization of sort for DataVector/List.
Definition: DVL_algorithms.h:623
python.TriggerHandler.verbose
verbose
Definition: TriggerHandler.py:297
Analysis::CDIReader::record_metadata_map
void record_metadata_map(const Data &data, const std::string &path)
Definition: CDIReader.h:132
Analysis::CDIReader::m_labels
std::set< std::string > m_labels
Definition: CDIReader.h:108
str
Definition: BTagTrackIpAccessor.cxx:11
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:798
calibdata.copy
bool copy
Definition: calibdata.py:27
CaloCondBlobAlgs_fillNoiseFromASCII.tag
string tag
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:24