ATLAS Offline Software
Classes | Public Member Functions | Protected Member Functions | Private Types | Private Member Functions | Private Attributes | List of all members
MagField::AtlasFieldMapCondAlg Class Reference

#include <AtlasFieldMapCondAlg.h>

Inheritance diagram for MagField::AtlasFieldMapCondAlg:
Collaboration diagram for MagField::AtlasFieldMapCondAlg:

Classes

struct  Cache
 

Public Member Functions

 AtlasFieldMapCondAlg (const std::string &name, ISvcLocator *pSvcLocator)
 
virtual ~AtlasFieldMapCondAlg ()
 
StatusCode start () override final
 
StatusCode initialize () override final
 
StatusCode execute (const EventContext &ctx) const override final
 
virtual bool isReEntrant () const override final
 
virtual StatusCode sysInitialize () override
 Override sysInitialize. More...
 
virtual bool isClonable () const override
 Specify if the algorithm is clonable. More...
 
virtual unsigned int cardinality () const override
 Cardinality (Maximum number of clones that can exist) special value 0 means that algorithm is reentrant. More...
 
virtual StatusCode sysExecute (const EventContext &ctx) override
 Execute an algorithm. More...
 
virtual const DataObjIDColl & extraOutputDeps () const override
 Return the list of extra output dependencies. More...
 
virtual bool filterPassed (const EventContext &ctx) const
 
virtual void setFilterPassed (bool state, const EventContext &ctx) const
 
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & evtStore () const
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc. More...
 
virtual StatusCode sysStart () override
 Handle START transition. More...
 
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles. More...
 
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles. More...
 
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T > &t)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKey &hndl, const std::string &doc, const SG::VarHandleKeyType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleBase &hndl, const std::string &doc, const SG::VarHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKeyArray &hndArr, const std::string &doc, const SG::VarHandleKeyArrayType &)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc, const SG::NotHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc="none")
 Declare a new Gaudi property. More...
 
void updateVHKA (Gaudi::Details::PropertyBase &)
 
MsgStream & msg () const
 
MsgStream & msg (const MSG::Level lvl) const
 
bool msgLvl (const MSG::Level lvl) const
 

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution More...
 
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. More...
 

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t
 

Private Member Functions

StatusCode updateFieldMap (const EventContext &ctx, Cache &cache) const
 
StatusCode checkCurrentFromConditions (const EventContext &ctx, double &soleCurrent, double &toroCurrent, EventIDRange &rangeDCS) const
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyArrayType &)
 specialization for handling Gaudi::Property<SG::VarHandleKeyArray> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleType &)
 specialization for handling Gaudi::Property<SG::VarHandleBase> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &t, const SG::NotHandleType &)
 specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray> More...
 

Private Attributes

Gaudi::Property< std::string > m_fullMapFilename
 map file names - if not read from cool More...
 
Gaudi::Property< std::string > m_soleMapFilename
 
Gaudi::Property< std::string > m_toroMapFilename
 
Gaudi::Property< double > m_mapSoleCurrent
 nominal current for the maps More...
 
Gaudi::Property< double > m_mapToroCurrent
 
Gaudi::Property< double > m_soleMinCurrent
 
Gaudi::Property< double > m_toroMinCurrent
 
Gaudi::Property< bool > m_loadMapOnStart
 
Gaudi::Property< bool > m_useMapsFromCOOL
 
SG::ReadCondHandleKey< CondAttrListCollectionm_mapsInputKey
 
SG::WriteCondHandleKey< AtlasFieldMapCondObjm_mapCondObjOutputKey
 
SG::ReadCondHandleKey< CondAttrListCollectionm_currInputKey
 
DataObjIDColl m_extendedExtraObjects
 Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks. More...
 
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default) More...
 
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default) More...
 
std::vector< SG::VarHandleKeyArray * > m_vhka
 
bool m_varHandleArraysDeclared
 

Detailed Description

Definition at line 22 of file AtlasFieldMapCondAlg.h.

Member Typedef Documentation

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Constructor & Destructor Documentation

◆ AtlasFieldMapCondAlg()

AtlasFieldMapCondAlg::AtlasFieldMapCondAlg ( const std::string &  name,
ISvcLocator *  pSvcLocator 
)

Definition at line 33 of file AtlasFieldMapCondAlg.cxx.

35  : AthReentrantAlgorithm(name, pSvcLocator)
36 {}

◆ ~AtlasFieldMapCondAlg()

AtlasFieldMapCondAlg::~AtlasFieldMapCondAlg ( )
virtualdefault

Member Function Documentation

◆ cardinality()

unsigned int AthReentrantAlgorithm::cardinality ( ) const
overridevirtualinherited

Cardinality (Maximum number of clones that can exist) special value 0 means that algorithm is reentrant.

Override this to return 0 for reentrant algorithms.

Override this to return 0 for reentrant algorithms.

Definition at line 55 of file AthReentrantAlgorithm.cxx.

56 {
57  return 0;
58 }

◆ checkCurrentFromConditions()

StatusCode AtlasFieldMapCondAlg::checkCurrentFromConditions ( const EventContext &  ctx,
double &  soleCurrent,
double &  toroCurrent,
EventIDRange &  rangeDCS 
) const
private

Definition at line 427 of file AtlasFieldMapCondAlg.cxx.

