ATLAS Offline Software
Loading...
Searching...
No Matches
FastSimulationMasterTool.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration
3*/
4
5// Base class
7
8// For the process setup
9#include "G4ParticleTable.hh"
10#include "G4FastSimulationManagerProcess.hh"
11#include "G4ProcessManager.hh"
12
13FastSimulationMasterTool::FastSimulationMasterTool(const std::string& type, const std::string& name, const IInterface* parent)
14 : base_class(type,name,parent)
15{
16}
17
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 FastSim processes. Each process will attach
26 // itself to the relevant region at construction
27 for (auto& ifs : m_FastSimList){
28 CHECK(ifs->initializeFastSim());
29 }
30
31 return StatusCode::SUCCESS;
32}
33
35 // Method that gets called at the beginning of every *athena* event
36 for (auto& ifs : m_FastSimList){
37 CHECK(ifs->BeginOfAthenaEvent());
38 }
39 return StatusCode::SUCCESS;
40}
41
43 // Method that gets called at the end of every *athena* event
44 for (auto& ifs : m_FastSimList){
45 CHECK(ifs->EndOfAthenaEvent());
46 }
47 return StatusCode::SUCCESS;
48}
#define ATH_MSG_INFO(x)
#define ATH_MSG_VERBOSE(x)
#define CHECK(...)
Evaluate an expression and check for errors.
StatusCode initializeFastSims() override final
StatusCode EndOfAthenaEvent() override final
!< Base class method that calls BeginOfAthenaEvent for all fast simulation models.
StatusCode BeginOfAthenaEvent() override final
!< Base class method to initialize all the fast simulation models
ToolHandleArray< IFastSimulation > m_FastSimList
!< Base class method that calls EndOfAthenaEvent for all fast simulation models.
FastSimulationMasterTool(const std::string &type, const std::string &name, const IInterface *parent)