ATLAS Offline Software
Public Member Functions | Private Attributes | List of all members
FastSimulationMasterTool Class Reference

#include <FastSimulationMasterTool.h>

Inheritance diagram for FastSimulationMasterTool:
Collaboration diagram for FastSimulationMasterTool:

Public Member Functions

 FastSimulationMasterTool (const std::string &type, const std::string &name, const IInterface *parent)
 
virtual ~FastSimulationMasterTool ()
 
StatusCode initializeFastSims () override final
 
StatusCode BeginOfAthenaEvent () override final
 !< Base class method to initialize all the fast simulation models More...
 
StatusCode EndOfAthenaEvent () override final
 !< Base class method that calls BeginOfAthenaEvent for all fast simulation models. More...
 

Private Attributes

ToolHandleArray< IFastSimulationm_FastSimList {this, "FastSimulations", {}, "Tool handle array of fast simulation tools"}
 !< Base class method that calls EndOfAthenaEvent for all fast simulation models. More...
 

Detailed Description

Definition at line 16 of file FastSimulationMasterTool.h.

Constructor & Destructor Documentation

◆ FastSimulationMasterTool()

FastSimulationMasterTool::FastSimulationMasterTool ( const std::string &  type,
const std::string &  name,
const IInterface *  parent 
)

Definition at line 13 of file FastSimulationMasterTool.cxx.

14  : base_class(type,name,parent)
15 {
16 }

◆ ~FastSimulationMasterTool()

virtual FastSimulationMasterTool::~FastSimulationMasterTool ( )
inlinevirtual

Definition at line 20 of file FastSimulationMasterTool.h.

20 {}

Member Function Documentation

◆ BeginOfAthenaEvent()

StatusCode FastSimulationMasterTool::BeginOfAthenaEvent ( )
finaloverride

!< Base class method to initialize all the fast simulation models

Definition at line 47 of file FastSimulationMasterTool.cxx.

47  {
48  // Method that gets called at the beginning of every *athena* event
49  for (auto& ifs : m_FastSimList){
50  CHECK(ifs->BeginOfAthenaEvent());
51  }
52  return StatusCode::SUCCESS;
53 }

◆ EndOfAthenaEvent()

StatusCode FastSimulationMasterTool::EndOfAthenaEvent ( )
finaloverride

!< Base class method that calls BeginOfAthenaEvent for all fast simulation models.

Definition at line 55 of file FastSimulationMasterTool.cxx.

55  {
56  // Method that gets called at the end of every *athena* event
57  for (auto& ifs : m_FastSimList){
58  CHECK(ifs->EndOfAthenaEvent());
59  }
60  return StatusCode::SUCCESS;
61 }

◆ initializeFastSims()

StatusCode FastSimulationMasterTool::initializeFastSims ( )
finaloverride

Definition at line 18 of file FastSimulationMasterTool.cxx.

18  {
19  ATH_MSG_VERBOSE( name() << "::initializeFastSims()" );
20  // Loop through list of fast simulations and retrieve them
21  // This forces a call to initialize() for each of them
22  ATH_MSG_INFO( "Initializing list of " << m_FastSimList.size() << " fast simulation tools in " << name() );
23  CHECK( m_FastSimList.retrieve() );
24 
25  // Initialize the SDs
26  for (auto& ifs : m_FastSimList){
27  CHECK(ifs->initializeFastSim());
28  }
29 
30  // If we added a fast simulation, then we will need to add the process to the particles
31  if ( m_FastSimList.size() > 0 ){
32  G4FastSimulationManagerProcess* fastSimManagerProcess = new G4FastSimulationManagerProcess();
33  G4ParticleTable* theParticleTable = G4ParticleTable::GetParticleTable();
34  G4ParticleTable::G4PTblDicIterator* theParticleIterator = theParticleTable->GetIterator();
35 
36  theParticleIterator->reset();
37  while( (*theParticleIterator)() ){
38  G4ProcessManager* pmanager = theParticleIterator->value()->GetProcessManager();
39  pmanager->AddProcess(fastSimManagerProcess, -1, 1, 1);
40  } // Done with loop over particles
41  } // Done with process assignment
42 
43  return StatusCode::SUCCESS;
44 }

Member Data Documentation

◆ m_FastSimList

ToolHandleArray<IFastSimulation> FastSimulationMasterTool::m_FastSimList {this, "FastSimulations", {}, "Tool handle array of fast simulation tools"}
private

!< Base class method that calls EndOfAthenaEvent for all fast simulation models.

Definition at line 28 of file FastSimulationMasterTool.h.


The documentation for this class was generated from the following files:
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
FastSimulationMasterTool::m_FastSimList
ToolHandleArray< IFastSimulation > m_FastSimList
!< Base class method that calls EndOfAthenaEvent for all fast simulation models.
Definition: FastSimulationMasterTool.h:28
test_pyathena.parent
parent
Definition: test_pyathena.py:15
CHECK
#define CHECK(...)
Evaluate an expression and check for errors.
Definition: Control/AthenaKernel/AthenaKernel/errorcheck.h:422
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:195
python.CaloScaleNoiseConfig.type
type
Definition: CaloScaleNoiseConfig.py:78