432 {
433 
434  // readin current value
436  const CondAttrListCollection* attrListColl{ *readHandle };
437  if (attrListColl == nullptr) {
438  ATH_MSG_ERROR("checkCurrentFromConditions: Failed to retrieve "
439  "CondAttributeListCollection with key "
440  << m_currInputKey.key());
441  return StatusCode::FAILURE;
442  }
443 
444  // Get the validitiy range
445  if (!readHandle.range(rangeDCS)) {
447  "checkCurrentFromConditions: Failed to retrieve validity range for "
448  << readHandle.key());
449  return StatusCode::FAILURE;
450  }
451  ATH_MSG_INFO("checkCurrentFromConditions: Range of input currents is "
452  << rangeDCS);
453 
454  // get magnet currents from DCS
455  double solcur{ 0. };
456  double torcur{ 0. };
457  bool gotsol{ false };
458  bool gottor{ false };
459 
460  /*
461  * due to inconsistencies between CONDBR2 and OFLP200/COMP200 (the former
462  * includes channel names in the /EXT/DCS/MAGNETS/SENSORDATA folder, the
463  * latter don't), we try to read currents in both ways
464  */
465  bool hasChanNames{ false };
466  ATH_MSG_INFO("checkCurrentFromConditions: Attempt 1 at reading currents from "
467  "DCS (using channel name)");
468  for (CondAttrListCollection::const_iterator itr = attrListColl->begin();
469  itr != attrListColl->end();
470  ++itr) {
471  const std::string& name = attrListColl->chanName(itr->first);
472  ATH_MSG_INFO("checkCurrentFromConditions: Trying to read from DCS: "
473  "[channel name, index, value] "
474  << name << " , " << itr->first << " , "
475  << itr->second["value"].data<float>());
476  if (name.compare("") != 0) {
477  hasChanNames = true;
478  }
479  if (name.compare("CentralSol_Current") == 0) {
480  // channel 1 is solenoid current
481  solcur = itr->second["value"].data<float>();
482  gotsol = true;
483  } else if (name.compare("Toroids_Current") == 0) {
484  // channel 3 is toroid current
485  torcur = itr->second["value"].data<float>();
486  gottor = true;
487  }
488  }
489  if (!hasChanNames) {
490  ATH_MSG_INFO("checkCurrentFromConditions: Attempt 2 at reading currents "
491  "from DCS (using channel index)");
492  // in no channel is named, try again using channel index instead
493  for (CondAttrListCollection::const_iterator itr = attrListColl->begin();
494  itr != attrListColl->end();
495  ++itr) {
496 
497  if (itr->first == 1) {
498  // channel 1 is solenoid current
499  solcur = itr->second["value"].data<float>();
500  gotsol = true;
501  } else if (itr->first == 3) {
502  // channel 3 is toroid current
503  torcur = itr->second["value"].data<float>();
504  gottor = true;
505  }
506  }
507  }
508  if (!gotsol || !gottor) {
509  if (!gotsol)
510  ATH_MSG_ERROR("checkCurrentFromConditions: Missing solenoid current in "
511  "DCS information");
512  if (!gottor)
513  ATH_MSG_ERROR("checkCurrentFromConditions: Missing toroid current in DCS "
514  "information");
515  return StatusCode::FAILURE;
516  }
517 
518  ATH_MSG_INFO("checkCurrentFromConditions: Currents read from DCS - solenoid "
519  << solcur << " toroid " << torcur);
520 
521  // round to zero if close to zero
522  if (solcur < m_soleMinCurrent) {
523  solcur = 0.0;
524  ATH_MSG_INFO("checkCurrentFromConditions: Solenoid is off");
525  }
526  if (torcur < m_toroMinCurrent) {
527  torcur = 0.0;
528  ATH_MSG_INFO("checkCurrentFromConditions: Toroids are off");
529  }
530 
531  soleCurrent = solcur;
532  toroCurrent = torcur;
533 
534  return StatusCode::SUCCESS;
535 }

◆ declareGaudiProperty() [1/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleKeyArrayType  
)
inlineprivateinherited

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

Definition at line 170 of file AthCommonDataStore.h.

172  {
173  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
174  hndl.value(),
175  hndl.documentation());
176 
177  }

◆ declareGaudiProperty() [2/4]

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

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

Definition at line 156 of file AthCommonDataStore.h.

158  {
159  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
160  hndl.value(),
161  hndl.documentation());
162 
163  }

◆ declareGaudiProperty() [3/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleType  
)
inlineprivateinherited

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

Definition at line 184 of file AthCommonDataStore.h.

186  {
187  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
188  hndl.value(),
189  hndl.documentation());
190  }

