ATLAS Offline Software
Loading...
Searching...
No Matches
egammaTransformerCalibTool Class Reference

A tool used by the egammaMVASvc to help calibrate energy for one particle type. More...

#include <egammaTransformerCalibTool.h>

Inheritance diagram for egammaTransformerCalibTool:
Collaboration diagram for egammaTransformerCalibTool:

Public Member Functions

 egammaTransformerCalibTool (const std::string &type)
virtual ~egammaTransformerCalibTool () override
virtual StatusCode initialize () override
 Dummy implementation of the initialisation function.
float getEnergy (const xAOD::CaloCluster &clus, const xAOD::Egamma *eg, const egammaMVACalib::GlobalEventInfo &gei=egammaMVACalib::GlobalEventInfo()) const override final
 returns the calibrated energy
virtual void print () const
 Print the state of the tool.
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual StatusCode sysInitialize () override
 Perform system initialization for an algorithm.
virtual StatusCode sysStart () override
 Handle START transition.
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles.
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles.
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T, V, H > &t)
void updateVHKA (Gaudi::Details::PropertyBase &)
MsgStream & msg () const
bool msgLvl (const MSG::Level lvl) const
Additional helper functions, not directly mimicking Athena
template<class T>
const T * getProperty (const std::string &name) const
 Get one of the tool's properties.
const std::string & msg_level_name () const __attribute__((deprecated))
 A deprecated function for getting the message level's name.
const std::string & getName (const void *ptr) const
 Get the name of an object that is / should be in the event store.
SG::sgkey_t getKey (const void *ptr) const
 Get the (hashed) key of an object that is in the event store.

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce (T &h)
void extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps)
 Add StoreName to extra input/output deps as needed.

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

StatusCode setupTransformerModel (const std::string &fileName)
 a utility to set up the transformer model, separated from initialize for better readability
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

Gaudi::Property< int > m_particleType
Gaudi::Property< bool > m_clusterEif0
Gaudi::Property< std::string > m_folder
 string with folder for weight files
Gaudi::Property< bool > m_isMC {this, "isMC", false, "Whether the input file is MC or data"}
 Layer calibration related properties.
Gaudi::Property< bool > m_useLayerCorrected
Gaudi::Property< std::string > m_layerCalibTune
Gaudi::Property< bool > m_useSaccCorrection
Gaudi::Property< bool > m_useFixForMissingCells
Gaudi::Property< bool > m_useExtraLayerScales
Gaudi::Property< std::string > m_electronModelFile
Gaudi::Property< std::string > m_unconvertedPhotonModelFile
Gaudi::Property< std::string > m_convertedPhotonModelFile
Gaudi::Property< std::string > m_forwardElectronModelFile
std::unique_ptr< const FlavorTagInference::SaltModelm_saltModel
int m_num_cluster_features = 0
int m_num_cell_features = 0
std::unique_ptr< egammaLayerRecalibToolm_layerRecalibTool = nullptr
ToolHandle< IegammaCellRecoveryToolm_egammaCellRecoveryTool
 Pointer to the egammaCellRecoveryTool.
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default).
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default).
std::vector< SG::VarHandleKeyArray * > m_vhka
bool m_varHandleArraysDeclared

Static Private Attributes

static constexpr double m_timeCut = 12.

Detailed Description

A tool used by the egammaMVASvc to help calibrate energy for one particle type.

The particle type to be calibrated must be specified by the property ParticleType. The property folder must be set with the path to a folder containig three transformer model in onnx format Since Transformer use cells directly as input, layer calibration will be applied to one of the decorator and another decorator will not have layer calibration applied. On data the property use_layer_corrected should be set to true. In reconstruction this flag is always false. In PhysicsAnalysis it should be set appropriately. When set to true when using the layer energies as input the data-driver-corrected version are used.

Public members of this function is kept same as BDT for interface consistency.

Definition at line 50 of file egammaTransformerCalibTool.h.

Member Typedef Documentation

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< AlgTool > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Constructor & Destructor Documentation

◆ egammaTransformerCalibTool()

egammaTransformerCalibTool::egammaTransformerCalibTool ( const std::string & type)

Definition at line 32 of file egammaTransformerCalibTool.cxx.

32 :
33 asg::AsgTool(name)
34{
35}

◆ ~egammaTransformerCalibTool()

egammaTransformerCalibTool::~egammaTransformerCalibTool ( )
overridevirtual

Definition at line 39 of file egammaTransformerCalibTool.cxx.

40{
41}

Member Function Documentation

◆ declareGaudiProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T, V, H > & hndl,
const SG::VarHandleKeyType &  )
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKey>

Definition at line 156 of file AthCommonDataStore.h.

158 {
160 hndl.value(),
161 hndl.documentation());
162
163 }
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)

