9#include "G4Threading.hh"
10#include "G4UImanager.hh"
11#include "G4UnitsTable.hh"
21 int get_nthreads(
const std::shared_ptr<GOptions>& gopts,
const std::shared_ptr<GLogger>& log) {
22 int useThreads = gopts->getScalarInt(
"nthreads");
25 int ncores = G4Threading::G4GetNumberOfCores();
30 if (useThreads == 0 || useThreads > ncores) useThreads = ncores;
32 log->info(0,
"Using ", useThreads,
" threads out of ", ncores,
" available cores.");
37 std::vector<std::string>
verbosity_commands([[maybe_unused]]
const std::shared_ptr<GOptions>& gopts,
38 [[maybe_unused]]
const std::shared_ptr<GLogger>& log) {
39 std::vector<std::string> cmds;
43 cmds.emplace_back(
"/control/verbose 0");
44 cmds.emplace_back(
"/hit/verbose 0");
46 cmds.emplace_back(
"/process/verbose 0");
47 cmds.emplace_back(
"/process/setVerbose 0 all");
48 cmds.emplace_back(
"/process/had/verbose 0");
49 cmds.emplace_back(
"/process/had/deex/verbose 0");
50 cmds.emplace_back(
"/process/had/cascade 0");
51 cmds.emplace_back(
"/process/em/verbose 0");
52 cmds.emplace_back(
"/process/eLoss/verbose 0");
54 cmds.emplace_back(
"/tracking/verbose 0");
55 cmds.emplace_back(
"/geometry/navigator/verbose 0");
57 cmds.emplace_back(
"/event/verbose 0");
58 cmds.emplace_back(
"/event/stack/verbose 0");
60 cmds.emplace_back(
"/cuts/verbose 0");
62 cmds.emplace_back(
"/run/particle/verbose 0");
63 cmds.emplace_back(
"/run/verbose 0");
65 cmds.emplace_back(
"/material/verbose 0");
67 cmds.emplace_back(
"/vis/verbose 0");
68 cmds.emplace_back(
"/particle/verbose 0");
77 [[maybe_unused]]
const std::shared_ptr<GLogger>& log) {
79 auto check_overlaps = gopts->getScalarInt(
"check_overlaps");
80 auto gui = gopts->getSwitch(
"gui");
82 std::vector<std::string> cmds;
86 if (check_overlaps == 2) {
87 log->info(0,
"Running /geometry/test/run with 50 points.");
88 cmds.emplace_back(
"/geometry/test/resolution 50");
89 cmds.emplace_back(
"/geometry/test/run");
91 else if (check_overlaps >= 100) {
92 log->info(0,
"Running /geometry/test/run with ", check_overlaps,
" points.");
93 cmds.emplace_back(
"/geometry/test/resolution " + std::to_string(check_overlaps));
94 cmds.emplace_back(
"/geometry/test/run");
100 cmds.emplace_back(
"/run/initialize");
103 if (!gui)
return cmds;
106 cmds.emplace_back(
"/vis/drawVolume");
109 cmds.emplace_back(
"/vis/viewer/set/autoRefresh false");
110 cmds.emplace_back(
"/vis/viewer/set/viewpointVector -1 0 0");
111 cmds.emplace_back(
"/vis/viewer/set/lightsVector -1 0 0");
113 cmds.emplace_back(
"/vis/scene/add/trajectories smooth");
114 cmds.emplace_back(
"/vis/modeling/trajectories/create/drawByCharge");
115 cmds.emplace_back(
"/vis/modeling/trajectories/drawByCharge-0/default/setDrawStepPts true");
116 cmds.emplace_back(
"/vis/modeling/trajectories/drawByCharge-0/default/setStepPtsSize 2");
117 cmds.emplace_back(
"/vis/scene/add/hits");
118 cmds.emplace_back(
"/vis/scene/endOfEventAction accumulate 10000");
122 cmds.push_back(
"/vis/viewer/set/background 0.05 0.05 0.26");
125 cmds.emplace_back(
"/vis/viewer/set/autoRefresh true");
126 cmds.emplace_back(
"/vis/viewer/flush");
134 const std::shared_ptr<GLogger>& log,
const std::vector<std::string>& commands) {
135 auto* g4uim = G4UImanager::GetUIpointer();
138 for (
const auto& cmd : commands) {
139 log->info(2,
"Executing UIManager command: ", cmd);
140 g4uim->ApplyCommand(cmd);
155 auto randomEngineName = gopts->getScalarString(
"randomEngine");
156 auto seed = gopts->getScalarInt(
"seed");
161 auto timed = time(NULL);
162 auto clockd = clock();
163 auto getpidi = getpid();
164 seed = (G4int)( timed - clockd - getpidi );
165 log->info(1,
"Using random seed ", seed);
167 log->info(1,
"User defined seed ", seed);
175 if (randomEngineName ==
"DRand48Engine")
176 G4Random::setTheEngine(
new CLHEP::DRand48Engine(seed));
177 else if (randomEngineName ==
"DualRand")
178 G4Random::setTheEngine(
new CLHEP::DualRand(seed));
179 else if (randomEngineName ==
"Hurd160Engine")
180 G4Random::setTheEngine(
new CLHEP::Hurd160Engine(seed));
181 else if (randomEngineName ==
"HepJamesRandom")
182 G4Random::setTheEngine(
new CLHEP::HepJamesRandom(seed));
183 else if (randomEngineName ==
"MTwistEngine")
184 G4Random::setTheEngine(
new CLHEP::MTwistEngine(seed));
185 else if (randomEngineName ==
"MixMaxRng")
186 G4Random::setTheEngine(
new CLHEP::MixMaxRng(seed));
187 else if (randomEngineName ==
"RandEngine")
188 G4Random::setTheEngine(
new CLHEP::RandEngine(seed));
189 else if (randomEngineName ==
"RanecuEngine")
190 G4Random::setTheEngine(
new CLHEP::RanecuEngine(seed));
191 else if (randomEngineName ==
"Ranlux64Engine")
192 G4Random::setTheEngine(
new CLHEP::Ranlux64Engine(seed));
193 else if (randomEngineName ==
"RanluxEngine")
194 G4Random::setTheEngine(
new CLHEP::RanluxEngine(seed));
195 else if (randomEngineName ==
"RanshiEngine")
196 G4Random::setTheEngine(
new CLHEP::RanshiEngine(seed));
197 else if (randomEngineName ==
"Hurd288Engine")
198 G4Random::setTheEngine(
new CLHEP::Hurd288Engine(seed));
199 else if (randomEngineName ==
"TripleRand")
200 G4Random::setTheEngine(
new CLHEP::TripleRand(seed));
204 log->info(0,
"Starting random engine ", randomEngineName,
" with seed ", seed);
205 G4Random::setTheSeed(seed);
Conventional constants used by GEMC utility helpers.
Utility helpers for runtime setup, command preparation, and random-engine initialization.
#define SEEDNOTSET
Sentinel value used to mark that the random seed has not been explicitly set.
#define EC__RANDOMENGINENOTFOUND
Error code used when the configured random engine name is not recognized.
void define_new_gemc_units()
void start_random_engine(const std::shared_ptr< GOptions > &gopts, const std::shared_ptr< GLogger > &log)
Select and start the random engine, then seed it.
std::vector< std::string > verbosity_commands(const std::shared_ptr< GOptions > &gopts, const std::shared_ptr< GLogger > &log)
Build a list of Geant4 UI commands that reduce verbosity across subsystems.
std::vector< std::string > initial_commands(const std::shared_ptr< GOptions > &gopts, const std::shared_ptr< GLogger > &log)
Build a list of Geant4 UI commands needed at startup.
void run_manager_commands(const std::shared_ptr< GOptions > &gopts, const std::shared_ptr< GLogger > &log, const std::vector< std::string > &commands)
Execute a sequence of Geant4 UI commands through the UI manager.
int get_nthreads(const std::shared_ptr< GOptions > &gopts, const std::shared_ptr< GLogger > &log)
Determine the number of worker threads to use for the run.
constexpr G4double milligray
constexpr G4double nanogray
constexpr G4double microgray
constexpr G4double picogray