A simple algorithm that reads in the material maps and writes out a new file, allowing to manipulate the material maps.
More...
#include <MaterialManipulation.h>
A simple algorithm that reads in the material maps and writes out a new file, allowing to manipulate the material maps.
- Author
- Andre.nosp@m.as.S.nosp@m.alzbu.nosp@m.rger.nosp@m.@cern.nosp@m..ch
Definition at line 35 of file MaterialManipulation.h.
◆ StoreGateSvc_t
◆ MaterialManipulation()
| Trk::MaterialManipulation::MaterialManipulation |
( |
const std::string & | name, |
|
|
ISvcLocator * | pSvcLocator ) |
Standard Athena-Algorithm Constructor.
Definition at line 20 of file MaterialManipulation.cxx.
26{
28
31
32}
AthAlgorithm()
Default constructor:
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
std::string m_outputLayerMaterialMapName
ToolHandle< ILayerMaterialManipulator > m_layerMaterialManipulator
const LayerMaterialMap * m_inputLayerMaterialMap
output material properties
std::string m_inputLayerMaterialMapName
< input material properties
◆ ~MaterialManipulation()
| Trk::MaterialManipulation::~MaterialManipulation |
( |
| ) |
|
|
default |
◆ declareGaudiProperty()
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition at line 156 of file AthCommonDataStore.h.
158 {
161 hndl.documentation());
162
163 }
◆ declareProperty()
Definition at line 145 of file AthCommonDataStore.h.
145 {
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
◆ detStore()
◆ evtStore()
◆ execute()
| StatusCode Trk::MaterialManipulation::execute |
( |
| ) |
|
|
overridevirtual |
standard Athena-Algorithm method
Definition at line 49 of file MaterialManipulation.cxx.
50{
52
53 Trk::LayerMaterialMap* outputLayerMaterialMap = nullptr;
54
55
57
58
61 return StatusCode::FAILURE;
62 } else
64
65
66 outputLayerMaterialMap = new Trk::LayerMaterialMap();
67
69
71
72 const Trk::LayerMaterialProperties* lmp = nullptr;
73
76 else
77 lmp = lmIter.second->
clone();
78
79 (*outputLayerMaterialMap)[lmIter.first] = lmp;
80 }
81
82
84 if (eTable){
85 auto tElementTable = std::make_shared<Trk::ElementTable>(*eTable);
87 }
88
91 delete outputLayerMaterialMap;
92 } else
94
95 }
96 return StatusCode::SUCCESS;
97
98}
#define ATH_MSG_VERBOSE(x)
const ServiceHandle< StoreGateSvc > & detStore() const
void updateElementTable(const std::shared_ptr< const ElementTable > &eTable)
update method
virtual LayerMaterialProperties * clone() const =0
Pseudo-Constructor clone()
retrieve(aClass, aKey=None)
◆ extraDeps_update_handler()
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 & AthAlgorithm::extraOutputDeps |
( |
| ) |
const |
|
overridevirtualinherited |
Return the list of extra output dependencies.
This list is extended to include symlinks implied by inheritance relations.
Definition at line 50 of file AthAlgorithm.cxx.
51{
52
53
56 }
57 return Algorithm::extraOutputDeps();
58}
DataObjIDColl m_extendedExtraObjects
◆ finalize()
| StatusCode Trk::MaterialManipulation::finalize |
( |
| ) |
|
|
overridevirtual |
standard Athena-Algorithm method
Definition at line 101 of file MaterialManipulation.cxx.
102{
103
104 ATH_MSG_INFO(
"========================================================================================= ");
106 return StatusCode::SUCCESS;
107}
◆ initialize()
| StatusCode Trk::MaterialManipulation::initialize |
( |
| ) |
|
|
overridevirtual |
standard Athena-Algorithm method
Definition at line 37 of file MaterialManipulation.cxx.
38{
40
42 ATH_MSG_FATAL(
"Could not retrieve LayerMaterial manipulator - although configured. Aborting.");
43 return StatusCode::FAILURE;
44 }
45 return StatusCode::SUCCESS;
46}
◆ inputHandles()
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()
◆ msgLvl()
| bool AthCommonMsg< Algorithm >::msgLvl |
( |
const MSG::Level | lvl | ) |
const |
|
inlineinherited |
◆ outputHandles()
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()
Definition at line 380 of file AthCommonDataStore.h.
381 {
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()
◆ sysInitialize()
| StatusCode AthAlgorithm::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< Algorithm > >.
Reimplemented in AthAnalysisAlgorithm, AthFilterAlgorithm, AthHistogramAlgorithm, and PyAthena::Alg.
Definition at line 66 of file AthAlgorithm.cxx.
66 {
68
71 }
72 ServiceHandle<ICondSvc> cs(
"CondSvc",
name());
74 if (
h->isCondition() &&
h->mode() == Gaudi::DataHandle::Writer) {
75
76 if ( cs.retrieve().isFailure() ) {
78 return StatusCode::SUCCESS;
79 }
80 if (cs->regHandle(this,*h).isFailure()) {
81 sc = StatusCode::FAILURE;
82 ATH_MSG_ERROR(
"unable to register WriteCondHandle " <<
h->fullKey()
83 << " with CondSvc");
84 }
85 }
86 }
88}
#define ATH_MSG_WARNING(x)
virtual StatusCode sysInitialize() override
Override sysInitialize.
AthCommonDataStore(const std::string &name, T... args)
virtual std::vector< Gaudi::DataHandle * > outputHandles() const override
::StatusCode StatusCode
StatusCode definition for legacy code.
◆ sysStart()
Handle START transition.
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.
◆ updateVHKA()
Definition at line 308 of file AthCommonDataStore.h.
308 {
309
310
313 for (
auto k :
keys) {
315 }
316 }
317 }
std::vector< SG::VarHandleKeyArray * > m_vhka
◆ m_detStore
◆ m_evtStore
◆ m_extendedExtraObjects
| DataObjIDColl AthAlgorithm::m_extendedExtraObjects |
|
privateinherited |
◆ m_inputLayerMaterialMap
◆ m_inputLayerMaterialMapName
| std::string Trk::MaterialManipulation::m_inputLayerMaterialMapName |
|
private |
◆ m_layerMaterialManipulator
◆ m_outputLayerMaterialMapName
| std::string Trk::MaterialManipulation::m_outputLayerMaterialMapName |
|
private |
◆ m_varHandleArraysDeclared
◆ m_vhka
The documentation for this class was generated from the following files: