LDMX Software
EcalGeometryProvider.cxx
Go to the documentation of this file.
1#include <regex.h>
2#include <sys/types.h>
3
7#include "Framework/RunHeader.h"
8
15namespace ecal {
16
18 public:
24 EcalGeometryProvider(const std::string& name, const std::string& tagname,
25 const framework::config::Parameters& parameters,
27
29 virtual ~EcalGeometryProvider();
30
37 virtual std::pair<const framework::ConditionsObject*,
39 getCondition(const ldmx::EventHeader& context);
40
46
47 virtual void onNewRun(ldmx::RunHeader& rh) {
48 if (detector_geometry_.empty())
50 else if (ecal_geometry_ != nullptr &&
52 EXCEPTION_RAISE(
53 "GeometryException",
54 "Attempting to run a single job with multiple geometries " +
55 detector_geometry_ + " and '" + rh.getDetectorName() + "'");
56 }
57 // make sure detector name has been set
58 if (detector_geometry_.empty())
59 EXCEPTION_RAISE("GeometryException",
60 "EcalGeometryProvider unable to get the name of the "
61 "detector from the RunHeader.");
62 }
63
64 private:
66 std::vector<framework::config::Parameters> geometries_;
68 std::string detector_geometry_;
69 ldmx::EcalGeometry* ecal_geometry_;
70};
71
73 const std::string& name, const std::string& tagname,
74 const framework::config::Parameters& parameters,
75 framework::Process& process)
77 ldmx::EcalGeometry::CONDITIONS_OBJECT_NAME, tagname, parameters,
78 process} {
80 parameters.get<std::vector<framework::config::Parameters>>("geometries");
81 ecal_geometry_ = 0;
82}
83
85 if (ecal_geometry_) delete ecal_geometry_;
86 ecal_geometry_ = 0;
87}
88
89std::pair<const framework::ConditionsObject*, framework::ConditionsIOV>
91 static const std::string keyname("detectors_valid");
92
93 if (!ecal_geometry_) {
94 // search through the subtrees
95 for (auto pver : geometries_) {
96 if (!pver.exists(keyname)) {
97 ldmx_log(warn) << "No parameter " << keyname
98 << " found one of the detector vesrsions.";
99 // log strange situation and continue
100 continue;
101 }
102
103 std::vector<std::string> dets_valid =
104 pver.get<std::vector<std::string>>(keyname);
105 for (auto detregex : dets_valid) {
106 std::string regex(detregex);
107 if (regex.empty()) continue; // no empty regex allowed
108 if (regex[0] != '^') regex.insert(0, 1, '^');
109 if (regex.back() != '$') regex += '$';
110 regex_t reg;
111
112 int rv =
113 regcomp(&reg, regex.c_str(), REG_EXTENDED | REG_ICASE | REG_NOSUB);
114 if (rv) {
115 char err[1024];
116 regerror(rv, &reg, err, 1024);
117 EXCEPTION_RAISE(
118 "GeometryException",
119 "Invalid detector regular expression : '" + regex + "' " + err);
120 }
121 int nmatch = regexec(&reg, detector_geometry_.c_str(), 0, 0, 0);
122 regfree(&reg);
123 if (!nmatch) {
124 ecal_geometry_ = new ldmx::EcalGeometry(pver);
125 break;
126 }
127 }
128 if (ecal_geometry_) break;
129 }
130 if (!ecal_geometry_) {
131 EXCEPTION_RAISE("GeometryException", "Unable to create EcalGeometry");
132 }
133 }
134
135 return std::make_pair(
136 ecal_geometry_,
137 framework::ConditionsIOV(context.getRun(), context.getRun(), true, true));
138}
139
140} // namespace ecal
141
Base class for provider of conditions information like pedestals, gains, electronics maps,...
#define DECLARE_CONDITIONS_PROVIDER(CLASS)
Macro which allows the framework to construct a producer given its name during configuration.
Class that translates raw positions of ECal module hits into cells in a hexagonal readout.
Class that provides header information about an event such as event number and timestamp.
be configured to load conditions objects from CSV files.
virtual ~EcalGeometryProvider()
Destructor.
EcalGeometryProvider(const std::string &name, const std::string &tagname, const framework::config::Parameters &parameters, framework::Process &process)
Class constructor.
virtual std::pair< const framework::ConditionsObject *, framework::ConditionsIOV > getCondition(const ldmx::EventHeader &context)
Provides access to the EcalGeometry or EcalTriggerGeometry.
std::string detector_geometry_
Geometry as last used.
std::vector< framework::config::Parameters > geometries_
parameters for the various geometry versions we can support
virtual void releaseConditionsObject(const framework::ConditionsObject *co)
Take no action on release, as the object is permanently owned by the Provider.
virtual void onNewRun(ldmx::RunHeader &rh)
Callback for the ConditionsObjectProvider to take any necessary action when the processing of events ...
Class which defines the run/event/type range for which a given condition is valid,...
Base class for all providers of conditions objects.
const Process & process() const
Get the process handle.
Base class for all conditions objects, very simple.
Class which represents the process under execution.
Definition Process.h:36
Class encapsulating parameters for configuring a processor.
Definition Parameters.h:29
const T & get(const std::string &name) const
Retrieve the parameter of the given name.
Definition Parameters.h:78
Translation between real-space positions and cell IDs within the ECal.
Provides header information an event such as event number and timestamp.
Definition EventHeader.h:44
int getRun() const
Return the run number.
Definition EventHeader.h:84
Run-specific configuration and data stored in its own output TTree alongside the event TTree in the o...
Definition RunHeader.h:57
const std::string & getDetectorName() const
Definition RunHeader.h:80
All classes in the ldmx-sw project use this namespace.