LDMX Software
ecal::EcalGeometryProvider Class Reference

Public Member Functions

 EcalGeometryProvider (const std::string &name, const std::string &tagname, const framework::config::Parameters &parameters, framework::Process &process)
 Class constructor.
 
virtual ~EcalGeometryProvider ()
 Destructor.
 
virtual std::pair< const framework::ConditionsObject *, framework::ConditionsIOVgetCondition (const ldmx::EventHeader &context)
 Provides access to the EcalGeometry or EcalTriggerGeometry.
 
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 starts for a given run.
 
- Public Member Functions inherited from framework::ConditionsObjectProvider
 DECLARE_FACTORY (ConditionsObjectProvider, std::shared_ptr< ConditionsObjectProvider >, const std::string &, const std::string &, const framework::config::Parameters &, Process &)
 declare that we have a factory for these types of classes
 
 ConditionsObjectProvider (const std::string &objname, const std::string &tagname, const framework::config::Parameters &parameters, Process &process)
 Class constructor.
 
virtual ~ConditionsObjectProvider ()=default
 Class destructor.
 
virtual void onProcessStart ()
 Callback for the ConditionsObjectProvider to take any necessary action when the processing of events starts.
 
virtual void onProcessEnd ()
 Callback for the ConditionsObjectProvider to take any necessary action when the processing of events finishes, such as closing database connections.
 
const std::string & getConditionObjectName () const
 Get the list of conditions objects available from this provider.
 
const std::string & getTagName () const
 Access the tag name.
 

Private Attributes

std::vector< framework::config::Parametersgeometries_
 parameters for the various geometry versions we can support
 
std::string detector_geometry_
 Geometry as last used.
 
ldmx::EcalGeometryecal_geometry_
 

Additional Inherited Members

- Protected Member Functions inherited from framework::ConditionsObjectProvider
std::pair< const ConditionsObject *, ConditionsIOVrequestParentCondition (const std::string &name, const ldmx::EventHeader &context)
 Request another condition needed to construct this condition.
 
const Processprocess () const
 Get the process handle.
 
- Protected Attributes inherited from framework::ConditionsObjectProvider
logging::logger the_log_
 The logger for this ConditionsObjectProvider.
 

Detailed Description

Definition at line 17 of file EcalGeometryProvider.cxx.

Constructor & Destructor Documentation

◆ EcalGeometryProvider()

ecal::EcalGeometryProvider::EcalGeometryProvider ( const std::string & name,
const std::string & tagname,
const framework::config::Parameters & parameters,
framework::Process & process )

Class constructor.

Parameters
parameters– uses the "EcalGeometry" section to configure the EcalGeometry

Definition at line 72 of file EcalGeometryProvider.cxx.

77 ldmx::EcalGeometry::CONDITIONS_OBJECT_NAME, tagname, parameters,
78 process} {
80 parameters.get<std::vector<framework::config::Parameters>>("geometries");
81 ecal_geometry_ = 0;
82}
std::vector< framework::config::Parameters > geometries_
parameters for the various geometry versions we can support
Base class for all providers of conditions objects.
const Process & process() const
Get the process handle.
const T & get(const std::string &name) const
Retrieve the parameter of the given name.
Definition Parameters.h:78

References geometries_, and framework::config::Parameters::get().

◆ ~EcalGeometryProvider()

ecal::EcalGeometryProvider::~EcalGeometryProvider ( )
virtual

Destructor.

Definition at line 84 of file EcalGeometryProvider.cxx.

84 {
85 if (ecal_geometry_) delete ecal_geometry_;
86 ecal_geometry_ = 0;
87}

Member Function Documentation

◆ getCondition()

std::pair< const framework::ConditionsObject *, framework::ConditionsIOV > ecal::EcalGeometryProvider::getCondition ( const ldmx::EventHeader & context)
virtual

Provides access to the EcalGeometry or EcalTriggerGeometry.

Note
Currently, these are assumed to be valid for all time, but this behavior could be changed. Users should not cache the pointer between events

Implements framework::ConditionsObjectProvider.

Definition at line 90 of file EcalGeometryProvider.cxx.

90 {
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}
std::string detector_geometry_
Geometry as last used.
Class which defines the run/event/type range for which a given condition is valid,...
Translation between real-space positions and cell IDs within the ECal.
int getRun() const
Return the run number.
Definition EventHeader.h:84

References detector_geometry_, geometries_, and ldmx::EventHeader::getRun().

◆ onNewRun()

virtual void ecal::EcalGeometryProvider::onNewRun ( ldmx::RunHeader & )
inlinevirtual

Callback for the ConditionsObjectProvider to take any necessary action when the processing of events starts for a given run.

Reimplemented from framework::ConditionsObjectProvider.

Definition at line 47 of file EcalGeometryProvider.cxx.

47 {
48 if (detector_geometry_.empty())
49 detector_geometry_ = rh.getDetectorName();
50 else if (ecal_geometry_ != nullptr &&
51 detector_geometry_ != rh.getDetectorName()) {
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 }

References detector_geometry_, and ldmx::RunHeader::getDetectorName().

◆ releaseConditionsObject()

virtual void ecal::EcalGeometryProvider::releaseConditionsObject ( const framework::ConditionsObject * co)
inlinevirtual

Take no action on release, as the object is permanently owned by the Provider.

Reimplemented from framework::ConditionsObjectProvider.

Definition at line 45 of file EcalGeometryProvider.cxx.

45{}

Member Data Documentation

◆ detector_geometry_

std::string ecal::EcalGeometryProvider::detector_geometry_
private

Geometry as last used.

Definition at line 68 of file EcalGeometryProvider.cxx.

Referenced by getCondition(), and onNewRun().

◆ ecal_geometry_

ldmx::EcalGeometry* ecal::EcalGeometryProvider::ecal_geometry_
private

Definition at line 69 of file EcalGeometryProvider.cxx.

◆ geometries_

std::vector<framework::config::Parameters> ecal::EcalGeometryProvider::geometries_
private

parameters for the various geometry versions we can support

Definition at line 66 of file EcalGeometryProvider.cxx.

Referenced by EcalGeometryProvider(), and getCondition().


The documentation for this class was generated from the following file: