Loading [MathJax]/extensions/tex2jax.js
ATLAS Offline Software
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
src/PixelDetectorTool.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3 */
4 
5 
6 #include "PixelDetectorTool.h"
7 #include "PixelDetectorFactory.h"
10 #include "PixelDetectorFactoryDC2.h"
11 #include "PixelGeometryManager.h"
12 #include "PixelSwitches.h"
13 
19 #include "GaudiKernel/ServiceHandle.h"
22 #include "GeoModelRead/ReadGeoModel.h"
23 
27 
29 #include "SGTools/DataProxy.h"
30 
32 
35 
36 PixelDetectorTool::PixelDetectorTool( const std::string& type, const std::string& name, const IInterface* parent )
38 {
39  declareProperty("Services",m_services);
40  declareProperty("ServicesOnLadder",m_servicesOnLadder);
41  declareProperty("Alignable", m_alignable);
42  declareProperty("TweakIBLDist", m_tweakIBLDist);
43  declareProperty("DC1Geometry",m_dc1Geometry);
44  declareProperty("InitialLayout",m_initialLayout);
45  declareProperty("DevVersion", m_devVersion);
46  declareProperty("OverrideVersionName", m_overrideVersionName);
47  declareProperty("useDynamicAlignFolders", m_useDynamicAlignFolders);
48 }
49 
51 {
52  delete m_athenaComps;
53 }
54 
55 
57 {
58  if (!m_bcmTool.empty()) {
59  ATH_CHECK( m_bcmTool.retrieve() );
60  }
61  if (!m_blmTool.empty()) {
62  ATH_CHECK( m_blmTool.retrieve() );
63  }
64  return StatusCode::SUCCESS;
65 }
66 
71 {
72  if (m_devVersion) ATH_MSG_WARNING("You are using a development version. There are no guarantees of stability");
73 
74  // Get the detector configuration.
75  ServiceHandle<IGeoDbTagSvc> geoDbTagSvc("GeoDbTagSvc",name());
76  ATH_CHECK(geoDbTagSvc.retrieve());
77 
78  ServiceHandle<IRDBAccessSvc> rdbAccessSvc(geoDbTagSvc->getParamSvcName(),name());
79  ATH_CHECK(rdbAccessSvc.retrieve());
80 
81 
82  GeoModelExperiment* theExpt = nullptr;
83  ATH_CHECK(detStore()->retrieve(theExpt,"ATLAS"));
84 
85  GeoPhysVol *world=theExpt->getPhysVol();
86  GeoModelIO::ReadGeoModel* sqliteReader = geoDbTagSvc->getSqliteReader();
87 
88  std::string detectorKey{""};
89  std::string detectorNode{""};
90  if(!sqliteReader) {
91  DecodeVersionKey decodeVersion(geoDbTagSvc.operator->(), "Pixel");
92  detectorKey = decodeVersion.tag();
93  detectorNode = decodeVersion.node();
94  if(decodeVersion.custom()) {
95  ATH_MSG_WARNING("PixelDetectorTool: Detector Information coming from a custom configuration!!" );
96  }
97  }
98 
99  IRDBRecordset_ptr switchSet = rdbAccessSvc->getRecordsetPtr("PixelSwitches", detectorKey, detectorNode);
100  const IRDBRecord *switchTable = (*switchSet)[0];
101 
102  std::string versionName;
103  std::string descrName="noDescr";
104 
105  m_dc1Geometry = switchTable->getInt("DC1GEOMETRY");
106  m_initialLayout = switchTable->getInt("INITIALLAYOUT");
107  if (!switchTable->isFieldNull("VERSIONNAME")) {
108  versionName = switchTable->getString("VERSIONNAME");
109  }
110  if (!switchTable->isFieldNull("DESCRIPTION")) {
111  descrName = switchTable->getString("DESCRIPTION");
112  }
113  m_buildDBM = switchTable->getInt("BUILDDBM");
114 
115  // Initialize switches
116  PixelSwitches switches;
117 
118  switches.setServices(m_services);
119  switches.setDC1Geometry(m_dc1Geometry);
120  switches.setAlignable(m_alignable);
122  switches.setDBM(m_buildDBM); //DBM flag
124 
125  //JBdV
127  switches.setServices(m_services); //Overwrite there for the time being.
128 
129  const PixelID * idHelper = nullptr;
130  ATH_CHECK(detStore()->retrieve(idHelper, "PixelID"));
131 
132  // Retrieve the Geometry DB Interface
133  ATH_CHECK(m_geometryDBSvc.retrieve());
134 
135  // Pass athena services to factory, etc
137  m_athenaComps->setDetStore(detStore().operator->());
138  m_athenaComps->setGeoDbTagSvc(&*geoDbTagSvc);
139  m_athenaComps->setRDBAccessSvc(&*rdbAccessSvc);
141  m_athenaComps->setIdHelper(idHelper);
142 
143  // BCM Tool.
144  if (!m_bcmTool.empty()) {
145  if (!m_bcmTool.retrieve().isFailure()) {
146  ATH_MSG_INFO("BCM_GeoModel tool retrieved: " << m_bcmTool );
147  } else {
148  ATH_MSG_INFO("Could not retrieve " << m_bcmTool << " - BCM will not be built" );
149  }
151  }
152  else {
153  ATH_MSG_INFO("BCM not requested." );
154  }
155 
156  // BLM Tool.
157  if (!m_blmTool.empty()) {
158  if (!m_blmTool.retrieve().isFailure()) {
159  ATH_MSG_INFO("BLM_GeoModel tool retrieved: " << m_blmTool );
160  }
161  else {
162  ATH_MSG_INFO("Could not retrieve " << m_blmTool << " - BLM will not be built" );
163  }
165  }
166  else {
167  ATH_MSG_INFO("BLM not requested." );
168  }
169 
170  // Service builder tool
171  if (!m_serviceBuilderTool.empty()) {
172  if (!m_serviceBuilderTool.retrieve().isFailure()) {
173  ATH_MSG_INFO("Service builder tool retrieved: " << m_serviceBuilderTool );
175  }
176  else {
177  ATH_MSG_ERROR("Could not retrieve " << m_serviceBuilderTool << ", some services will not be built." );
178  }
179  }
180  else {
181  if (versionName == "SLHC") { // TODO
182  ATH_MSG_ERROR("Service builder tool not specified. Some services will not be built" );
183  }
184  else {
185  ATH_MSG_INFO("Service builder tool not specified." );
186  }
187  }
188 
189  if(sqliteReader) {
190  // ---------------------- Build from SQLite file --------------------------
191  ATH_MSG_INFO("Building the geometry from the SQLite file");
192 
193  ATH_MSG_DEBUG("Creating the Pixel ");
194  ATH_MSG_DEBUG("Pixel Geometry Options:");
195  ATH_MSG_DEBUG(" Services = " << (m_services ? "true" : "false"));
196  ATH_MSG_DEBUG(" Alignable = " << (m_alignable ? "true" : "false"));
197  ATH_MSG_DEBUG(" DC1Geometry = " << (m_dc1Geometry ? "true" : "false"));
198  ATH_MSG_DEBUG(" InitialLayout = " << (m_initialLayout ? "true" : "false"));
199  ATH_MSG_DEBUG(" VersioName = " << versionName );
200 
201  if (versionName == "IBL") switches.setIBL();
202 
203  PixelDetectorFactoryLite thePixelFactory(sqliteReader,m_athenaComps,switches);
204  thePixelFactory.create(world);
205  m_manager=thePixelFactory.getDetectorManager();
206  }
207  else {
208  // ---------------------- Build from GeometryDB --------------------------
209  ATH_MSG_INFO("Building Pixel Detector with Version Tag: " << detectorKey
210  << " at Node: " << detectorNode);
211 
212  ATH_MSG_INFO("Building the geometry in the standard way");
213 
214  // Print the version tag:
215  std::string pixelVersionTag = rdbAccessSvc->getChildTag("Pixel", detectorKey, detectorNode);
216  ATH_MSG_INFO("Pixel Version: " << pixelVersionTag );
217 
218  // Check if version is empty. If so, then the Pixel cannot be built. This may or may not be intentional.
219  // We just issue an INFO message.
220  if (pixelVersionTag.empty()) {
221  ATH_MSG_INFO("No Pixel Version. Pixel Detector will not be built." );
222  return StatusCode::SUCCESS;
223  }
224 
225  // Unless we are using custom pixel, the switch positions are going to
226  // come from the database:
227 
228  ATH_MSG_DEBUG("PixelDetectorTool: Detector Information coming from the database and job options IGNORED." );
229  ATH_MSG_DEBUG("Keys for Pixel Switches are " << detectorKey << " " << detectorNode );
230 
231  if (versionName.empty()) {
232  if (m_dc1Geometry) {
233  versionName = "DC1";
234  }
235  else {
236  versionName = "DC2";
237  }
238  }
239 
240  if (!m_overrideVersionName.empty()) {
241  versionName = m_overrideVersionName;
242  ATH_MSG_INFO("Overriding version name: " << versionName );
243  }
244 
245  ATH_MSG_DEBUG("Creating the Pixel " );
246  ATH_MSG_DEBUG("Pixel Geometry Options:" );
247  ATH_MSG_DEBUG(" Services = " << (m_services ? "true" : "false") );
248  ATH_MSG_DEBUG(" Alignable = " << (m_alignable ? "true" : "false"));
249  ATH_MSG_DEBUG(" DC1Geometry = " << (m_dc1Geometry ? "true" : "false"));
250  ATH_MSG_DEBUG(" InitialLayout = " << (m_initialLayout ? "true" : "false"));
251  ATH_MSG_DEBUG(" VersioName = " << versionName );
252 
253  if (m_IBLParameterSvc.retrieve().isFailure()) {
254  ATH_MSG_WARNING( "Could not retrieve IBLParameterSvc");
255  }
256  else {
257  m_IBLParameterSvc->setBoolParameters(m_alignable,"alignable");
258  }
259 
260  if (versionName == "IBL") switches.setIBL();
261 
262  if (!m_devVersion) {
263 
264  if(versionName == "DC1" || versionName == "DC2") {
265  // DC1/DC2 version
266  PixelDetectorFactoryDC2 thePixel(m_athenaComps, switches);
267  thePixel.create(world);
268  m_manager = thePixel.getDetectorManager();
269  }
270  else if (versionName == "SR1") {
271  // SR1. Same a DC3 but only 1 part (barrel, ec A or ec C) built
272  PixelDetectorFactorySR1 thePixel(m_athenaComps, switches);
273  thePixel.create(world);
274  m_manager = thePixel.getDetectorManager();
275  }
276  else {
277  // DC3, SLHC, IBL
278  PixelDetectorFactory thePixel(m_athenaComps, switches);
279  if(descrName.compare("TrackingGeometry")!=0) {
280  thePixel.create(world);
281  }
282  else {
283  ATH_MSG_INFO("Pixel - TrackingGeometry tag - no geometry built" );
284  }
285  m_manager = thePixel.getDetectorManager();
286  }
287 
288  }
289  else {
290  // DEVELOPMENT VERSIONS
291  PixelDetectorFactory thePixel(m_athenaComps, switches);
292  thePixel.create(world);
293  m_manager = thePixel.getDetectorManager();
294  }
295  }
296 
297  // Register the manager to the Det Store
298  ATH_CHECK(detStore()->record(m_manager, m_manager->getName()));
299  // Add the manager to the experiment
300  theExpt->addManager(m_manager);
301 
302  // Symlink the manager
303  const SiDetectorManager * siDetManager = m_manager;
304  ATH_CHECK(detStore()->symLink(m_manager, siDetManager));
305 
306  return StatusCode::SUCCESS;
307 }
308 
310 {
312  if(proxy) {
313  proxy->reset();
314  m_manager = nullptr;
315  }
316  return StatusCode::SUCCESS;
317 }
318 
319 StatusCode
321 {
322  if (!m_manager) {
323  ATH_MSG_WARNING("Manager does not exist" );
324  return StatusCode::FAILURE;
325  }
326  if (m_alignable) {
327  return m_manager->align(I,keys);
328  } else {
329  ATH_MSG_DEBUG("Alignment disabled. No alignments applied" );
330  return StatusCode::SUCCESS;
331  }
332 }
IRDBRecord::getInt
virtual int getInt(const std::string &fieldName) const =0
Get int field value.
python.PyKernel.retrieve
def retrieve(aClass, aKey=None)
Definition: PyKernel.py:110
PixelDetectorFactory::getDetectorManager
virtual const InDetDD::PixelDetectorManager * getDetectorManager() const
Definition: PixelDetectorFactory.cxx:212
PixelDetectorFactoryLite::create
virtual void create(GeoPhysVol *world) override
Definition: PixelDetectorFactoryLite.cxx:111
GeoModelExperiment::getPhysVol
GeoPhysVol * getPhysVol()
Destructor.
Definition: GeoModelExperiment.cxx:21
PixelDetectorFactorySR1.h
PixelDetectorTool::m_blmTool
ToolHandle< IGeoSubDetTool > m_blmTool
Definition: src/PixelDetectorTool.h:55
PixelDetectorTool::m_overrideVersionName
std::string m_overrideVersionName
Definition: src/PixelDetectorTool.h:59
PixelDetectorTool::~PixelDetectorTool
virtual ~PixelDetectorTool() override final
Definition: src/PixelDetectorTool.cxx:50
StateLessPT_NewConfig.proxy
proxy
Definition: StateLessPT_NewConfig.py:392
PixelDetectorTool::initialize
virtual StatusCode initialize() override final
Definition: src/PixelDetectorTool.cxx:56
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
PixelDetectorFactoryDC2
Definition: PixelDetectorFactoryDC2.h:21
PixelDetectorTool::m_initialLayout
bool m_initialLayout
Definition: src/PixelDetectorTool.h:50
PixelSwitches
Definition: PixelSwitches.h:13
PixelDetectorFactoryDC2.h
IRDBRecord::getString
virtual const std::string & getString(const std::string &fieldName) const =0
Get string field value.
GeoModelExperiment
Definition: GeoModelExperiment.h:32
PixelDetectorTool::m_useDynamicAlignFolders
bool m_useDynamicAlignFolders
Definition: src/PixelDetectorTool.h:53
PixelDetectorFactorySR1::getDetectorManager
virtual const InDetDD::PixelDetectorManager * getDetectorManager() const
Definition: PixelDetectorFactorySR1.cxx:259
IOVSVC_CALLBACK_ARGS_P
#define IOVSVC_CALLBACK_ARGS_P(I, K)
short hand for IOVSvc call back argument list, to be used when access to formal arguments is needed,...
Definition: IOVSvcDefs.h:42
PixelDetectorTool::m_dc1Geometry
bool m_dc1Geometry
Definition: src/PixelDetectorTool.h:47
PixelGeoModelAthenaComps::setIdHelper
void setIdHelper(const PixelID *idHelper)
Definition: PixelGeoModelAthenaComps.cxx:53
PixelDetectorTool::m_bcmTool
ToolHandle< IGeoSubDetTool > m_bcmTool
Definition: src/PixelDetectorTool.h:54
python.CaloAddPedShiftConfig.type
type
Definition: CaloAddPedShiftConfig.py:42
PixelGeometryManager.h
PixelDetectorFactory
Definition: PixelDetectorFactory.h:19
PixelDetectorTool::m_IBLParameterSvc
ServiceHandle< IIBLParameterSvc > m_IBLParameterSvc
Definition: src/PixelDetectorTool.h:46
PixelDetectorTool::m_devVersion
bool m_devVersion
Definition: src/PixelDetectorTool.h:51
PixelDetectorFactory.h
InDetDD::AthenaComps::setGeoDbTagSvc
void setGeoDbTagSvc(IGeoDbTagSvc *)
Definition: InDetDDAthenaComps.cxx:22
PixelDetectorTool::PixelDetectorTool
PixelDetectorTool(const std::string &type, const std::string &name, const IInterface *parent)
Definition: src/PixelDetectorTool.cxx:36
InDetDD::AthenaComps::setDetStore
void setDetStore(StoreGateSvc *)
Definition: InDetDDAthenaComps.cxx:17
PixelGeoModelAthenaComps.h
GeoModelExperiment.h
PixelDetectorFactorySR1::create
virtual void create(GeoPhysVol *world)
Definition: PixelDetectorFactorySR1.cxx:105
PixelSwitches::setDBM
void setDBM(bool flag=false)
Definition: PixelSwitches.cxx:43
InDetDD_Defs.h
PixelDetectorManager.h
IRDBAccessSvc.h
Definition of the abstract IRDBAccessSvc interface.
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
PixelDetectorTool::create
virtual StatusCode create() override final
Create the Detector Node corresponding to this tool.
Definition: src/PixelDetectorTool.cxx:70
ClassID_traits.h
a traits class that associates a CLID to a type T It also detects whether T inherits from Gaudi DataO...
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
AlignableTransformContainer.h
DecodeVersionKey
This is a helper class to query the version tags from GeoModelSvc and determine the appropriate tag a...
Definition: DecodeVersionKey.h:18
ClassID_traits
Default, invalid implementation of ClassID_traits.
Definition: Control/AthenaKernel/AthenaKernel/ClassID_traits.h:37
test_pyathena.parent
parent
Definition: test_pyathena.py:15
DecodeVersionKey::tag
const std::string & tag() const
Return version tag.
Definition: DecodeVersionKey.cxx:91
GeoModelTool
Definition: GeoModelTool.h:16
InDetDD::AthenaComps::setRDBAccessSvc
void setRDBAccessSvc(IRDBAccessSvc *)
Definition: InDetDDAthenaComps.cxx:27
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
IRDBRecordset_ptr
std::shared_ptr< IRDBRecordset > IRDBRecordset_ptr
Definition: IRDBAccessSvc.h:25
PixelDetectorTool::m_servicesOnLadder
bool m_servicesOnLadder
Definition: src/PixelDetectorTool.h:44
PixelSwitches::setInitialLayout
void setInitialLayout(bool flag)
Definition: PixelSwitches.cxx:29
PixelSwitches::setServices
void setServices(bool flag)
Definition: PixelSwitches.cxx:19
PixelDetectorFactoryDC2::getDetectorManager
virtual const InDetDD::PixelDetectorManager * getDetectorManager() const
Definition: PixelDetectorFactoryDC2.cxx:184
PixelSwitches::setIBL
void setIBL(bool flag=true)
Definition: PixelSwitches.cxx:40
PixelSwitches::setServicesOnLadder
void setServicesOnLadder(bool flag)
Definition: PixelSwitches.cxx:22
python.PyKernel.detStore
detStore
Definition: PyKernel.py:41
PixelDetectorTool::m_geometryDBSvc
ServiceHandle< IGeometryDBSvc > m_geometryDBSvc
Definition: src/PixelDetectorTool.h:57
InDetDD::PixelDetectorManager
Definition: PixelDetectorManager.h:47
PixelSwitches.h
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:240
PixelDetectorTool::m_buildDBM
bool m_buildDBM
Definition: src/PixelDetectorTool.h:52
InDetDD::InDetDetectorManager::align
StatusCode align(IOVSVC_CALLBACK_ARGS) const
PixelGeoModelAthenaComps::setBCM
void setBCM(IGeoSubDetTool *bcmTool)
Definition: PixelGeoModelAthenaComps.cxx:17
PixelGeoModelAthenaComps::setServiceBuilderTool
void setServiceBuilderTool(IInDetServMatBuilderTool *serviceBuilderTool)
Definition: PixelGeoModelAthenaComps.cxx:41
PixelDetectorFactory::create
virtual void create(GeoPhysVol *world)
Definition: PixelDetectorFactory.cxx:112
PixelDetectorFactorySR1
Definition: PixelDetectorFactorySR1.h:18
DecodeVersionKey.h
PixelDetectorTool::m_tweakIBLDist
bool m_tweakIBLDist
Definition: src/PixelDetectorTool.h:49
GeoModelExperiment::addManager
void addManager(const GeoVDetectorManager *)
Definition: GeoModelExperiment.cxx:40
PixelSwitches::setDynamicAlignFolders
void setDynamicAlignFolders(const bool useDynAlignFolders)
Definition: PixelSwitches.cxx:46
PixelGeoModelAthenaComps
Class to hold various Athena components.
Definition: PixelGeoModelAthenaComps.h:16
IRDBRecord.h
Definition of the abstract IRDBRecord interface.
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
IRDBRecord::isFieldNull
virtual bool isFieldNull(const std::string &fieldName) const =0
Check if the field value is NULL.
PixelDetectorTool::m_services
bool m_services
Definition: src/PixelDetectorTool.h:43
IRDBRecord
IRDBRecord is one record in the IRDBRecordset object.
Definition: IRDBRecord.h:27
InDetDD::AthenaComps::setGeometryDBSvc
void setGeometryDBSvc(IGeometryDBSvc *)
Definition: InDetDDAthenaComps.cxx:32
PixelDetectorTool::align
virtual StatusCode align(IOVSVC_CALLBACK_ARGS) override
Definition: src/PixelDetectorTool.cxx:320
InDetDD::SiDetectorManager
Definition: SiDetectorManager.h:60
PixelDetectorFactoryLite
Definition: PixelDetectorFactoryLite.h:28
PixelGeoModelAthenaComps::setBLM
void setBLM(IGeoSubDetTool *blmTool)
Definition: PixelGeoModelAthenaComps.cxx:29
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:798
PixelDetectorTool.h
I
#define I(x, y, z)
Definition: MD5.cxx:116
IRDBRecordset.h
Definition of the abstract IRDBRecordset interface.
PixelDetectorFactoryLite::getDetectorManager
virtual const InDetDD::PixelDetectorManager * getDetectorManager() const override
Definition: PixelDetectorFactoryLite.h:43
PixelDetectorFactoryDC2::create
virtual void create(GeoPhysVol *world)
Definition: PixelDetectorFactoryDC2.cxx:120
checker_macros.h
Define macros for attributes used to control the static checker.
PixelSwitches::setAlignable
void setAlignable(bool flag)
Definition: PixelSwitches.cxx:37
PixelID
Definition: PixelID.h:67
SG::DataProxy
Definition: DataProxy.h:45
PixelDetectorFactoryLite.h
PixelSwitches::setDC1Geometry
void setDC1Geometry(bool flag)
Definition: PixelSwitches.cxx:33
IGeoDbTagSvc.h
PixelDetectorTool::m_athenaComps
PixelGeoModelAthenaComps * m_athenaComps
Definition: src/PixelDetectorTool.h:61
PixelDetectorTool::m_manager
const InDetDD::PixelDetectorManager * m_manager
Definition: src/PixelDetectorTool.h:58
PixelDetectorTool::m_alignable
bool m_alignable
Definition: src/PixelDetectorTool.h:48
PixelDetectorTool::clear
virtual StatusCode clear() override final
Definition: src/PixelDetectorTool.cxx:309
ServiceHandle< IGeoDbTagSvc >
PixelDetectorTool::m_serviceBuilderTool
PublicToolHandle< IInDetServMatBuilderTool > m_serviceBuilderTool
Definition: src/PixelDetectorTool.h:56
DataProxy.h