◆ declareProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( Gaudi::Property< T, V, H > & t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145 {
146 typedef typename SG::HandleClassifier<T>::type htype;
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>

◆ detStore()

const ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< AlgTool > >::detStore ( ) const
inlineinherited

The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 95 of file AthCommonDataStore.h.

◆ evtStore()

ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore ( )
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 85 of file AthCommonDataStore.h.

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::extraDeps_update_handler ( Gaudi::Details::PropertyBase & ExtraDeps)
protectedinherited

Add StoreName to extra input/output deps as needed.

use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given

◆ getEnergy()

float egammaTransformerCalibTool::getEnergy ( const xAOD::CaloCluster & clus,
const xAOD::Egamma * eg,
const egammaMVACalib::GlobalEventInfo & gei = egammaMVACalib::GlobalEventInfo() ) const
finaloverridevirtual

returns the calibrated energy

Implements IegammaMVACalibTool.

Definition at line 166 of file egammaTransformerCalibTool.cxx.

169{
170 // 0. Safety Checks
171 if (!m_saltModel || !eg) {
172 if (m_clusterEif0) {
173 ATH_MSG_WARNING("Model not loaded or Egamma pointer is null, returning cluster energy");
174 return clus.e();
175 } else {
176 ATH_MSG_FATAL("Model not loaded or Egamma pointer is null, and useClusterIf0 is false, cannot proceed");
177 return 0.0f;
178 }
179 }
180
181 // --- 1. Cell Recovery (Timing Cut Fix) ---
182 IegammaCellRecoveryTool::Info recoveryInfo;
183 bool recoverySucceeded = true;
184 if (!m_egammaCellRecoveryTool.empty()) {
185 egammaCellUtils::MaxECell maxECell(&clus);
186 if (maxECell.sc == StatusCode::FAILURE) {
187 ATH_MSG_WARNING("Issues in finding maximum energy cell.");
188 recoverySucceeded = false;
189 } else {
190 recoveryInfo.etamax = maxECell.etaCell;
191 recoveryInfo.phimax = maxECell.phiCell;
192 if (m_egammaCellRecoveryTool->execute(clus, recoveryInfo).isFailure()) {
193 ATH_MSG_WARNING("Cell Recovery Tool failed. Proceeding without recovered cells.");
194 recoverySucceeded = false;
195 }
196 }
197 }
198
199 // --- 2. Apply Layer Calibration if needed ---
201 auto array_layer_scales = std::array<double, 4>{1.0, 1.0, 1.0, 1.0}; // default scales
202
203 if (m_layerRecalibTool && !m_isMC && !isForward) {
204 ATH_MSG_DEBUG("Applying layer recalibration for GNN on data.");
205
206 // Apply correction to the new, non-const object
207 const xAOD::EventInfo* eventInfo = gei.eventInfo;
208 array_layer_scales = m_layerRecalibTool->getLayerCorrections(*eg, *eventInfo);
209 }
210
211 if ( m_useExtraLayerScales ) {
212 ATH_MSG_DEBUG("Applying extra layer scales for systematic studies, normally this is for MC events.");
213 if ( !m_isMC ) {
214 ATH_MSG_WARNING("You are applying extra layer scales but the input is not MC! Are you sure this is intended?");
215 }
216 // extract scales from global event info
217 for (std::size_t i = 0; i < 4; ++i)
218 array_layer_scales[i] *= gei.scaleEs[i];
219 }
220
221 // --- 3. Calculate Scale Factors ---
222
223 // Raw energies + Recovered Energy (Timing Fix)
224 // double raw_Es0 = clus.energyBE(0); // LG: not sure if this is still needed but keeping it here for consistency
225 double raw_Es1 = clus.energyBE(1);
226 double raw_Es2 = clus.energyBE(2) + (recoverySucceeded && m_useFixForMissingCells ? recoveryInfo.eCells[0] : 0.0);
227 double raw_Es3 = clus.energyBE(3) + (recoverySucceeded && m_useFixForMissingCells ? recoveryInfo.eCells[1] : 0.0);
228
229 // --- 4. Cell Gathering ---
230 std::vector<float> cells_E, cells_eta, cells_phi, cells_x, cells_y, cells_z;
231 std::vector<int> cells_layer;
232 std::vector<Identifier> included_cells; // Track cells to avoid duplicates
233
234 // Layer sums
235 double sum_cell_E_L0 = 0.0, sum_cell_E_L1 = 0.0, sum_cell_E_L2 = 0.0, sum_cell_E_L3 = 0.0, sum_cell_E_Gap = 0.0;
236
237 // A. Iterate over Standard Cluster Cells
238 const CaloClusterCellLink* cellLinks = clus.getCellLinks();
239 if (cellLinks) {
240 for (const CaloCell* cell : *cellLinks) {
241 if (!cell) continue;
242
243 int sampling = cell->caloDDE()->getSampling();
244 double scale_factor = 1.0;
245 int layer_idx = -1;
246
247 switch (sampling) {
248 case CaloCell_ID::PreSamplerB: case CaloCell_ID::PreSamplerE:
249 scale_factor = array_layer_scales[0]; layer_idx = 0; break;
250 case CaloCell_ID::EMB1: case CaloCell_ID::EME1:
251 scale_factor = array_layer_scales[1]; layer_idx = 1; break;
252 case CaloCell_ID::EMB2: case CaloCell_ID::EME2:
253 scale_factor = array_layer_scales[2]; layer_idx = 2;
254 // Track cells that might be already recovered (those with time > timing cut)
255 if (cell->time() > m_timeCut) { // Use your actual timing cut threshold
256 included_cells.push_back(cell->ID());
257 }
258 break;
259 case CaloCell_ID::EMB3: case CaloCell_ID::EME3:
260 scale_factor = array_layer_scales[3]; layer_idx = 3;
261 if (cell->time() > m_timeCut) {
262 included_cells.push_back(cell->ID());
263 }
264 break;
265 case CaloCell_ID::TileGap3:
266 scale_factor = 1.0; layer_idx = 4; break;
267 default: continue;
268 }
269
270 double final_E = cell->e() * scale_factor;
271
272 cells_E.push_back(final_E);
273 cells_eta.push_back(cell->eta());
274 cells_phi.push_back(cell->phi());
275 cells_x.push_back(cell->x());
276 cells_y.push_back(cell->y());
277 cells_z.push_back(cell->z());
278 cells_layer.push_back(layer_idx);
279
280 // Accumulate Sums
281 switch(layer_idx) {
282 case 0: sum_cell_E_L0 += final_E; break;
283 case 1: sum_cell_E_L1 += final_E; break;
284 case 2: sum_cell_E_L2 += final_E; break;
285 case 3: sum_cell_E_L3 += final_E; break;
286 case 4: sum_cell_E_Gap += final_E; break;
287 }
288 }
289 }
290
291 // B. Iterate over Recovered Cells (from Tool) - Skip Duplicates
292 // Added cells are only expected in layers 2 and 3, so the dedup list only tracks those layers.
293 for (const CaloCell* cell : recoveryInfo.addedCells) {
294 if (!cell || !cell->caloDDE()) continue;
295
296 // Skip if this cell is already in the cluster
297 if (std::find(included_cells.begin(), included_cells.end(), cell->ID()) != included_cells.end()) {
298 ATH_MSG_WARNING("Recovered cell " << cell->ID() << " already included in cluster. Skipping to avoid double counting.");
299 continue;
300 }
301 else {
302 ATH_MSG_DEBUG("Adding recovered cell " << cell->ID() << " to cluster inputs.");
303 }
304
305 int sampling = cell->caloDDE()->getSampling();
306 double scale_factor = 1.0;
307 int layer_idx = -1;
308
309 if (sampling == CaloCell_ID::EMB2 || sampling == CaloCell_ID::EME2) {
310 scale_factor = array_layer_scales[2]; layer_idx = 2;
311 } else if (sampling == CaloCell_ID::EMB3 || sampling == CaloCell_ID::EME3) {
312 scale_factor = array_layer_scales[3]; layer_idx = 3;
313 } else {
314 // Fallback
315 if (sampling == CaloCell_ID::PreSamplerB || sampling == CaloCell_ID::PreSamplerE) {
316 scale_factor = array_layer_scales[0]; layer_idx = 0;
317 } else if (sampling == CaloCell_ID::EMB1 || sampling == CaloCell_ID::EME1) {
318 scale_factor = array_layer_scales[1]; layer_idx = 1;
319 } else {
320 continue;
321 }
322 }
323
324 double final_E = cell->e() * scale_factor;
325
326 cells_E.push_back(final_E);
327 cells_eta.push_back(cell->eta());
328 cells_phi.push_back(cell->phi());
329 cells_x.push_back(cell->x());
330 cells_y.push_back(cell->y());
331 cells_z.push_back(cell->z());
332 cells_layer.push_back(layer_idx);
333
334 switch(layer_idx) {
335 case 0: sum_cell_E_L0 += final_E; break;
336 case 1: sum_cell_E_L1 += final_E; break;
337 case 2: sum_cell_E_L2 += final_E; break;
338 case 3: sum_cell_E_L3 += final_E; break;
339 case 4: sum_cell_E_Gap += final_E; break;
340 }
341 }
342
343 // --- 5. Calculate Derived Features (Post-Loop) ---
344 const size_t nCells = cells_E.size();
345 if (nCells == 0) return 0.0f;
346
347 double sum_cell_E_total = sum_cell_E_L0 + sum_cell_E_L1 + sum_cell_E_L2 + sum_cell_E_L3;
348 const double cluster_eta = clus.eta();
349 const double cluster_phi = clus.phi();
350
351 std::vector<float> cells_deta, cells_dphi, cells_eFrac;
352 cells_deta.reserve(nCells);
353 cells_dphi.reserve(nCells);
354 cells_eFrac.reserve(nCells);
355
356 for (size_t i = 0; i < nCells; ++i) {
357 float deta = cells_eta[i] - cluster_eta;
358 float dphi = cells_phi[i] - cluster_phi;
359 dphi = std::fmod(dphi + 3.0f * M_PI, 2.0f * M_PI) - M_PI;
360
361 cells_deta.push_back(deta);
362 cells_dphi.push_back(dphi);
363
364 float eFrac_layer = 0.0f;
365 switch (cells_layer[i]) {
366 case 0: eFrac_layer = (sum_cell_E_L0 != 0) ? (cells_E[i] / sum_cell_E_L0) : 0.0f; break;
367 case 1: eFrac_layer = (sum_cell_E_L1 != 0) ? (cells_E[i] / sum_cell_E_L1) : 0.0f; break;
368 case 2: eFrac_layer = (sum_cell_E_L2 != 0) ? (cells_E[i] / sum_cell_E_L2) : 0.0f; break;
369 case 3: eFrac_layer = (sum_cell_E_L3 != 0) ? (cells_E[i] / sum_cell_E_L3) : 0.0f; break;
370 case 4: eFrac_layer = (sum_cell_E_Gap != 0) ? (cells_E[i] / sum_cell_E_Gap) : 0.0f; break;
371 }
372 cells_eFrac.push_back(eFrac_layer);
373 }
374
375 // --- 6. Prepare GNN Inputs and Run Inference ---
376 double ratio_L1_L2 = (sum_cell_E_L2 != 0) ? (sum_cell_E_L1 / sum_cell_E_L2) : 0.0;
377 double main_layers_sum = sum_cell_E_L1 + sum_cell_E_L2 + sum_cell_E_L3;
378 double ratio_L0_total = (main_layers_sum != 0) ? (sum_cell_E_L0 / main_layers_sum) : 0.0;
379 double ratio_Tile_total = (main_layers_sum != 0) ? (sum_cell_E_Gap / main_layers_sum) : 0.0;
380
382
383 // Cluster Features
384 std::vector<float> cluster_feats = {
385 static_cast<float>(sum_cell_E_total),
386 static_cast<float>(sum_cell_E_L0),
387 static_cast<float>(sum_cell_E_L1),
388 static_cast<float>(sum_cell_E_L2),
389 static_cast<float>(sum_cell_E_L3),
390 static_cast<float>(sum_cell_E_Gap),
391 static_cast<float>(cluster_eta),
392 static_cast<float>(cluster_phi),
393 static_cast<float>(ratio_L1_L2),
394 static_cast<float>(ratio_L0_total),
395 static_cast<float>(ratio_Tile_total)
396 };
397
398 // For converted photons, append conversion-specific features in order: convR, convEtOverPt, convPtRatio, conversionType.
400 const xAOD::Photon* photon = dynamic_cast<const xAOD::Photon*>(eg);
401 if (photon) {
402 // - convR
403 float convR = 799.0f;
404 if (egammaMVAFunctions::compute_ptconv(photon) > 3 * GeV) {
406 }
407
408 // - convEtOverPt
409 float convEtOverPt = 0.0f;
410 float ptconv = egammaMVAFunctions::compute_ptconv(photon);
411 if (xAOD::EgammaHelpers::numberOfSiTracks(photon) == 2 && ptconv > 0.0f) {
412 float eacc = (m_useLayerCorrected ?
413 (raw_Es1 * array_layer_scales[1] + raw_Es2 * array_layer_scales[2] + raw_Es3 * array_layer_scales[3]) :
414 (raw_Es1 + raw_Es2 + raw_Es3));
415 float cl_eta = eg->caloCluster()->eta();
416 convEtOverPt = std::max(0.0f, eacc / (std::cosh(cl_eta) * ptconv));
417 }
418 convEtOverPt = std::min(convEtOverPt, 2.0f);
419
420 // - convPtRatio
421 float convPtRatio = 1.0f;
422 if (xAOD::EgammaHelpers::numberOfSiTracks(photon) == 2) {
423 float pt1 = egammaMVAFunctions::compute_pt1conv(photon);
424 float pt2 = egammaMVAFunctions::compute_pt2conv(photon);
425 if ((pt1 + pt2) > 0.0f) {
426 convPtRatio = std::max(pt1, pt2) / (pt1 + pt2);
427 }
428 }
429
430 // - conversionType
431 float conversionType = static_cast<float>(photon->conversionType());
432 // must push back in this order as the model expects features in this order
433 cluster_feats.push_back(convR);
434 cluster_feats.push_back(convEtOverPt);
435 cluster_feats.push_back(convPtRatio);
436 cluster_feats.push_back(conversionType);
437 } else {
438 cluster_feats.push_back(0.0f);
439 cluster_feats.push_back(0.0f);
440 cluster_feats.push_back(0.0f);
441 cluster_feats.push_back(0.0f);
442 }
443 }
444
445
446 gnn_input["cluster_features"] = FlavorTagInference::Inputs(cluster_feats, {1, (int64_t)cluster_feats.size()});
447
448 // Cell Features
449 std::vector<float> cell_feats_flat;
450 cell_feats_flat.reserve(nCells * m_num_cell_features);
451 for (size_t i = 0; i < nCells; ++i) {
452 cell_feats_flat.push_back(cells_eFrac[i]);
453 cell_feats_flat.push_back(cells_deta[i]);
454 cell_feats_flat.push_back(cells_dphi[i]);
455 cell_feats_flat.push_back(cells_x[i]);
456 cell_feats_flat.push_back(cells_y[i]);
457 cell_feats_flat.push_back(cells_z[i]);
458 cell_feats_flat.push_back(static_cast<float>(cells_layer[i]));
459 }
460 gnn_input["cell_features"] = FlavorTagInference::Inputs(cell_feats_flat, {(int64_t)nCells, m_num_cell_features});
461
462 // Run Inference
463 auto [out_f, out_vc, out_vf] = m_saltModel->runInference(gnn_input);
464
465 float el_gnn_score = 0.0f;
466 if (out_vf.empty() || out_vf.begin()->second.empty()) {
467 ATH_MSG_DEBUG("GNN inference output is empty!");
468 } else {
469 el_gnn_score = out_vf.begin()->second.front();
470 }
471
472 // what to do if the Transformer response is 0;
473 if (el_gnn_score == 0.0f) {
474 return m_clusterEif0 ? clus.e() : 0.0f;
475 }
476
477 return el_gnn_score * static_cast<float>(sum_cell_E_total);
478}
#define M_PI
#define ATH_MSG_FATAL(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
std::vector< const CaloCell * > addedCells
std::unique_ptr< const FlavorTagInference::SaltModel > m_saltModel
Gaudi::Property< bool > m_isMC
Layer calibration related properties.
Gaudi::Property< bool > m_useLayerCorrected
Gaudi::Property< bool > m_useFixForMissingCells
Gaudi::Property< bool > m_useExtraLayerScales
std::unique_ptr< egammaLayerRecalibTool > m_layerRecalibTool
ToolHandle< IegammaCellRecoveryTool > m_egammaCellRecoveryTool
Pointer to the egammaCellRecoveryTool.
Gaudi::Property< bool > m_clusterEif0
const CaloClusterCellLink * getCellLinks() const
Get a pointer to the CaloClusterCellLink object (const version).
virtual double eta() const
The pseudorapidity ( ) of the particle.
virtual double e() const
The total energy of the particle.
float energyBE(const unsigned layer) const
Get the energy in one layer of the EM Calo.
virtual double phi() const
The azimuthal angle ( ) of the particle.
const xAOD::CaloCluster * caloCluster(size_t index=0) const
Pointer to the xAOD::CaloCluster/s that define the electron candidate.
std::map< std::string, Inputs, std::less<> > InputMap
Definition ISaltModel.h:37
float compute_ptconv(const xAOD::Photon *ph)
This ptconv is the old one used by MVACalib.
float compute_pt2conv(const xAOD::Photon *ph)
float compute_pt1conv(const xAOD::Photon *ph)
ConversionType conversionType(const bool hasTrk1, const bool hasTrk2, const std::uint8_t nSiHits1, const std::uint8_t nSiHits2)
return the photon conversion type (see EgammaEnums)
std::size_t numberOfSiTracks(const xAOD::Photon *eg)
return the number of Si tracks in the conversion
float conversionRadius(const xAOD::Vertex *vx)
return the conversion radius or 9999.
EventInfo_v1 EventInfo
Definition of the latest event info version.
Photon_v1 Photon
Definition of the current "egamma version".
setRawEt setRawPhi nCells
std::array< float, 4 > scaleEs
const xAOD::EventInfo * eventInfo

◆ getKey()

SG::sgkey_t asg::AsgTool::getKey ( const void * ptr) const
inherited

Get the (hashed) key of an object that is in the event store.

This is a bit of a special one. StoreGateSvc and xAOD::Event both provide ways for getting the SG::sgkey_t key for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.

In order to allow tools to efficiently perform this operation, they can use this helper function.

See also
asg::AsgTool::getName
Parameters
ptrThe bare pointer to the object that the event store should know about
Returns
The hashed key of the object in the store. If not found, an invalid (zero) key.

Definition at line 119 of file AsgTool.cxx.

119 {
120
121#ifdef XAOD_STANDALONE
122 // In case we use @c xAOD::Event, we have a direct function call
123 // for this.
124 return evtStore()->event()->getKey( ptr );
125#else
126 const SG::DataProxy* proxy = evtStore()->proxy( ptr );
127 return ( proxy == nullptr ? 0 : proxy->sgkey() );
128#endif // XAOD_STANDALONE
129 }
ServiceHandle< StoreGateSvc > & evtStore()

◆ getName()

const std::string & asg::AsgTool::getName ( const void * ptr) const
inherited

Get the name of an object that is / should be in the event store.

This is a bit of a special one. StoreGateSvc and xAOD::Event both provide ways for getting the std::string name for an object that is in the store, based on a bare pointer. But they provide different interfaces for doing so.

In order to allow tools to efficiently perform this operation, they can use this helper function.

See also
asg::AsgTool::getKey
Parameters
ptrThe bare pointer to the object that the event store should know about
Returns
The string name of the object in the store. If not found, an empty string.

Definition at line 106 of file AsgTool.cxx.

106 {
107
108#ifdef XAOD_STANDALONE
109 // In case we use @c xAOD::Event, we have a direct function call
110 // for this.
111 return evtStore()->event()->getName( ptr );
112#else
113 const SG::DataProxy* proxy = evtStore()->proxy( ptr );
114 static const std::string dummy = "";
115 return ( proxy == nullptr ? dummy : proxy->name() );
116#endif // XAOD_STANDALONE
117 }

◆ getProperty()

template<class T>
const T * asg::AsgTool::getProperty ( const std::string & name) const
inherited

Get one of the tool's properties.

◆ initialize()

StatusCode egammaTransformerCalibTool::initialize ( void )
overridevirtual

Dummy implementation of the initialisation function.

It's here to allow the dual-use tools to skip defining an initialisation function. Since many are doing so...

Reimplemented from asg::AsgTool.

Definition at line 44 of file egammaTransformerCalibTool.cxx.

45{
47 ATH_MSG_FATAL("Particle type not set: you have to set property ParticleType to a valid value");
48 return StatusCode::FAILURE;
49 }
50 ATH_MSG_DEBUG("Initializing with particle " << m_particleType);
51
52 if (m_isMC) {
53 ATH_MSG_DEBUG("Input is MC");
54 } else {
55 ATH_MSG_DEBUG("Input is data");
56 }
57
58 if (!m_egammaCellRecoveryTool.empty()) {
59 ATH_MSG_DEBUG("Retrieving cell recovery tool");
61 } else {
62 ATH_MSG_DEBUG("Disabling cell recovery tool");
64 }
65
67 ATH_MSG_DEBUG("Using layer-corrected energies as input to Transformer");
68 //
69 m_layerRecalibTool = std::make_unique<egammaLayerRecalibTool>(m_layerCalibTune, m_useSaccCorrection);
71 m_layerRecalibTool->disable_LayerclEdecoration();
72 // by default it will not apply timing cut fix, we apply the timing cut fix here by default
73 } else {
74 ATH_MSG_DEBUG("Not using layer tool, Using raw layer energies as input to Transformer");
75 }
76
77 // get the Transformer models and initialize functions
78 ATH_MSG_DEBUG("get Transformer ONNX models in folder: " << m_folder);
79 switch (m_particleType) {
81 {
85 }
86 break;
88 {
92 }
93 break;
95 {
99 }
100 break;
101
102 default:
103 ATH_MSG_FATAL("Particle type not set properly: " << m_particleType);
104 return StatusCode::FAILURE;
105 }
106
107 return StatusCode::SUCCESS;
108}
#define ATH_CHECK
Evaluate an expression and check for errors.
std::string PathResolverFindCalibFile(const std::string &logical_file_name)
Gaudi::Property< std::string > m_unconvertedPhotonModelFile
StatusCode setupTransformerModel(const std::string &fileName)
a utility to set up the transformer model, separated from initialize for better readability
Gaudi::Property< std::string > m_layerCalibTune
Gaudi::Property< std::string > m_convertedPhotonModelFile
Gaudi::Property< std::string > m_folder
string with folder for weight files
Gaudi::Property< std::string > m_electronModelFile
Gaudi::Property< bool > m_useSaccCorrection

◆ inputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< AlgTool > >::inputHandles ( ) const
overridevirtualinherited

Return this algorithm's input handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ msg()

MsgStream & AthCommonMsg< AlgTool >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24 {
25 return this->msgStream();
26 }

◆ msg_level_name()

const std::string & asg::AsgTool::msg_level_name ( ) const
inherited

A deprecated function for getting the message level's name.

Instead of using this, weirdly named function, user code should get the string name of the current minimum message level (in case they really need it...), with:

MSG::name( msg().level() )

This function's name doesn't follow the ATLAS coding rules, and as such will be removed in the not too distant future.

Returns
The string name of the current minimum message level that's printed

Definition at line 101 of file AsgTool.cxx.

101 {
102
103 return MSG::name( msg().level() );
104 }
MsgStream & msg() const
const std::string & name(Level lvl)
Convenience function for translating message levels to strings.
Definition MsgLevel.cxx:19

◆ msgLvl()

bool AthCommonMsg< AlgTool >::msgLvl ( const MSG::Level lvl) const
inlineinherited

Definition at line 30 of file AthCommonMsg.h.

30 {
31 return this->msgLevel(lvl);
32 }

◆ outputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< AlgTool > >::outputHandles ( ) const
overridevirtualinherited

Return this algorithm's output handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ print()