◆ declareGaudiProperty() [4/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareGaudiProperty ( Gaudi::Property< T > &  t,
const SG::NotHandleType  
)
inlineprivateinherited

specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray>

Definition at line 199 of file AthCommonDataStore.h.

200  {
201  return PBASE::declareProperty(t);
202  }

◆ declareProperty() [1/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareProperty ( const std::string &  name,
SG::VarHandleBase hndl,
const std::string &  doc,
const SG::VarHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleBase. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 245 of file AthCommonDataStore.h.

249  {
250  this->declare(hndl.vhKey());
251  hndl.vhKey().setOwner(this);
252 
253  return PBASE::declareProperty(name,hndl,doc);
254  }

◆ declareProperty() [2/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareProperty ( const std::string &  name,
SG::VarHandleKey hndl,
const std::string &  doc,
const SG::VarHandleKeyType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleKey. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 221 of file AthCommonDataStore.h.

225  {
226  this->declare(hndl);
227  hndl.setOwner(this);
228 
229  return PBASE::declareProperty(name,hndl,doc);
230  }

◆ declareProperty() [3/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareProperty ( const std::string &  name,
SG::VarHandleKeyArray hndArr,
const std::string &  doc,
const SG::VarHandleKeyArrayType  
)
inlineinherited

Definition at line 259 of file AthCommonDataStore.h.

263  {
264 
265  // std::ostringstream ost;
266  // ost << Algorithm::name() << " VHKA declareProp: " << name
267  // << " size: " << hndArr.keys().size()
268  // << " mode: " << hndArr.mode()
269  // << " vhka size: " << m_vhka.size()
270  // << "\n";
271  // debug() << ost.str() << endmsg;
272 
273  hndArr.setOwner(this);
274  m_vhka.push_back(&hndArr);
275 
276  Gaudi::Details::PropertyBase* p = PBASE::declareProperty(name, hndArr, doc);
277  if (p != 0) {
278  p->declareUpdateHandler(&AthCommonDataStore<PBASE>::updateVHKA, this);
279  } else {
280  ATH_MSG_ERROR("unable to call declareProperty on VarHandleKeyArray "
281  << name);
282  }
283 
284  return p;
285 
286  }

◆ declareProperty() [4/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc,
const SG::NotHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This is the generic version, for types that do not derive from SG::VarHandleKey. It just forwards to the base class version of declareProperty.

Definition at line 333 of file AthCommonDataStore.h.

337  {
338  return PBASE::declareProperty(name, property, doc);
339  }

◆ declareProperty() [5/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc = "none" 
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This dispatches to either the generic declareProperty or the one for VarHandle/Key/KeyArray.

Definition at line 352 of file AthCommonDataStore.h.

355  {
356  typedef typename SG::HandleClassifier<T>::type htype;
357  return declareProperty (name, property, doc, htype());
358  }

◆ declareProperty() [6/6]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::declareProperty ( Gaudi::Property< T > &  t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145  {
146  typedef typename SG::HandleClassifier<T>::type htype;
148  }

◆ detStore()

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

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

Definition at line 95 of file AthCommonDataStore.h.

95 { return m_detStore; }

◆ evtStore() [1/2]

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

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

Definition at line 85 of file AthCommonDataStore.h.

85 { return m_evtStore; }

◆ evtStore() [2/2]

const ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::evtStore ( ) const
inlineinherited

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

Definition at line 90 of file AthCommonDataStore.h.

90 { return m_evtStore; }

◆ execute()

StatusCode AtlasFieldMapCondAlg::execute ( const EventContext &  ctx) const
finaloverride

Definition at line 82 of file AtlasFieldMapCondAlg.cxx.

83 {
84 
85  ATH_MSG_DEBUG("execute: entering " << ctx.eventID());
86 
87  // Check if output conditions object with field map object is still valid, if
88  // not replace it with new map
91  };
92  if (mapWriteHandle.isValid()) {
93  ATH_MSG_DEBUG("execute: CondHandle " << mapWriteHandle.fullKey()
94  << " is still valid. ");
95  return StatusCode::SUCCESS;
96  }
97 
98  // This will need to be filled before we construct the condition object
99  Cache cache{};
100 
101  ATH_CHECK(updateFieldMap(ctx, cache));
102 
103  if (cache.m_fieldMap) {
104  ATH_MSG_INFO("execute: solenoid zone id "
105  << cache.m_fieldMap->solenoidZoneId());
106  } else {
107  ATH_MSG_INFO("execute: no map read (currents == 0");
108  }
109 
110  // Save newly created map in conditions object, and record it in the
111  // conditions store, with its own range
112  auto fieldMapCondObj = std::make_unique<AtlasFieldMapCondObj>();
113  // move ownership of the field map to the fieldMapCondObj
114  if (cache.m_fieldMap)
115  fieldMapCondObj->setFieldMap(std::move(cache.m_fieldMap));
116  if (mapWriteHandle
117  .record(cache.m_mapCondObjOutputRange, std::move(fieldMapCondObj))
118  .isFailure()) {
119  ATH_MSG_ERROR("execute: Could not record AtlasFieldMapCondObj object with "
120  << mapWriteHandle.key() << " with EventRange "
121  << cache.m_mapCondObjOutputRange << " into Conditions Store");
122  return StatusCode::FAILURE;
123  }
124  ATH_MSG_INFO("execute: recorded AtlasFieldMapCondObj with EventRange "
125  << cache.m_mapCondObjOutputRange);
126 
127  return StatusCode::SUCCESS;
128 }

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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

◆ extraOutputDeps()

const DataObjIDColl & AthReentrantAlgorithm::extraOutputDeps ( ) const
overridevirtualinherited

Return the list of extra output dependencies.

This list is extended to include symlinks implied by inheritance relations.

Definition at line 79 of file AthReentrantAlgorithm.cxx.

80 {
81  // If we didn't find any symlinks to add, just return the collection
82  // from the base class. Otherwise, return the extended collection.
83  if (!m_extendedExtraObjects.empty()) {
85  }
86  return Algorithm::extraOutputDeps();
87 }

◆ filterPassed()

virtual bool AthReentrantAlgorithm::filterPassed ( const EventContext &  ctx) const
inlinevirtualinherited

Definition at line 135 of file AthReentrantAlgorithm.h.

135  {
136  return execState( ctx ).filterPassed();
137  }

◆ initialize()

StatusCode AtlasFieldMapCondAlg::initialize ( )
finaloverride

Definition at line 41 of file AtlasFieldMapCondAlg.cxx.

42 {
43  // Read Handle for the map
45 
46  // Read Handle for the current
48 
49  // Output handle for the field map
51 
52  ATH_MSG_DEBUG("Initialize: Key " << m_mapCondObjOutputKey.fullKey()
53  << " has been succesfully registered ");
54 
55  ATH_MSG_INFO("Initialize: Will update the field map from " <<
56  (m_useMapsFromCOOL ? "conditions" : "jobOpt file name") );
57 
58  // Load these dictionaries now, so we don't need to try to do so
59  // while multiple threads are running.
60  TClass::GetClass("TLeafI");
61  TClass::GetClass("TLeafD");
62  TClass::GetClass("TLeafO");
63  TClass::GetClass("TLeafS");
64 
65  return StatusCode::SUCCESS;
66 }

◆ inputHandles()

virtual std::vector<Gaudi::DataHandle*> AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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.

◆ isClonable()

bool AthReentrantAlgorithm::isClonable ( ) const
overridevirtualinherited

◆ isReEntrant()

virtual bool MagField::AtlasFieldMapCondAlg::isReEntrant ( ) const
inlinefinaloverridevirtual

Definition at line 31 of file AtlasFieldMapCondAlg.h.

31 { return false; }

◆ msg() [1/2]

MsgStream& AthCommonMsg< Gaudi::Algorithm >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

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

◆ msg() [2/2]

MsgStream& AthCommonMsg< Gaudi::Algorithm >::msg ( const MSG::Level  lvl) const
inlineinherited

Definition at line 27 of file AthCommonMsg.h.

27  {
28  return this->msgStream(lvl);
29  }

◆ msgLvl()

bool AthCommonMsg< Gaudi::Algorithm >::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< Gaudi::Algorithm > >::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.

◆ 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< Gaudi::Algorithm > >::renounce ( T &  h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381  {
382  h.renounce();
383  PBASE::renounce (h);
384  }

◆ renounceArray()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::renounceArray ( SG::VarHandleKeyArray handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364  {
365  handlesArray.renounce();
366  }

◆ setFilterPassed()

virtual void AthReentrantAlgorithm::setFilterPassed ( bool  state,
const EventContext &  ctx 
) const
inlinevirtualinherited

Definition at line 139 of file AthReentrantAlgorithm.h.

139  {
140  execState( ctx ).setFilterPassed( state );
141  }

◆ start()

StatusCode AtlasFieldMapCondAlg::start ( )
finaloverride

Definition at line 69 of file AtlasFieldMapCondAlg.cxx.

70 {
71  ATH_MSG_DEBUG("start: entering ");
72 
73  // Load map on start, we assume that the current context is valid
74  if (m_loadMapOnStart) {
75  return (execute(Gaudi::Hive::currentContext()));
76  }
77 
78  return StatusCode::SUCCESS;
79 }

◆ sysExecute()

StatusCode AthReentrantAlgorithm::sysExecute ( const EventContext &  ctx)
overridevirtualinherited

Execute an algorithm.

We override this in order to work around an issue with the Algorithm base class storing the event context in a member variable that can cause crashes in MT jobs.

Definition at line 67 of file AthReentrantAlgorithm.cxx.

68 {
69  return Gaudi::Algorithm::sysExecute (ctx);
70 }

◆ sysInitialize()

StatusCode AthReentrantAlgorithm::sysInitialize ( )
overridevirtualinherited

Override sysInitialize.

Override sysInitialize from the base class.

Loop through all output handles, and if they're WriteCondHandles, automatically register them and this Algorithm with the CondSvc

Scan through all outputHandles, and if they're WriteCondHandles, register them with the CondSvc

Reimplemented from AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >.

Reimplemented in InputMakerBase, and HypoBase.

Definition at line 96 of file AthReentrantAlgorithm.cxx.

96  {
98 
99  if (sc.isFailure()) {
100  return sc;
101  }
102 
103  ServiceHandle<ICondSvc> cs("CondSvc",name());
104  for (auto h : outputHandles()) {
105  if (h->isCondition() && h->mode() == Gaudi::DataHandle::Writer) {
106  // do this inside the loop so we don't create the CondSvc until needed
107  if ( cs.retrieve().isFailure() ) {
108  ATH_MSG_WARNING("no CondSvc found: won't autoreg WriteCondHandles");
109  return StatusCode::SUCCESS;
110  }
111  if (cs->regHandle(this,*h).isFailure()) {
112  sc = StatusCode::FAILURE;
113  ATH_MSG_ERROR("unable to register WriteCondHandle " << h->fullKey()
114  << " with CondSvc");
115  }
116  }
117  }
118  return sc;
119 }

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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.

◆ updateFieldMap()

StatusCode AtlasFieldMapCondAlg::updateFieldMap ( const EventContext &  ctx,
Cache cache 
) const
private

Definition at line 131 of file AtlasFieldMapCondAlg.cxx.

133 {
134  // We get here only for the first creation of the field map, or if the
135  // AtlasFieldMapCondObj object, where the map is stored, is no longer valid,
136  // i.e. the IOV is out of range
137 
138  // Update the map either with the file names from cool or from alg properties,
139  // according to m_useMapsFromCOOL
140 
141  // Get file names from COOL, or use local ones:
142  std::string fullMapFilename;
143  std::string soleMapFilename;
144  std::string toroMapFilename;
145 
146  if (m_useMapsFromCOOL) {
147 
148  ATH_MSG_INFO("updateFieldMap: Update map from conditions");
149 
150  // readin map file name from cool
152  ctx };
153  const CondAttrListCollection* attrListColl{ *readHandle };
154  if (attrListColl == nullptr) {
155  ATH_MSG_ERROR("updateFieldMap: Failed to retrieve "
156  "CondAttributeListCollection with key "
157  << readHandle.key());
158  return StatusCode::FAILURE;
159  }
160 
161  // // handle for COOL field map filenames
162  // const DataHandle<CondAttrListCollection> mapHandle;
163 
164  // Get the validitiy range
165  EventIDRange rangeW;
166  if (!readHandle.range(rangeW)) {
167  ATH_MSG_FATAL("updateFieldMap: Failed to retrieve validity range for "
168  << readHandle.key());
169  return StatusCode::FAILURE;
170  }
171  cache.m_mapCondObjOutputRange = rangeW;
172  ATH_MSG_INFO(
173  "updateFieldMap: Update map from conditions: Range of input/output is "
174  << cache.m_mapCondObjOutputRange);
175 
176  ATH_MSG_INFO(
177  "updateFieldMap: reading magnetic field map filenames from COOL");
178 
179  for (CondAttrListCollection::const_iterator itr = attrListColl->begin();
180  itr != attrListColl->end();
181  ++itr) {
182  const coral::AttributeList& attr = itr->second;
183  const std::string& mapType = attr["FieldType"].data<std::string>();
184  const std::string& mapFile = attr["MapFileName"].data<std::string>();
185  const float soleCur = attr["SolenoidCurrent"].data<float>();
186  const float toroCur = attr["ToroidCurrent"].data<float>();
187 
188  ATH_MSG_INFO("updateFieldMap: found map of type "
189  << mapType << " with soleCur=" << soleCur
190  << " toroCur=" << toroCur << " (path " << mapFile << ")");
191 
192  // first 5 letters are reserved (like "file:")
193  const std::string mapFile_decoded = mapFile.substr(5);
194  if (mapType == "GlobalMap") {
195  fullMapFilename = mapFile_decoded;
196  cache.m_mapSoleCurrent = soleCur;
197  cache.m_mapToroCurrent = toroCur;
198  } else if (mapType == "SolenoidMap") {
199  soleMapFilename = mapFile_decoded;
200  } else if (mapType == "ToroidMap") {
201  toroMapFilename = mapFile_decoded;
202  }
203  // note: the idea is that the folder contains exactly three maps
204  // (if it contains more than 3 maps, then this logic doesn't work
205  // perfectly) nominal currents are read from the global map
206  }
207 
208  if (m_loadMapOnStart) {
209 
210  // For loading map on start - online scenario - take the currents from job
211  // options And set IOV range to current run number to run number + 1
212 
213  cache.m_mapSoleCurrent = m_mapSoleCurrent;
214  cache.m_mapToroCurrent = m_mapToroCurrent;
215 
216  // Create a range for the current run
217  EventIDBase start, stop;
218  start.set_run_number(ctx.eventID().run_number());
219  start.set_lumi_block(0);
220  stop.set_run_number(ctx.eventID().run_number() + 1);
221  stop.set_lumi_block(0);
222  cache.m_mapCondObjOutputRange = EventIDRange(start, stop);
223 
224  ATH_MSG_INFO("updateFieldMap: loadMapOnStart is set, overriding currents "
225  "from job options - solCur "
226  << cache.m_mapSoleCurrent << ", torCur "
227  << cache.m_mapToroCurrent << " and setting IOV range: "
228  << cache.m_mapCondObjOutputRange);
229  } else {
230  // For normal athena jobs, check the currents in DCS to check if one of
231  // the two magnets is OFF so that the correct map can be used. If a field
232  // is off, set an IOV validity range to be the current run only. (Note DCS
233  // currents have a timestamp-based IOV, so this is not used.)
234 
235  // Note: for the nominal maps from COOL, three maps are available:
236  // - Global with both solenoid and toroid
237  // - Solenoid - just the currents for the solenoid
238  // - Toroid - just the currents for the toroid
239 
240  double soleCurrent;
241  double toroCurrent;
242  EventIDRange rangeDCS;
243  ATH_CHECK(
244  checkCurrentFromConditions(ctx, soleCurrent, toroCurrent, rangeDCS));
245 
246  bool mustCreateIOVRange = false;
247  if (soleCurrent < m_soleMinCurrent) {
248  cache.m_mapSoleCurrent = 0;
249  mustCreateIOVRange = true;
250  ATH_MSG_INFO("updateFieldMap: set solenoid current to 0 from DCS");
251  }
252  if (toroCurrent < m_toroMinCurrent) {
253  cache.m_mapToroCurrent = 0;
254  mustCreateIOVRange = true;
255  ATH_MSG_INFO("updateFieldMap: set toroid current to 0 from DCS");
256  }
257  if (mustCreateIOVRange) {
258  // The currents from DCS are zero for either solenoid or toroid,
259  // construct an IOV range for one run
260  EventIDBase start, stop;
261  // use ctx run number
262  start.set_run_number(ctx.eventID().run_number());
263  start.set_lumi_block(0);
264  stop.set_run_number(ctx.eventID().run_number() + 1);
265  stop.set_lumi_block(0);
266  cache.m_mapCondObjOutputRange = EventIDRange(start, stop);
267  ATH_MSG_INFO("updateFieldMap: map IOV range "
268  << cache.m_mapCondObjOutputRange);
269  } else {
270  ATH_MSG_INFO("updateFieldMap: currents are OK, will use nominal maps");
271  }
272  }
273  }
274 
275  else {
276  // not m_useMapsFromCOOL - set values from job options
277  fullMapFilename = m_fullMapFilename;
278  soleMapFilename = m_soleMapFilename;
279  toroMapFilename = m_toroMapFilename;
281  cache.m_mapSoleCurrent = 0;
282  ATH_MSG_INFO("updateFieldMap: requested solenoid current in JobOpt "
283  << m_mapSoleCurrent << " is below allowed minimum "
284  << m_soleMinCurrent << " setting to 0");
285  } else {
286  cache.m_mapSoleCurrent = m_mapSoleCurrent;
287  }
289  cache.m_mapToroCurrent = 0;
290  ATH_MSG_INFO("updateFieldMap: requested toroid current in JobOpt "
291  << m_mapToroCurrent << " is below allowed minimum "
292  << m_toroMinCurrent << " setting to 0");
293  } else {
294  cache.m_mapToroCurrent = m_mapToroCurrent;
295  }
296 
297  // Create a range for the current run
298  EventIDBase start, stop;
299  start.set_run_number(ctx.eventID().run_number());
300  start.set_lumi_block(0);
301  stop.set_run_number(ctx.eventID().run_number() + 1);
302  stop.set_lumi_block(0);
303  cache.m_mapCondObjOutputRange = EventIDRange(start, stop);
304 
305  ATH_MSG_INFO(
306  "updateFieldMap: useMapsFromCOOL == false, using default range "
307  << cache.m_mapCondObjOutputRange);
308  }
309 
310  // We allow to set currents via the TagInfoMgr which adds tags to the TagInfo
311  // object - only allowed for offline
312 
313  if (m_useMapsFromCOOL) {
314 
315  // get currents via TagInfoMgr
316  ServiceHandle<ITagInfoMgr> tagInfoMgr("TagInfoMgr", name());
317  if (tagInfoMgr.retrieve().isSuccess()) {
318  ATH_MSG_INFO("updateFieldMap: found TagInfoMgr ");
319  bool resetCurrentsFromTagInfo = false;
320  std::string mapSoleCurrent = tagInfoMgr->findTag("MapSoleCurrent");
321  if (not mapSoleCurrent.empty()) {
322  cache.m_mapSoleCurrent = std::stof(mapSoleCurrent);
323  resetCurrentsFromTagInfo = true;
324  ATH_MSG_INFO("updateFieldMap: found MapSoleCurrent in TagInfo, setting "
325  "the solenoid current "
326  << cache.m_mapSoleCurrent);
327  }
328  std::string mapToroCurrent = tagInfoMgr->findTag("MapToroCurrent");
329  if (not mapToroCurrent.empty()) {
330  cache.m_mapToroCurrent = std::stof(mapToroCurrent);
331  resetCurrentsFromTagInfo = true;
332  ATH_MSG_INFO("updateFieldMap: found MapToroCurrent in TagInfo, setting "
333  "the toroid current "
334  << cache.m_mapToroCurrent);
335  }
336  if (resetCurrentsFromTagInfo)
337  ATH_MSG_INFO("updateFieldMap: reset currents from TagInfo");
338  else
339  ATH_MSG_INFO("updateFieldMap: DID NOT reset currents from TagInfo");
340  } else {
341  ATH_MSG_INFO("updateFieldMap: TagInfoMgr NOT found. ");
342  }
343  }
344 
345  // Select map file according to the value of the currents which indicate which
346  // map is 'on'
347 
348  // determine the map to load
349  std::string mapFile;
350  if (cache.solenoidOn() && cache.toroidOn())
351  mapFile = fullMapFilename;
352  else if (cache.solenoidOn())
353  mapFile = soleMapFilename;
354  else if (cache.toroidOn())
355  mapFile = toroMapFilename;
356  else {
357  // all magnets OFF. no need to read map
358  return StatusCode::SUCCESS;
359  }
360 
361  ATH_MSG_INFO(
362  "updateFieldMap: Set map currents from FieldSvc: solenoid/toroid "
363  << cache.m_mapSoleCurrent << "," << cache.m_mapToroCurrent);
364  ATH_MSG_INFO("updateFieldMap: Use map file " << mapFile);
365 
366  // find the path to the map file
367  std::string resolvedMapFile = PathResolver::find_file(mapFile, "CALIBPATH");
368  if (resolvedMapFile.empty()) {
369  ATH_MSG_ERROR("Field map file " << mapFile << " not found");
370  return StatusCode::FAILURE;
371  }
372  // Do checks and extract root file to initialize the map
373  if (resolvedMapFile.find(".root") == std::string::npos) {
374  ATH_MSG_ERROR("updateFieldMap: input file name '"
375  << resolvedMapFile << "' does not end with .root");
376  return StatusCode::FAILURE;
377  }
378  TFile* rootfile = new TFile(resolvedMapFile.c_str(), "OLD");
379  if (!rootfile) {
380  ATH_MSG_ERROR("updateFieldMap: failed to open " << resolvedMapFile);
381  return StatusCode::FAILURE;
382  }
383  if (!rootfile->cd()) {
384  // could not make it current directory
386  "updateFieldMap: unable to cd() into the ROOT field map TFile");
387  rootfile->Close();
388  delete rootfile;
389  return StatusCode::FAILURE;
390  }
391  // open the tree
392  TTree* tree = (TTree*)rootfile->Get("BFieldMap");
393  if (tree == nullptr) {
394  // no tree
396  "updateFieldMap: TTree 'BFieldMap' does not exist in ROOT field map");
397  rootfile->Close();
398  delete rootfile;
399  return StatusCode::FAILURE;
400  }
401 
402  // create map
403  cache.m_fieldMap = std::make_unique<MagField::AtlasFieldMap>();
404 
405  // initialize map
406  if (!cache.m_fieldMap->initializeMap(
407  rootfile, cache.m_mapSoleCurrent, cache.m_mapToroCurrent)) {
408  // failed to initialize the map
410  "updateFieldMap: unable to initialize the map for AtlasFieldMap for file "
411  << resolvedMapFile);
412  rootfile->Close();
413  delete rootfile;
414  return StatusCode::FAILURE;
415  }
416 
417  rootfile->Close();
418  delete rootfile;
419 
420  ATH_MSG_INFO("updateFieldMap: Initialized the field map from "
421  << resolvedMapFile);
422 
423  return StatusCode::SUCCESS;
424 }

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::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) {
312  std::vector<SG::VarHandleKey*> keys = a->keys();
313  for (auto k : keys) {
314  k->setOwner(this);
315  }
316  }
317  }

Member Data Documentation

◆ m_currInputKey

SG::ReadCondHandleKey<CondAttrListCollection> MagField::AtlasFieldMapCondAlg::m_currInputKey
private
Initial value:
{
this,
"COOLCurrentsFolderName",
"/EXT/DCS/MAGNETS/SENSORDATA",
"Name of the COOL folder containing magnet currents"
}

Definition at line 152 of file AtlasFieldMapCondAlg.h.

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default)

Definition at line 393 of file AthCommonDataStore.h.

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default)

