12#include "G4DarkBreM/G4DarkBremsstrahlung.h"
14#include "SimCore/BiasOperators/XsecBiasingOperator.h"
15#include "SimCore/DetectorConstruction.h"
18#include "SimCore/G4User/RunAction.h"
19#include "SimCore/G4User/StackingAction.h"
20#include "SimCore/G4User/SteppingAction.h"
23#include "SimCore/ParallelWorld.h"
29#include "FTFP_BERT.hh"
30#include "G4GDMLParser.hh"
31#include "G4GenericBiasingPhysics.hh"
32#include "G4ParallelWorldPhysics.hh"
33#include "G4ProcessTable.hh"
34#include "G4VModularPhysicsList.hh"
43 auto root_primary_gen_use_seed{
44 parameters.
get<
bool>(
"root_primary_gen_use_seed")};
52 p_list->SetVerboseLevel(0);
57 ldmx_log(debug) <<
"Parallel worlds physics list has been registered";
58 p_list->RegisterPhysics(
new G4ParallelWorldPhysics(
"ldmxParallelWorld"));
71 auto biasing_operators{
73 "biasing_operators", {})};
74 if (!biasing_operators.empty()) {
75 ldmx_log(info) <<
" Biasing enabled with " << biasing_operators.size()
80 if (not simcore::XsecBiasingOperator::Factory::get().make(
81 bop.get<std::string>(
"class_name"),
82 bop.get<std::string>(
"instance_name"), bop)) {
83 EXCEPTION_RAISE(
"UnableToCreate",
84 "Unable to create a XsecBiasingOperator of type " +
85 bop.get<std::string>(
"class_name"));
90 G4GenericBiasingPhysics* biasing_physics =
new G4GenericBiasingPhysics();
95 simcore::XsecBiasingOperator::Factory::get().apply(
96 [
this, biasing_physics](
auto bop) {
97 ldmx_log(info) <<
"Biasing operator '" << bop->GetName()
98 <<
"' set to bias " << bop->getParticleToBias();
99 biasing_physics->Bias(bop->getParticleToBias());
103 p_list->RegisterPhysics(biasing_physics);
106 this->SetUserInitialization(p_list);
115 ldmx_log(debug) <<
"Parallel worlds have been enabled";
117 auto validate_geometry{
parameters_.
get<
bool>(
"validate_detector")};
118 G4GDMLParser* pw_parser =
new G4GDMLParser();
128 G4RunManager::Initialize();
138 SetUserAction(primary_action);
139 SetUserAction(run_action);
140 SetUserAction(event_action);
141 SetUserAction(tracking_action);
142 SetUserAction(stepping_action);
143 SetUserAction(stacking_action);
146 auto user_actions{
parameters_.
get<std::vector<framework::config::Parameters>>(
148 for (
auto& user_action : user_actions) {
149 auto ua = UserAction::Factory::get().make(
150 user_action.get<std::string>(
"class_name"),
151 user_action.get<std::string>(
"instance_name"), user_action);
155 "Unable to create a UserAction of type " +
156 user_action.get<std::string>(
"class_name") +
157 ". Did you inherit from simcore::UserAction? "
158 "Do you have DECLARE_ACTION in your implementation (.cxx) file? "
159 "Did you include the fully-specified class name in your python "
160 "configuration class? "
161 "Did you specify the correct library in the python configuration "
164 for (
auto& type : ua.value()->getTypes()) {
165 if (type == simcore::TYPE::RUN) {
166 run_action->registerAction(ua.value());
167 }
else if (type == simcore::TYPE::EVENT) {
168 event_action->registerAction(ua.value());
169 }
else if (type == simcore::TYPE::TRACKING) {
170 tracking_action->registerAction(ua.value());
171 }
else if (type == simcore::TYPE::STEPPING) {
172 stepping_action->registerAction(ua.value());
173 }
else if (type == simcore::TYPE::STACKING) {
174 stacking_action->registerAction(ua.value());
176 EXCEPTION_RAISE(
"ActionType",
"Action type does not exist.");
184 G4RunManager::TerminateOneEvent();
189 static auto reactivate_dark_brem = [](G4ProcessManager* pman) {
190 for (
int i_proc{0}; i_proc < pman->GetProcessList()->size(); i_proc++) {
191 G4VProcess* p{(*(pman->GetProcessList()))[i_proc]};
192 if (p->GetProcessName().contains(G4DarkBremsstrahlung::PROCESS_NAME)) {
193 pman->SetProcessActivation(p,
true);
199 reactivate_dark_brem(G4Electron::Definition()->GetProcessManager());
Class which defines basic APrime physics.
Class which implements the Geant4 user event action.
Physics constructor for fractionally charged particle (FCP) processes.
Class used to enhanced the gamma physics list.
Class implementing the Geant4 primary generator action.
Class providing a Geant4 run manager implementation.
Class which implements the user tracking action.
Class encapsulating parameters for configuring a processor.
const T & get(const std::string &name) const
Retrieve the parameter of the given name.
Defines basic APrime physics.
Handle to the conditions system, provided at construction to classes which require it.
Implements the Geant4 detector construction.
Physics constructor for fractionally charged particles.
extra gamma particle physics for simulation and sets up the photonuclear model to use from the config...
Allows the configuration of properties of kaons produced in the simulation, in particular setting the...
Implementation of Geant4 primary generator action.
std::string parallel_world_path_
Path to GDML description of parallel world.
framework::config::Parameters parameters_
The set of parameters used to configure the RunManager.
void TerminateOneEvent()
Called at the end of each event.
void setupPhysics()
Initialize physics.
void setUseRootSeed(bool useIt=true)
Tell RunManager to use the seed from the root file.
bool is_pw_enabled_
Flag indicating whether a parallel world should be registered.
void Initialize()
Perform application initialization.
DetectorConstruction * getDetectorConstruction()
Get the user detector construction cast to a specific type.
G4PhysListFactory physics_list_factory_
Factory class for instantiating the physics list.
RunManager(framework::config::Parameters ¶meters, ConditionsInterface &)
Class constructor.
Implementation of user event action hook.
Implementation of user run action hook.
Class implementing a user stacking action.
Implements the Geant4 user stepping action.
Implementation of user tracking action.
Dynamically loadable photonuclear models either from SimCore or external libraries implementing this ...