void asg::AsgTool::print ( ) const
virtualinherited

◆ renounce()

std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > AthCommonDataStore< AthCommonMsg< AlgTool > >::renounce ( T & h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381 {
382 h.renounce();
384 }
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce(T &h)

◆ renounceArray()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::renounceArray ( SG::VarHandleKeyArray & handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364 {
366 }

◆ setupTransformerModel()

StatusCode egammaTransformerCalibTool::setupTransformerModel ( const std::string & fileName)
private

a utility to set up the transformer model, separated from initialize for better readability

Definition at line 111 of file egammaTransformerCalibTool.cxx.

112{
113 ATH_MSG_DEBUG("initialize() initialize salt model...");
114
115 m_saltModel = std::make_unique<FlavorTagInference::SaltModel>(fileName);
116
117 // return StatusCode::SUCCESS;
118
119 // set up decorators using a dummy query of the onnx model
121
122 ATH_MSG_DEBUG("initialize() initialize cluster-level features...");
123 std::vector<float> cluster_feat(m_num_cluster_features, 0.);
124 std::vector<int64_t> cluster_feat_dim = {1, static_cast<int64_t>(cluster_feat.size())};
125 FlavorTagInference::Inputs elec_info(cluster_feat, cluster_feat_dim);
126 gnn_input.insert({"cluster_features", elec_info}); // need to use the "jet_features" keyword as we are borrowing flavour tagging code
127
128 ATH_MSG_DEBUG("initialize() initialize cell-level features...");
129 std::vector<float> cell_feat(m_num_cell_features, 0.);
130 std::vector<int64_t> cell_feat_dim = {1, m_num_cell_features};
131 FlavorTagInference::Inputs track_info(cell_feat, cell_feat_dim);
132 gnn_input.insert({"cell_features", track_info});
133
134 ATH_MSG_DEBUG("initialize() initialize dummy evaluation...");
135 auto [out_f, out_vc, out_vf] = m_saltModel->runInference(gnn_input); // the dummy evaluation
136
137 ATH_MSG_DEBUG("initialize() finished dummy evaluation...");
138 ATH_MSG_DEBUG("initialize() Output Float(s):");
139 for (auto &singlefloat : out_f)
140 {
141 ATH_MSG_DEBUG("initialize() " << singlefloat.first << " = " << singlefloat.second);
142 }
143 ATH_MSG_DEBUG("initialize() Output vector char(s):");
144 for (auto &vecchar : out_vc)
145 {
146 ATH_MSG_DEBUG("initialize() " << vecchar.first << " = ");
147 for (auto &cc : vecchar.second)
148 {
149 ATH_MSG_DEBUG("initialize() " << cc);
150 }
151 }
152
153 ATH_MSG_DEBUG("initialize() Output vector float(s):");
154 for (auto &vecfloat : out_vf)
155 {
156 ATH_MSG_DEBUG("initialize() " << vecfloat.first << " = ");
157 for (auto &ff : vecfloat.second)
158 {
159 ATH_MSG_DEBUG("initialize() " << ff);
160 }
161 }
162
163 return StatusCode::SUCCESS;
164}

◆ sysInitialize()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysInitialize ( )
overridevirtualinherited

Perform system initialization for an algorithm.

We override this to declare all the elements of handle key arrays at the end of initialization. See comments on updateVHKA.

Reimplemented in asg::AsgMetadataTool, AthCheckedComponent< AthAlgTool >, and AthCheckedComponent<::AthAlgTool >.

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysStart ( )
overridevirtualinherited

Handle START transition.

We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::updateVHKA ( Gaudi::Details::PropertyBase & )
inlineinherited

Definition at line 308 of file AthCommonDataStore.h.

308 {
309 // debug() << "updateVHKA for property " << p.name() << " " << p.toString()
310 // << " size: " << m_vhka.size() << endmsg;
311 for (auto &a : m_vhka) {
313 for (auto k : keys) {
314 k->setOwner(this);
315 }
316 }
317 }
std::vector< SG::VarHandleKeyArray * > m_vhka

Member Data Documentation

◆ m_clusterEif0

Gaudi::Property<bool> egammaTransformerCalibTool::m_clusterEif0
private
Initial value:
{
this, "useClusterIf0", true, "Use cluster energy if MVA response is 0"}

Definition at line 69 of file egammaTransformerCalibTool.h.

69 {
70 this, "useClusterIf0", true, "Use cluster energy if MVA response is 0"};

◆ m_convertedPhotonModelFile

Gaudi::Property<std::string> egammaTransformerCalibTool::m_convertedPhotonModelFile
private
Initial value:
{
this, "ConvertedPhotonModelFile",
"converted_photon_model_calibration.onnx",
"ONNX file for converted photon transformer model"}

Definition at line 103 of file egammaTransformerCalibTool.h.

103 {
104 this, "ConvertedPhotonModelFile",
105 "converted_photon_model_calibration.onnx",
106 "ONNX file for converted photon transformer model"};

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default).

Definition at line 393 of file AthCommonDataStore.h.

◆ m_egammaCellRecoveryTool

ToolHandle<IegammaCellRecoveryTool> egammaTransformerCalibTool::m_egammaCellRecoveryTool
private
Initial value:
{
this,
"egammaCellRecoveryTool",
"egammaCellRecoveryTool/egammaCellRecoveryTool",
"Optional tool that adds cells in L2 or L3 "
"that could have been rejected by timing cut"
}

Pointer to the egammaCellRecoveryTool.

Definition at line 125 of file egammaTransformerCalibTool.h.

125 {
126 this,
127 "egammaCellRecoveryTool",
128 "egammaCellRecoveryTool/egammaCellRecoveryTool",
129 "Optional tool that adds cells in L2 or L3 "
130 "that could have been rejected by timing cut"
131 };

◆ m_electronModelFile

Gaudi::Property<std::string> egammaTransformerCalibTool::m_electronModelFile
private
Initial value:
{
this, "ElectronModelFile", "electron_model_calibration.onnx",
"ONNX file for electron transformer model"}

Definition at line 94 of file egammaTransformerCalibTool.h.

94 {
95 this, "ElectronModelFile", "electron_model_calibration.onnx",
96 "ONNX file for electron transformer model"};

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default).