Definition at line 390 of file AthCommonDataStore.h.

◆ m_extendedExtraObjects

DataObjIDColl AthReentrantAlgorithm::m_extendedExtraObjects
privateinherited

Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks.

Empty if no symlinks were found.

Definition at line 153 of file AthReentrantAlgorithm.h.

◆ m_fullMapFilename

Gaudi::Property<std::string> MagField::AtlasFieldMapCondAlg::m_fullMapFilename
private
Initial value:
{
this,
"FullMapFile",
"MagneticFieldMaps/bfieldmap_7730_20400_14m.root",
"File storing the full magnetic field map"
}

map file names - if not read from cool

Definition at line 73 of file AtlasFieldMapCondAlg.h.

◆ m_loadMapOnStart

Gaudi::Property<bool> MagField::AtlasFieldMapCondAlg::m_loadMapOnStart
private
Initial value:
{
this,
"LoadMapOnStart",
false,
"Load the magnetic field map at start"
}

Definition at line 116 of file AtlasFieldMapCondAlg.h.

◆ m_mapCondObjOutputKey

SG::WriteCondHandleKey<AtlasFieldMapCondObj> MagField::AtlasFieldMapCondAlg::m_mapCondObjOutputKey
private
Initial value:
{
this,
"AtlasFieldMapCondObj",
"fieldMapCondObj",
"Name of key for the Magnetic Field conditions object with the map file "
"names"
}

