ATLAS Offline Software
Loading...
Searching...
No Matches
G4AtlasDetectorConstructionTool::G4AtlasDetectorConstruction Class Reference

G4VUserDetectorConstruction object passed to the G4 run manager Thid shouldn't live longer than the parent tool. More...

#include <G4AtlasDetectorConstructionTool.h>

Inheritance diagram for G4AtlasDetectorConstructionTool::G4AtlasDetectorConstruction:
Collaboration diagram for G4AtlasDetectorConstructionTool::G4AtlasDetectorConstruction:

Public Member Functions

 G4AtlasDetectorConstruction (G4AtlasDetectorConstructionTool *detConstructionTool)
virtual G4VPhysicalVolume * Construct () override final
virtual void ConstructSDandField () override final
bool msgLvl (const MSG::Level lvl) const
 Test the output level.
MsgStream & msg () const
 The standard message stream.
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream.
void setLevel (MSG::Level lvl)
 Change the current logging level.

Private Member Functions

void initMessaging () const
 Initialize our message level and MessageSvc.

Private Attributes

G4AtlasDetectorConstructionToolm_detConstructionTool
std::string m_nm
 Message source name.
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels)
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer.
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level.
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging)

Detailed Description

G4VUserDetectorConstruction object passed to the G4 run manager Thid shouldn't live longer than the parent tool.

Definition at line 40 of file G4AtlasDetectorConstructionTool.h.

Constructor & Destructor Documentation

◆ G4AtlasDetectorConstruction()

G4AtlasDetectorConstructionTool::G4AtlasDetectorConstruction::G4AtlasDetectorConstruction ( G4AtlasDetectorConstructionTool * detConstructionTool)
inline

Definition at line 43 of file G4AtlasDetectorConstructionTool.h.

45 : AthMessaging("G4AtlasDetectorConstruction"),
46 m_detConstructionTool(detConstructionTool) {}
AthMessaging()
Default constructor:

Member Function Documentation

◆ Construct()

G4VPhysicalVolume * G4AtlasDetectorConstructionTool::G4AtlasDetectorConstruction::Construct ( )
finaloverridevirtual

Definition at line 93 of file G4AtlasDetectorConstructionTool.cxx.

93 {
94 ATH_MSG_DEBUG("Detectors " << m_detConstructionTool->m_detTool.name()
95 << " being set as World");
96 m_detConstructionTool->m_detTool->SetAsWorld();
97 m_detConstructionTool->m_detTool->Build();
98
99 ATH_MSG_DEBUG( "Setting up G4 physics regions" );
100 for (auto& it : m_detConstructionTool->m_regionCreators) {
101 it->Construct();
102 }
103
104 if (m_detConstructionTool->m_activateParallelWorlds) {
105 ATH_MSG_DEBUG( "Setting up G4 parallel worlds" );
106 for (auto& it : m_detConstructionTool->m_parallelWorlds) {
107 m_detConstructionTool->m_parallelWorldNames.push_back(it.name());
108 this->RegisterParallelWorld(it->GetParallelWorld());
109 }
110 }
111
112 ATH_MSG_DEBUG( "Running geometry post-configuration tools" );
113 for (auto it : m_detConstructionTool->m_configurationTools) {
114 StatusCode sc = it->postGeometryConfigure();
115 if (!sc.isSuccess())
116 {
117 ATH_MSG_FATAL( "Unable to run post-geometry configuration for " << it->name() );
118 }
119 }
120
121 // Build world volume and rebuild LV/PV stores if Geant4 is 11 or newer
122 // - Rebuild necessary because Athena may install LV/PV notifiers that change
123 // volume names, which invalidates store maps.
124 G4VPhysicalVolume* wv = m_detConstructionTool->m_detTool->GetWorldVolume();
125#if G4VERSION_NUMBER > 1079
126 G4LogicalVolumeStore::GetInstance()->SetMapValid(false);
127 G4LogicalVolumeStore::GetInstance()->UpdateMap();
128 G4PhysicalVolumeStore::GetInstance()->SetMapValid(false);
129 G4PhysicalVolumeStore::GetInstance()->UpdateMap();
130#endif
131
132 return wv;
133}
#define ATH_MSG_FATAL(x)
#define ATH_MSG_DEBUG(x)
static Double_t sc
::StatusCode StatusCode
StatusCode definition for legacy code.

◆ ConstructSDandField()

void G4AtlasDetectorConstructionTool::G4AtlasDetectorConstruction::ConstructSDandField ( )
finaloverridevirtual

Definition at line 135 of file G4AtlasDetectorConstructionTool.cxx.