Definition at line 390 of file AthCommonDataStore.h.

◆ m_folder

Gaudi::Property<std::string> egammaTransformerCalibTool::m_folder
private
Initial value:
{this, "folder", "",
"string with folder for weight files"}

string with folder for weight files

Definition at line 73 of file egammaTransformerCalibTool.h.

73 {this, "folder", "",
74 "string with folder for weight files"};

◆ m_forwardElectronModelFile

Gaudi::Property<std::string> egammaTransformerCalibTool::m_forwardElectronModelFile
private
Initial value:
{
this, "ForwardElectronModelFile",
"",
"ONNX file for forward electron transformer model, this is NOT "
"implemented yet"}

Definition at line 108 of file egammaTransformerCalibTool.h.

108 {
109 this, "ForwardElectronModelFile",
110 "",
111 "ONNX file for forward electron transformer model, this is NOT "
112 "implemented yet"};

◆ m_isMC

Gaudi::Property<bool> egammaTransformerCalibTool::m_isMC {this, "isMC", false, "Whether the input file is MC or data"}
private

Layer calibration related properties.

Definition at line 77 of file egammaTransformerCalibTool.h.

77{this, "isMC", false, "Whether the input file is MC or data"};

◆ m_layerCalibTune

Gaudi::Property<std::string> egammaTransformerCalibTool::m_layerCalibTune
private
Initial value:
{this, "layerRecalibrationTune", "es2025_run3_extrapolate_gnn_v0",
"layer to use for layer corrections"}