Definition at line 142 of file AtlasFieldMapCondAlg.h.

◆ m_mapsInputKey

SG::ReadCondHandleKey<CondAttrListCollection> MagField::AtlasFieldMapCondAlg::m_mapsInputKey
private
Initial value:
{
this,
"COOLMapsFolderName",
"/GLOBAL/BField/Maps",
"Name of the COOL folder containing field maps"
}

Definition at line 133 of file AtlasFieldMapCondAlg.h.

◆ m_mapSoleCurrent

Gaudi::Property<double> MagField::AtlasFieldMapCondAlg::m_mapSoleCurrent
private
Initial value:
{ this,
"MapSoleCurrent",
7730.,
"Nominal solenoid current (A)" }

nominal current for the maps

Definition at line 92 of file AtlasFieldMapCondAlg.h.

◆ m_mapToroCurrent

Gaudi::Property<double> MagField::AtlasFieldMapCondAlg::m_mapToroCurrent
private
Initial value:
{ this,
"MapToroCurrent",
20400.,
"Nominal toroid current (A)" }

Definition at line 96 of file AtlasFieldMapCondAlg.h.

◆ m_soleMapFilename

Gaudi::Property<std::string> MagField::AtlasFieldMapCondAlg::m_soleMapFilename
private
Initial value:
{
this,
"SoleMapFile",
"MagneticFieldMaps/bfieldmap_7730_0_14m.root",
"File storing the solenoid-only magnetic field map"
}