136 {
137 ATH_MSG_DEBUG( "Setting up sensitive detectors" );
138 if (m_detConstructionTool->m_senDetTool->initializeSDs().isFailure()) {
139 ATH_MSG_FATAL("Failed to initialize SDs for worker thread");
140 }
141
142 if(!m_detConstructionTool->m_fastSimTool->initializeFastSims().isSuccess()) {
143 ATH_MSG_FATAL("Failed to initialize Fast Simulation Tool for worker thread");
144 return;
145 }
146
147 ATH_MSG_DEBUG( "Setting up field managers" );
148 for (auto& fm : m_detConstructionTool->m_fieldManagers) {
149 StatusCode sc = fm->initializeField();
150 if (!sc.isSuccess())
151 {
152 ATH_MSG_FATAL( "Unable to initialise field with " << fm->name() );
153 return;
154 }
155 }
156
157 if (m_detConstructionTool->m_G4CaloTransportTool.isEnabled()) {
158 ATH_MSG_DEBUG("Setting up G4CaloTransportTool");
159 if (m_detConstructionTool->m_G4CaloTransportTool->initializePropagator()
160 .isFailure()) {
161 ATH_MSG_FATAL("Failed to initialize G4CaloTransportTool for worker thread.");
162 return;
163 }
164 }
165
166 return;
167}

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 39 of file AthMessaging.cxx.

40{
42 // If user did not set an explicit level, set a default
43 if (m_lvl == MSG::NIL) {
44 m_lvl = m_imsg ?
45 static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
46 MSG::INFO;
47 }
48}
std::string m_nm
Message source name.
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
std::atomic< MSG::Level > m_lvl
Current logging level.
IMessageSvc * getMessageSvc(bool quiet=false)

◆ msg() [1/2]

MsgStream & AthMessaging::msg ( ) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 167 of file AthMessaging.h.

168{
169 MsgStream* ms = m_msg_tls.get();
170 if (!ms) {
171 if (!m_initialized.test_and_set()) initMessaging();
172 ms = new MsgStream(m_imsg,m_nm);
173 m_msg_tls.reset( ms );
174 }
175
176 ms->setLevel (m_lvl);
177 return *ms;
178}
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
void initMessaging() const
Initialize our message level and MessageSvc.

◆ msg() [2/2]

MsgStream & AthMessaging::msg ( const MSG::Level lvl) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 182 of file AthMessaging.h.

183{ return msg() << lvl; }
MsgStream & msg() const
The standard message stream.

◆ msgLvl()

bool AthMessaging::msgLvl ( const MSG::Level lvl) const
inlineinherited

Test the output level.

Parameters
lvlThe message level to test against
Returns
boolean Indicating if messages at given level will be printed
Return values
trueMessages at level "lvl" will be printed

Definition at line 151 of file AthMessaging.h.

152{
153 // If user did not set explicit message level we have to initialize
154 // the messaging and retrieve the default via the MessageSvc.
155 if (m_lvl==MSG::NIL && !m_initialized.test_and_set()) initMessaging();
156
157 if (m_lvl <= lvl) {
158 msg() << lvl;
159 return true;
160 } else {
161 return false;
162 }
163}

◆ setLevel()

void AthMessaging::setLevel ( MSG::Level lvl)
inherited

Change the current logging level.

Use this rather than msg().setLevel() for proper operation with MT.

Definition at line 28 of file AthMessaging.cxx.

29{
30 m_lvl = lvl;
31}

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
mutableprivateinherited

Messaging initialized (initMessaging)

Definition at line 141 of file AthMessaging.h.

◆ m_detConstructionTool

G4AtlasDetectorConstructionTool* G4AtlasDetectorConstructionTool::G4AtlasDetectorConstruction::m_detConstructionTool
private
Initial value:
{
nullptr}

Definition at line 52 of file G4AtlasDetectorConstructionTool.h.

52 {
53 nullptr}; // Pointer to the G4 Atlas detector construction tool

◆ m_imsg

std::atomic<IMessageSvc*> AthMessaging::m_imsg { nullptr }
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ m_lvl

std::atomic<MSG::Level> AthMessaging::m_lvl { MSG::NIL }
mutableprivateinherited

Current logging level.

Definition at line 138 of file AthMessaging.h.

138{ MSG::NIL };

◆ m_msg_tls

boost::thread_specific_ptr<MsgStream> AthMessaging::m_msg_tls
mutableprivateinherited

MsgStream instance (a std::cout like with print-out levels)

Definition at line 132 of file AthMessaging.h.

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.


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