Definition at line 82 of file egammaTransformerCalibTool.h.

82 {this, "layerRecalibrationTune", "es2025_run3_extrapolate_gnn_v0",
83 "layer to use for layer corrections"};

◆ m_layerRecalibTool

std::unique_ptr<egammaLayerRecalibTool> egammaTransformerCalibTool::m_layerRecalibTool = nullptr
private

Definition at line 120 of file egammaTransformerCalibTool.h.

◆ m_num_cell_features

int egammaTransformerCalibTool::m_num_cell_features = 0
private

Definition at line 117 of file egammaTransformerCalibTool.h.

◆ m_num_cluster_features

int egammaTransformerCalibTool::m_num_cluster_features = 0
private

Definition at line 116 of file egammaTransformerCalibTool.h.

◆ m_particleType

Gaudi::Property<int> egammaTransformerCalibTool::m_particleType
private
Initial value:
{
"What type of particle do we use"}

Definition at line 65 of file egammaTransformerCalibTool.h.

65 {
67 "What type of particle do we use"};

◆ m_saltModel

std::unique_ptr<const FlavorTagInference::SaltModel> egammaTransformerCalibTool::m_saltModel
private

Definition at line 115 of file egammaTransformerCalibTool.h.

◆ m_timeCut

double egammaTransformerCalibTool::m_timeCut = 12.
staticconstexprprivate

Definition at line 118 of file egammaTransformerCalibTool.h.

◆ m_unconvertedPhotonModelFile

Gaudi::Property<std::string> egammaTransformerCalibTool::m_unconvertedPhotonModelFile
private
Initial value:
{
this, "UnconvertedPhotonModelFile",
"unconverted_photon_model_calibration.onnx",
"ONNX file for unconverted photon transformer model"}

Definition at line 98 of file egammaTransformerCalibTool.h.

98 {
99 this, "UnconvertedPhotonModelFile",
100 "unconverted_photon_model_calibration.onnx",
101 "ONNX file for unconverted photon transformer model"};

◆ m_useExtraLayerScales

Gaudi::Property<bool> egammaTransformerCalibTool::m_useExtraLayerScales
private
Initial value:
{this, "useExtraLayerScales", false,
"whether to apply extra layer scales, this is for systematics studies, by default it is false and the extra layer scales are set to 1.0"}

Definition at line 91 of file egammaTransformerCalibTool.h.

91 {this, "useExtraLayerScales", false,
92 "whether to apply extra layer scales, this is for systematics studies, by default it is false and the extra layer scales are set to 1.0"};

◆ m_useFixForMissingCells

Gaudi::Property<bool> egammaTransformerCalibTool::m_useFixForMissingCells
private
Initial value:
{this, "useFixForMissingCells", true,
"whether to apply fix for missing cells in layer recalibration, this is applied by default, this must be set to true whenever the timing cut fix is applied. Otherwise the layer calibration will not have correct scale factors for cell energies after timing cut fix"}

Definition at line 88 of file egammaTransformerCalibTool.h.

88 {this, "useFixForMissingCells", true,
89 "whether to apply fix for missing cells in layer recalibration, this is applied by default, this must be set to true whenever the timing cut fix is applied. Otherwise the layer calibration will not have correct scale factors for cell energies after timing cut fix"};

◆ m_useLayerCorrected

Gaudi::Property<bool> egammaTransformerCalibTool::m_useLayerCorrected
private
Initial value:
{this, "useLayerCorrection", true,
"whether to use layer corrections"}

Definition at line 79 of file egammaTransformerCalibTool.h.

79 {this, "useLayerCorrection", true,
80 "whether to use layer corrections"};

◆ m_useSaccCorrection

Gaudi::Property<bool> egammaTransformerCalibTool::m_useSaccCorrection
private
Initial value:
{this, "useSaccCorrection", true,
"whether to use SACC correction for layer recalibration"}

Definition at line 85 of file egammaTransformerCalibTool.h.

85 {this, "useSaccCorrection", true,
86 "whether to use SACC correction for layer recalibration"};

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< AlgTool > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vhka

std::vector<SG::VarHandleKeyArray*> AthCommonDataStore< AthCommonMsg< AlgTool > >::m_vhka
privateinherited

Definition at line 398 of file AthCommonDataStore.h.


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