Definition at line 79 of file AtlasFieldMapCondAlg.h.

◆ m_soleMinCurrent

Gaudi::Property<double> MagField::AtlasFieldMapCondAlg::m_soleMinCurrent
private
Initial value:
{
this,
"SoleMinCurrent",
1.0,
"Minimum solenoid current (A) for which solenoid is considered ON"
}

Definition at line 102 of file AtlasFieldMapCondAlg.h.

◆ m_toroMapFilename

Gaudi::Property<std::string> MagField::AtlasFieldMapCondAlg::m_toroMapFilename
private
Initial value:
{
this,
"ToroMapFile",
"MagneticFieldMaps/bfieldmap_0_20400_14m.root",
"File storing the toroid-only magnetic field map"
}

Definition at line 85 of file AtlasFieldMapCondAlg.h.

◆ m_toroMinCurrent

Gaudi::Property<double> MagField::AtlasFieldMapCondAlg::m_toroMinCurrent
private
Initial value:
{
this,
"ToroMinCurrent",
1.0,
"Minimum toroid current (A) for which toroid is considered ON"
}

Definition at line 108 of file AtlasFieldMapCondAlg.h.

◆ m_useMapsFromCOOL

Gaudi::Property<bool> MagField::AtlasFieldMapCondAlg::m_useMapsFromCOOL
private
Initial value:
{
this,
"UseMapsFromCOOL",
true,
"Get magnetic field map filenames from COOL"
}

Definition at line 124 of file AtlasFieldMapCondAlg.h.

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vhka

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

Definition at line 398 of file AthCommonDataStore.h.


The documentation for this class was generated from the following files:
MagField::AtlasFieldMapCondAlg::m_currInputKey
SG::ReadCondHandleKey< CondAttrListCollection > m_currInputKey
Definition: AtlasFieldMapCondAlg.h:152
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
SG::ReadCondHandle
Definition: ReadCondHandle.h:44
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
PathResolver::find_file
static std::string find_file(const std::string &logical_file_name, const std::string &search_path, SearchType search_type=LocalSearch)
Definition: PathResolver.cxx:251
MagField::AtlasFieldMapCondAlg::m_mapCondObjOutputKey
SG::WriteCondHandleKey< AtlasFieldMapCondObj > m_mapCondObjOutputKey
Definition: AtlasFieldMapCondAlg.h:142
AthCommonDataStore::declareProperty
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T > &t)
Definition: AthCommonDataStore.h:145
tree
TChain * tree
Definition: tile_monitor.h:30
AthCommonDataStore::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 > renounce(T &h)
Definition: AthCommonDataStore.h:380
AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_evtStore
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
Definition: AthCommonDataStore.h:390
AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_vhka
std::vector< SG::VarHandleKeyArray * > m_vhka
Definition: AthCommonDataStore.h:398
PixelModuleFeMask_create_db.stop
int stop
Definition: PixelModuleFeMask_create_db.py:76
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
python.PyKernel.AttributeList
AttributeList
Definition: PyKernel.py:36
SG::VarHandleKey::key
const std::string & key() const
Return the StoreGate ID for the referenced object.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:141
CondAttrListCollection
This class is a collection of AttributeLists where each one is associated with a channel number....
Definition: CondAttrListCollection.h:52
LArCalib_HVScale2NtupleConfig.rootfile
string rootfile
Definition: LArCalib_HVScale2NtupleConfig.py:74
MagField::AtlasFieldMapCondAlg::execute
StatusCode execute(const EventContext &ctx) const override final
Definition: AtlasFieldMapCondAlg.cxx:82
AthenaPoolTestRead.sc
sc
Definition: AthenaPoolTestRead.py:27
SG::VarHandleKeyArray::setOwner
virtual void setOwner(IDataHandleHolder *o)=0
IDTPMcnv.htype
htype
Definition: IDTPMcnv.py:27
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
AthCommonDataStore
Definition: AthCommonDataStore.h:52
AthReentrantAlgorithm::AthReentrantAlgorithm
AthReentrantAlgorithm()
Default constructor:
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::outputHandles
virtual std::vector< Gaudi::DataHandle * > outputHandles() const override
Return this algorithm's output handles.
MagField::AtlasFieldMapCondAlg::m_mapsInputKey
SG::ReadCondHandleKey< CondAttrListCollection > m_mapsInputKey
Definition: AtlasFieldMapCondAlg.h:133
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
AthCommonDataStore< AthCommonMsg< Gaudi::Algorithm > >::m_detStore
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
Definition: AthCommonDataStore.h:393
AthReentrantAlgorithm::m_extendedExtraObjects
DataObjIDColl m_extendedExtraObjects
Extra output dependency collection, extended by AthAlgorithmDHUpdate to add symlinks.
Definition: AthReentrantAlgorithm.h:153
SG::VarHandleKeyArray::renounce
virtual void renounce()=0
SG::HandleClassifier::type
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
Definition: HandleClassifier.h:54
merge_scale_histograms.doc
string doc
Definition: merge_scale_histograms.py:9
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:221
AthReentrantAlgorithm::sysInitialize
virtual StatusCode sysInitialize() override
Override sysInitialize.
Definition: AthReentrantAlgorithm.cxx:96
SG::CondHandleKey::initialize
StatusCode initialize(bool used=true)
MagField::AtlasFieldMapCondAlg::checkCurrentFromConditions
StatusCode checkCurrentFromConditions(const EventContext &ctx, double &soleCurrent, double &toroCurrent, EventIDRange &rangeDCS) const
Definition: AtlasFieldMapCondAlg.cxx:427
MagField::AtlasFieldMapCondAlg::m_fullMapFilename
Gaudi::Property< std::string > m_fullMapFilename
map file names - if not read from cool
Definition: AtlasFieldMapCondAlg.h:73
a
TList * a
Definition: liststreamerinfos.cxx:10
h
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
CondAttrListCollection::const_iterator
ChanAttrListMap::const_iterator const_iterator
Definition: CondAttrListCollection.h:63
MagField::AtlasFieldMapCondAlg::m_soleMinCurrent
Gaudi::Property< double > m_soleMinCurrent
Definition: AtlasFieldMapCondAlg.h:102
MagField::AtlasFieldMapCondAlg::m_toroMapFilename
Gaudi::Property< std::string > m_toroMapFilename
Definition: AtlasFieldMapCondAlg.h:85
MagField::AtlasFieldMapCondAlg::m_loadMapOnStart
Gaudi::Property< bool > m_loadMapOnStart
Definition: AtlasFieldMapCondAlg.h:116
MagField::AtlasFieldMapCondAlg::updateFieldMap
StatusCode updateFieldMap(const EventContext &ctx, Cache &cache) const
Definition: AtlasFieldMapCondAlg.cxx:131
MagField::AtlasFieldMapCondAlg::m_toroMinCurrent
Gaudi::Property< double > m_toroMinCurrent
Definition: AtlasFieldMapCondAlg.h:108
SG::VarHandleBase::vhKey
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
Definition: StoreGate/src/VarHandleBase.cxx:623
MagField::AtlasFieldMapCondAlg::m_soleMapFilename
Gaudi::Property< std::string > m_soleMapFilename
Definition: AtlasFieldMapCondAlg.h:79
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:798
LHEF::Writer
Pythia8::Writer Writer
Definition: Prophecy4fMerger.cxx:12
MagField::AtlasFieldMapCondAlg::m_useMapsFromCOOL
Gaudi::Property< bool > m_useMapsFromCOOL
Definition: AtlasFieldMapCondAlg.h:124
MagField::AtlasFieldMapCondAlg::m_mapSoleCurrent
Gaudi::Property< double > m_mapSoleCurrent
nominal current for the maps
Definition: AtlasFieldMapCondAlg.h:92
MagField::AtlasFieldMapCondAlg::m_mapToroCurrent
Gaudi::Property< double > m_mapToroCurrent
Definition: AtlasFieldMapCondAlg.h:96
SG::WriteCondHandle
Definition: WriteCondHandle.h:26
AthCommonDataStore::declareGaudiProperty
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition: AthCommonDataStore.h:156
MagField::AtlasFieldMapCondAlg::start
StatusCode start() override final
Definition: AtlasFieldMapCondAlg.cxx:69
fitman.k
k
Definition: fitman.py:528
ServiceHandle< ICondSvc >