ATLAS Offline Software
LayerMaterialProvider.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration
3 */
4 
6 // LayerMaterialProvider.cxx, (c) ATLAS Detector software
8 
9 // STL
10 #include <sstream>
11 #include <atomic>
12 // Trk include
16 #include "TrkGeometry/Layer.h"
18 #include "TrkVolumes/Volume.h"
19 #include "TrkSurfaces/Surface.h"
22 
23 // constructor
24 Trk::LayerMaterialProvider::LayerMaterialProvider(const std::string& t, const std::string& n, const IInterface* p)
25 : base_class(t,n,p)
26 {
27  declareProperty ("LayerMaterialMapName", m_layerMaterialMapName,
28  "If LayerMaterialMapKey is not set, then fall back to retrieving this from the detector store.");
29 }
30 
31 // destructor
33 = default;
34 
35 
37 {
38  ATH_CHECK( m_layerMaterialMapKey.initialize (SG::AllowEmpty) );
39  return StatusCode::SUCCESS;
40 }
41 
42 // Processor Action to work on TrackingGeometry
45 {
46  const LayerMaterialMap* layerMaterialMap = nullptr;
47  if (!m_layerMaterialMapKey.key().empty()) {
48  SG::ReadCondHandle<LayerMaterialMap> layerMaterialMapH (m_layerMaterialMapKey);
49  layerMaterialMap = *layerMaterialMapH;
50  }
51  else {
52  ATH_CHECK( detStore()->retrieve (layerMaterialMap, m_layerMaterialMapName) );
53  }
54  dumpMaterialMap (*layerMaterialMap);
55 
56  ATH_MSG_VERBOSE("Start processing the TrackingGeometry recursively");
57  // retrieve the highest tracking volume
58  Trk::TrackingVolume* worldVolume = tgeo.highestTrackingVolume();
59  // check for the world volume
60  if (worldVolume){
61  // TrackingVolume : confined layers
62  ATH_MSG_VERBOSE("TrackingVolume '" << worldVolume->volumeName() << "' retrieved as highest level node.");
63  if (process(*worldVolume, *layerMaterialMap, 0).isFailure() ) {
64  ATH_MSG_FATAL("Could not load material maps for provided TrackingGeometry, abort job.");
65  return StatusCode::FAILURE;
66  }
67  // Boundary layers
68  if (!tgeo.boundaryLayers().empty()){
69  ATH_MSG_VERBOSE("TrackingGeometry has " << tgeo.numBoundaryLayers() << " unique boundary layers, loading material.");
70  for (const auto& bLayerIter : tgeo.boundaryLayers() ){
71  Trk::Layer* lay = bLayerIter.first;
72  int layCount = bLayerIter.second;
73  int layIndex = lay->layerIndex().value();
74  // only move on if layer index is different from 0
75  if (layIndex){
76  StatusCode sc( process(*lay, *layerMaterialMap, 0) );
77  // @TODO Currently recoverable errors are treated as failure. Is this the intended behaviour ? Elsewhere recoverable errors are treated as recoverable
78  if (sc.isSuccess())
79  ATH_MSG_DEBUG("---[B] Boundary layer with " << layCount << " references : successfully loaded material map for layer " << layIndex );
80  // else if (sc.isRecoverable())
81  // ATH_MSG_WARNING("Failed to call process(const Layer&) on layers - but recoverable.");
82  else {
83  ATH_MSG_FATAL("Failed to call process(const Layer&) on layer. Aborting.");
84  return StatusCode::FAILURE;
85  }
86  }
87  } // loop over layers
88  }// we have boundary layers
89  return StatusCode::SUCCESS;
90  } // we have a world volume
91  // abort job
92  ATH_MSG_FATAL("No highest level TrackingVolume found. Stopping recursive parsing, abort job.");
93  return StatusCode::FAILURE;
94 }
95 
96 // Processor Action to work on TrackingVolumes
99  size_t level) const
100 {
101  const LayerMaterialMap* layerMaterialMap = nullptr;
102  if (!m_layerMaterialMapKey.key().empty()) {
103  SG::ReadCondHandle<LayerMaterialMap> layerMaterialMapH (m_layerMaterialMapKey);
104  layerMaterialMap = *layerMaterialMapH;
105  }
106  else {
107  ATH_CHECK( detStore()->retrieve (layerMaterialMap, m_layerMaterialMapName) );
108  }
109  dumpMaterialMap (*layerMaterialMap);
110  ATH_CHECK( process (tvol, *layerMaterialMap, level) );
111  return StatusCode::SUCCESS;
112 }
113 
116  const LayerMaterialMap& layerMaterialMap,
117  size_t level) const
118 {
119  std::stringstream displayBuffer;
120  for (size_t il = 0; il < level; ++il) displayBuffer << " ";
121  // formatted screen output
122  ATH_MSG_VERBOSE(displayBuffer.str() << "TrackingVolume '" << tvol.volumeName() << "'");
123 
124  // @TODO add boundary surfaces
125 
126  // Process the contained layers
127  Trk::LayerArray* layerArray = tvol.confinedLayers();
128  if (layerArray) {
129  // display output
131  ATH_MSG_VERBOSE(displayBuffer.str() << "--> has " << layers.size() << " confined layers." );
132  for ( const auto & layIter : layers ){
133  if (!layIter)
134  ATH_MSG_WARNING("Zero-pointer found in LayerArray - indicates problem !");
135  else {
136  // get the layer index and only process if it's an indexed layer
137  int layIndex = layIter->layerIndex().value();
138  if (layIndex){
139  StatusCode sc = process(*layIter, layerMaterialMap, level);
140  if (sc.isSuccess())
141  ATH_MSG_DEBUG(displayBuffer.str() << "---[M] Material layer: successfully loaded material map for layer " << layIndex );
142  else if (sc.isRecoverable())
143  ATH_MSG_WARNING("Failed to call process(const Layer&) on layers - but recoverable.");
144  else {
145  ATH_MSG_FATAL("Failed to call process(const Layer&) on layer. Aborting.");
146  return StatusCode::FAILURE;
147  }
148  } else
149  ATH_MSG_DEBUG(displayBuffer.str() << "---[o] Navigation layer: skipping.");
150  }
151  }
152  }
153 
154  // Process the contained TrackingVolumes (recursively) if they exist
156  // register the next round
157  if (confinedVolumes) {
160  for (; volumesIter != volumes.end(); ++volumesIter){
161  if (!(*volumesIter))
162  ATH_MSG_WARNING("Zero-pointer found in VolumeArray - indicates problem !");
163  if ((*volumesIter) && process(**volumesIter, layerMaterialMap, ++level).isFailure() ){
164  ATH_MSG_FATAL("Failed to call process(const TrackingVolume&) on confined volumes. Aborting.");
165  return StatusCode::FAILURE;
166  }
167  }
168  }
169 
170  // return
171  return StatusCode::SUCCESS;
172 }
173 
174 // Processor Action to work on Layers
177 {
178  const LayerMaterialMap* layerMaterialMap = nullptr;
179  if (!m_layerMaterialMapKey.key().empty()) {
180  SG::ReadCondHandle<LayerMaterialMap> layerMaterialMapH(
181  m_layerMaterialMapKey);
182  layerMaterialMap = *layerMaterialMapH;
183  } else {
184  ATH_CHECK(detStore()->retrieve(layerMaterialMap, m_layerMaterialMapName));
185  }
186  dumpMaterialMap(*layerMaterialMap);
187  ATH_CHECK(process(lay, *layerMaterialMap, level));
188  return StatusCode::SUCCESS;
189 }
190 
193  const LayerMaterialMap& layerMaterialMap,
194  size_t level) const
195 {
196  // skip Layers w/o material
197  if (!lay.layerMaterialProperties())
198  return StatusCode::SUCCESS;
199 
200  // get the layer index for assignment
201  Trk::LayerIndex lIndex = lay.layerIndex();
202 
203  // display
204  std::stringstream displayBuffer;
205  for (size_t il = 0; il < level; ++il)
206  displayBuffer << " ";
207 
208  // find the layer and assign the material properties
209  auto lmIter = layerMaterialMap.find(lIndex);
210  if (lmIter != layerMaterialMap.end()) {
211  ATH_MSG_VERBOSE(displayBuffer.str()
212  << "---[+] found material for Layer with Index: "
213  << lIndex.value());
214  if (lay.surfaceRepresentation().isFree()) {
215  ATH_MSG_VERBOSE(displayBuffer.str()
216  << "---[!] the Layer is not owned by the "
217  "TrackingGeometry, could indicate problem.");
218  } else {
219  ATH_MSG_VERBOSE(displayBuffer.str()
220  << "---[+] the Layer is owned by the TrackingGeometry.");
221  }
222  lay.assignMaterialProperties(*((*lmIter).second));
223  } else {
224  ATH_MSG_WARNING(displayBuffer.str()
225  << "---[!] could not find material for Layer with Index: "
226  << lIndex.value());
227  return StatusCode::RECOVERABLE;
228  }
229  return StatusCode::SUCCESS;
230 }
231 
232 // Processor Action to work on Surfaces
234  return StatusCode::SUCCESS;
235 }
236 
237 
238 void
240 {
241  if (msgLvl (MSG::VERBOSE)) {
242  static std::atomic_flag flag ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT;
243  if (!flag.test_and_set()) {
244  ATH_MSG_VERBOSE("Listing the layer indeces found in the loaded LayerMaterialMap");
245  for ( const auto & lmIter : layerMaterialMap ){
246  ATH_MSG_VERBOSE(" -> Found map for layer with index " << lmIter.first);
247  }
248  }
249  }
250 }
251 
python.PyKernel.retrieve
def retrieve(aClass, aKey=None)
Definition: PyKernel.py:110
PlotCalibFromCool.il
il
Definition: PlotCalibFromCool.py:381
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
Trk::LayerMaterialProvider::~LayerMaterialProvider
virtual ~LayerMaterialProvider()
Destructor.
SG::ReadCondHandle
Definition: ReadCondHandle.h:44
Surface.h
Trk::TrackingGeometry::numBoundaryLayers
size_t numBoundaryLayers() const
Trk::LayerMaterialProvider::initialize
virtual StatusCode initialize() override
Definition: LayerMaterialProvider.cxx:36
module_driven_slicing.layers
layers
Definition: module_driven_slicing.py:114
Layer.h
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
SUSY_SimplifiedModel_PostInclude.process
string process
Definition: SUSY_SimplifiedModel_PostInclude.py:42
Trk::LayerMaterialMap
Definition: LayerMaterialMap.h:32
ReadCondHandle.h
AthenaPoolTestRead.sc
sc
Definition: AthenaPoolTestRead.py:27
python.iconfTool.models.loaders.level
level
Definition: loaders.py:20
Trk::LayerMaterialProvider::m_layerMaterialMapName
std::string m_layerMaterialMapName
Definition: LayerMaterialProvider.h:80
Trk::TrackingVolume::confinedLayers
const LayerArray * confinedLayers() const
Return the subLayer array.
Trk::LayerMaterialProvider::dumpMaterialMap
void dumpMaterialMap(const LayerMaterialMap &layerMaterialMap) const
Definition: LayerMaterialProvider.cxx:239
Trk::Layer::assignMaterialProperties
void assignMaterialProperties(const LayerMaterialProperties &, double scale=1.0)
assignMaterialPropeties
Definition: Layer.cxx:191
Volume.h
Trk::TrackingGeometry::highestTrackingVolume
const TrackingVolume * highestTrackingVolume() const
return the world
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
Trk::Layer::surfaceRepresentation
virtual const Surface & surfaceRepresentation() const =0
Transforms the layer into a Surface representation for extrapolation.
Trk::LayerIndex
Definition: LayerIndex.h:37
beamspotman.n
n
Definition: beamspotman.py:731
Trk::TrackingGeometry
Definition: TrackingGeometry.h:67
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
master.flag
bool flag
Definition: master.py:29
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
Trk::LayerIndex::value
int value() const
layerIndex expressed in an integer
Definition: LayerIndex.h:71
python.PyKernel.detStore
detStore
Definition: PyKernel.py:41
Trk::TrackingVolume::volumeName
const std::string & volumeName() const
Returns the VolumeName - for debug reason, might be depreciated later.
Trk::LayerMaterialProvider::process
virtual StatusCode process(TrackingGeometry &tgeo) const override
Processor Action to work on TrackingGeometry& tgeo.
Definition: LayerMaterialProvider.cxx:44
Trk::BinnedArray::arrayObjects
virtual BinnedArraySpan< T *const > arrayObjects()=0
Return all objects of the Array non-const we can still modify the T.
Trk::LayerMaterialProvider::LayerMaterialProvider
LayerMaterialProvider(const std::string &, const std::string &, const IInterface *)
Constructor.
Definition: LayerMaterialProvider.cxx:24
LayerMaterialMap.h
Trk::TrackingGeometry::boundaryLayers
const std::map< Layer *, int > & boundaryLayers()
Return the unique BoundarySurfaces with MaterialInformation.
Trk::Surface::isFree
bool isFree() const
Returns 'true' if this surface is 'free', i.e.
TrackingVolume.h
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
Trk::TrackingVolume::confinedVolumes
const TrackingVolumeArray * confinedVolumes() const
Return the subLayer array.
Trk::Layer::layerMaterialProperties
const LayerMaterialProperties * layerMaterialProperties() const
getting the LayerMaterialProperties including full/pre/post update
TrackingGeometry.h
ATLAS_THREAD_SAFE
#define ATLAS_THREAD_SAFE
Definition: checker_macros.h:211
python.Constants.VERBOSE
int VERBOSE
Definition: Control/AthenaCommon/python/Constants.py:14
Trk::BinnedArray
Definition: BinnedArray.h:38
Trk::Surface
Definition: Tracking/TrkDetDescr/TrkSurfaces/TrkSurfaces/Surface.h:75
checker_macros.h
Define macros for attributes used to control the static checker.
SG::AllowEmpty
@ AllowEmpty
Definition: StoreGate/StoreGate/VarHandleKey.h:30
Trk::TrackingVolume
Definition: TrackingVolume.h:121
Trk::BinnedArraySpan
std::span< T > BinnedArraySpan
Definition: BinnedArray.h:34
LayerMaterialProvider.h
Trk::Layer
Definition: Layer.h:73
Trk::Layer::layerIndex
const LayerIndex & layerIndex() const
get the layerIndex