51 : runManager(runMgr)
52{
53 runDirectory = new G4UIdirectory("/run/");
54 runDirectory->SetGuidance("Run control commands.");
55
56 initCmd = new G4UIcmdWithoutParameter("/run/initialize", this);
57 initCmd->SetGuidance("Initialize G4 kernel.");
59
60 beamOnCmd = new G4UIcommand("/run/beamOn", this);
61 beamOnCmd->SetGuidance("Start a Run.");
62 beamOnCmd->SetGuidance("If G4 kernel is not initialized, it will be initialized.");
63 beamOnCmd->SetGuidance("Default number of events to be processed is 1.");
64 beamOnCmd->SetGuidance("The second and third arguments can be used for");
65 beamOnCmd->SetGuidance("executing a macro file at the end of each event.");
66 beamOnCmd->SetGuidance("If the second argument, i.e. name of the macro");
67 beamOnCmd->SetGuidance("file, is given but the third argument is not,");
68 beamOnCmd->SetGuidance("the macro file will be executed for all of the");
69 beamOnCmd->SetGuidance("event.");
70 beamOnCmd->SetGuidance("If the third argument (nSelect) is given, the");
71 beamOnCmd->SetGuidance("macro file will be executed only for the first");
72 beamOnCmd->SetGuidance("nSelect events.");
74 beamOnCmd->SetToBeBroadcasted(false);
75 auto p1 = new G4UIparameter("numberOfEvent", 'i', true);
76 p1->SetDefaultValue(1);
77 p1->SetParameterRange("numberOfEvent >= 0");
78 beamOnCmd->SetParameter(p1);
79 auto p2 = new G4UIparameter("macroFile", 's', true);
80 p2->SetDefaultValue("***NULL***");
81 beamOnCmd->SetParameter(p2);
82 auto p3 = new G4UIparameter("nSelect", 'i', true);
83 p3->SetDefaultValue(-1);
84 p3->SetParameterRange("nSelect>=-1");
85 beamOnCmd->SetParameter(p3);
86
87
88 verboseCmd = new G4UIcmdWithAnInteger("/run/verbose", this);
89 verboseCmd->SetGuidance("Set the Verbose level of G4RunManager.");
90 verboseCmd->SetGuidance(" 0 : Silent (default)");
91 verboseCmd->SetGuidance(" 1 : Display main topics");
92 verboseCmd->SetGuidance(" 2 : Display main topics and run summary");
93 verboseCmd->SetGuidance(" 3 : Display some additional information");
94 verboseCmd->SetGuidance(" 4 : Display detailed information");
95 verboseCmd->SetGuidance(" N.B. 3 or 4 may cause significant performance degradation");
96 verboseCmd->SetParameterName("level", true);
97 verboseCmd->SetDefaultValue(0);
98 verboseCmd->SetRange("level >=0 && level <=4");
99
100 printProgCmd = new G4UIcmdWithAnInteger("/run/printProgress", this);
101 printProgCmd->SetGuidance("Display begin_of_event information at given frequency.");
102 printProgCmd->SetGuidance("If it is set to zero, only the begin_of_run is shown.");
103 printProgCmd->SetGuidance("If it is set to -1, no print-out is shown.");
104 printProgCmd->SetParameterName("mod", true);
105 printProgCmd->SetDefaultValue(-1);
106 printProgCmd->SetRange("mod>=-1");
107
108 nThreadsCmd = new G4UIcmdWithAnInteger("/run/numberOfThreads", this);
109 nThreadsCmd->SetGuidance("Set the number of threads to be used.");
110 nThreadsCmd->SetGuidance("This command works only in PreInit state.");
111 nThreadsCmd->SetGuidance("This command is valid only for multi-threaded mode.");
112 nThreadsCmd->SetGuidance("The command is ignored if it is issued in sequential mode.");
113 nThreadsCmd->SetParameterName("nThreads", true);
114 nThreadsCmd->SetDefaultValue(2);
115 nThreadsCmd->SetRange("nThreads >0");
116 nThreadsCmd->SetToBeBroadcasted(false);
118
119 maxThreadsCmd = new G4UIcmdWithoutParameter("/run/useMaximumLogicalCores", this);
120 maxThreadsCmd->SetGuidance(
121 "Set the number of threads to be the number of available logical cores.");
122 maxThreadsCmd->SetGuidance("This command works only in PreInit state.");
123 maxThreadsCmd->SetGuidance("This command is valid only for multi-threaded mode.");
124 maxThreadsCmd->SetGuidance("The command is ignored if it is issued in sequential mode.");
125 maxThreadsCmd->SetToBeBroadcasted(false);
127
128 pinAffinityCmd = new G4UIcmdWithAnInteger("/run/pinAffinity", this);
129 pinAffinityCmd->SetGuidance(
130 "Locks each thread to a specific logical core. Workers "
131 "are locked in round robin to logical cores.");
132 pinAffinityCmd->SetGuidance("This command is valid only for multi-threaded mode.");
133 pinAffinityCmd->SetGuidance("This command works only in PreInit state.");
134 pinAffinityCmd->SetGuidance("This command is ignored if it is issued in sequential mode.");
135 pinAffinityCmd->SetGuidance(
136 "If a value n>0 is provided it starts setting affinity "
137 "from the n-th CPU (note: counting from 1).");
138 pinAffinityCmd->SetGuidance(
139 "E.g. /run/pinAffinity 3 locks first thread on "
140 "third logical CPU (number 2).");
141 pinAffinityCmd->SetGuidance("If a value n<0 is provided never locks on n-th CPU.");
142 pinAffinityCmd->SetParameterName("pinAffinity", true);
143 pinAffinityCmd->SetDefaultValue(1);
144 pinAffinityCmd->SetToBeBroadcasted(false);
145 pinAffinityCmd->SetRange("pinAffinity > 0 || pinAffinity < 0");
147
148 evModCmd = new G4UIcommand("/run/eventModulo", this);
149 evModCmd->SetGuidance("Set the event modulo for dispatching events to worker threads");
150 evModCmd->SetGuidance("i.e. each worker thread is ordered to simulate N events and then");
151 evModCmd->SetGuidance("comes back to G4MTRunManager for next set.");
152 evModCmd->SetGuidance("If it is set to zero (default value), N is roughly given by this.");
153 evModCmd->SetGuidance(" N = int( sqrt( number_of_events / number_of_threads ) )");
154 evModCmd->SetGuidance("The value N may affect on the computing performance in particular");
155 evModCmd->SetGuidance("if N is too small compared to the total number of events.");
156 evModCmd->SetGuidance("The second parameter seedOnce specifies how frequently each worker");
157 evModCmd->SetGuidance("thread is seeded by the random number sequence centrally managed");
158 evModCmd->SetGuidance("by the master G4MTRunManager.");
159 evModCmd->SetGuidance(" - If seedOnce is set to 0 (default), seeds that are centrally managed");
160 evModCmd->SetGuidance(" by G4MTRunManager are set for every event of every worker thread.");
161 evModCmd->SetGuidance(" This option guarantees event reproducibility regardless of number");
162 evModCmd->SetGuidance(" of threads.");
163 evModCmd->SetGuidance(" - If seedOnce is set to 1, seeds are set only once for the first");
164 evModCmd->SetGuidance(" event of each run of each worker thread. Event reproducibility is");
165 evModCmd->SetGuidance(" guaranteed only if the same number of worker threads are used.");
166 evModCmd->SetGuidance(" On the other hand, this option offers better computing performance");
167 evModCmd->SetGuidance(" in particular for applications with relatively small primary");
168 evModCmd->SetGuidance(" particle energy and large number of events.");
169 evModCmd->SetGuidance(" - If seedOnce is set to 2, seeds are set only for the first event of");
170 evModCmd->SetGuidance(" group of N events. This option is reserved for the future use when");
171 evModCmd->SetGuidance(" Geant4 allows number of threads to be dynamically changed during an");
172 evModCmd->SetGuidance(" event loop.");
173 evModCmd->SetGuidance("This command is valid only for multi-threaded event-level parallel mode.");
174 evModCmd->SetGuidance("This command is ignored if it is issued in sequential mode or in");
175 evModCmd->SetGuidance("sub-event parallel mode.");
176 auto emp1 = new G4UIparameter("N", 'i', true);
177 emp1->SetDefaultValue(0);
178 emp1->SetParameterRange("N >= 0");
179 evModCmd->SetParameter(emp1);
180 auto emp2 = new G4UIparameter("seedOnce", 'i', true);
181 emp2->SetDefaultValue(0);
182 emp2->SetParameterRange("seedOnce >= 0 && seedOnce <=2");
183 evModCmd->SetParameter(emp2);
184 evModCmd->SetToBeBroadcasted(false);
186
187 dumpRegCmd = new G4UIcmdWithAString("/run/dumpRegion", this);
188 dumpRegCmd->SetGuidance("Dump region information.");
189 dumpRegCmd->SetGuidance("In case name of a region is not given, all regions will be displayed.");
190 dumpRegCmd->SetParameterName("regionName", true);
191 dumpRegCmd->SetDefaultValue("**ALL**");
193
194 dumpCoupleCmd = new G4UIcmdWithoutParameter("/run/dumpCouples", this);
195 dumpCoupleCmd->SetGuidance("Dump material-cuts-couple information.");
196 dumpCoupleCmd->SetGuidance("Note that material-cuts-couple information is updated");
197 dumpCoupleCmd->SetGuidance("after BeamOn has started.");
199
200 optCmd = new G4UIcmdWithABool("/run/optimizeGeometry", this);
201 optCmd->SetGuidance("Set the optimization flag for geometry.");
202 optCmd->SetGuidance("If it is set to TRUE, G4GeometryManager will optimize");
203 optCmd->SetGuidance("the geometry definitions.");
204 optCmd->SetGuidance("GEANT4 is initialized with this flag as TRUE.");
205 optCmd->SetParameterName("optimizeFlag", true);
206 optCmd->SetDefaultValue(true);
208
209 brkBoECmd = new G4UIcmdWithABool("/run/breakAtBeginOfEvent", this);
210 brkBoECmd->SetGuidance("Set a break point at the beginning of every event.");
211 brkBoECmd->SetParameterName("flag", true);
212 brkBoECmd->SetDefaultValue(true);
213
214 brkEoECmd = new G4UIcmdWithABool("/run/breakAtEndOfEvent", this);
215 brkEoECmd->SetGuidance("Set a break point at the end of every event.");
216 brkEoECmd->SetParameterName("flag", true);
217 brkEoECmd->SetDefaultValue(true);
218
219 abortCmd = new G4UIcmdWithABool("/run/abort", this);
220 abortCmd->SetGuidance("Abort current run processing.");
221 abortCmd->SetGuidance(
222 "If softAbort is false (default), currently processing event "
223 "will be immediately aborted,");
224 abortCmd->SetGuidance(
225 "while softAbort is true, abortion occurs after "
226 "processing the current event.");
228 abortCmd->SetParameterName("softAbort", true);
229 abortCmd->SetDefaultValue(false);
230
231 abortEventCmd = new G4UIcmdWithoutParameter("/run/abortCurrentEvent", this);
232 abortEventCmd->SetGuidance("Abort currently processing event.");
234
235 geomCmd = new G4UIcmdWithoutParameter("/run/geometryModified", this);
236 geomCmd->SetGuidance("Force geometry to be closed (re-voxellized) again.");
237 geomCmd->SetGuidance("This command must be applied if geometry has been modified");
238 geomCmd->SetGuidance(" after the first initialization (or BeamOn).");
240
241 geomRebCmd = new G4UIcmdWithABool("/run/reinitializeGeometry", this);
242 geomRebCmd->SetGuidance("Force geometry to be rebuilt once again.");
243 geomRebCmd->SetGuidance("This command must be applied if the user needs his/her");
244 geomRebCmd->SetGuidance(" detector construction to be reinvoked.");
245 geomRebCmd->SetGuidance("/run/geometryModified is automatically issued with this command.");
246 geomRebCmd->SetParameterName("destroyFirst", true);
247 geomRebCmd->SetDefaultValue(false);
249
250 physCmd = new G4UIcmdWithoutParameter("/run/physicsModified", this);
251 physCmd->SetGuidance("Force all physics tables recalculated again.");
252 physCmd->SetGuidance("This command must be applied");
253 physCmd->SetGuidance(" if physics process has been modified after the");
254 physCmd->SetGuidance(" first initialization (or BeamOn).");
256
257 constScoreCmd = new G4UIcmdWithoutParameter("/run/constructScoringWorlds", this);
258 constScoreCmd->SetGuidance("Construct scoring parallel world(s) if defined.");
259 constScoreCmd->SetGuidance(
260 "This command is not mandatory, but automatically "
261 "called when a run starts.");
262 constScoreCmd->SetGuidance(
263 "But the user may use this to visualize the scoring "
264 "world(s) before a run to start.");
266
267 randomDirectory = new G4UIdirectory("/random/");
268 randomDirectory->SetGuidance("Random number status control commands.");
269
270 seedCmd = new G4UIcmdWithAString("/random/setSeeds", this);
271 seedCmd->SetGuidance("Initialize the random number generator with integer seed stream.");
272 seedCmd->SetGuidance("Number of integers should be more than 1.");
273 seedCmd->SetGuidance(
274 "Actual number of integers to be used depends on the individual "
275 "random number engine.");
276#ifdef G4MULTITHREADED
277 seedCmd->SetGuidance("This command sets the seeds for the master thread.");
278#endif
279 seedCmd->SetParameterName("IntArray", false);
281 seedCmd->SetToBeBroadcasted(false);
282
283 randDirCmd = new G4UIcmdWithAString("/random/setDirectoryName", this);
284 randDirCmd->SetGuidance("Define the directory name of the rndm status files.");
285 randDirCmd->SetGuidance("Directory will be created if it does not exist.");
286 randDirCmd->SetParameterName("fileName", true);
287 randDirCmd->SetDefaultValue("./");
289
290 savingFlagCmd = new G4UIcmdWithABool("/random/setSavingFlag", this);
291 savingFlagCmd->SetGuidance("The randomNumberStatus will be saved at :");
292 savingFlagCmd->SetGuidance(
293 "beginning of run (currentRun.rndm) and "
294 "beginning of event (currentEvent.rndm) ");
295 savingFlagCmd->SetParameterName("flag", true);
296 savingFlagCmd->SetDefaultValue(true);
297
298 saveThisRunCmd = new G4UIcmdWithoutParameter("/random/saveThisRun", this);
299 saveThisRunCmd->SetGuidance("copy currentRun.rndm to runXXX.rndm");
301
302 saveThisEventCmd = new G4UIcmdWithoutParameter("/random/saveThisEvent", this);
303 saveThisEventCmd->SetGuidance("copy currentEvent.rndm to runXXXevtYYY.rndm");
305
306 restoreRandCmd = new G4UIcmdWithAString("/random/resetEngineFrom", this);
307 restoreRandCmd->SetGuidance("Reset the status of the rndm engine from a file.");
308 restoreRandCmd->SetGuidance("See CLHEP manual for detail.");
309 restoreRandCmd->SetGuidance("The engine status must be stored beforehand.");
310 restoreRandCmd->SetGuidance(
311 "Directory of the status file should be set by"
312 " /random/setDirectoryName.");
313 restoreRandCmd->SetParameterName("fileName", true);
314 restoreRandCmd->SetDefaultValue("currentRun.rndm");
316 restoreRandCmd->SetToBeBroadcasted(false);
317
318 restoreRandCmdMT = new G4UIcmdWithABool("/random/resetEngineFromEachEvent", this);
319 restoreRandCmdMT->SetGuidance("Reset the status of the rndm engine from a file at each event.");
320 restoreRandCmdMT->SetGuidance("Note that the file must follow the following naming convention:");
321 restoreRandCmdMT->SetGuidance(
322 "run{#1}evt{#2}.rndm ; where #1 is the run "
323 "number and #2 is the event number.");
324 restoreRandCmdMT->SetGuidance(
325 "For example to re-seed the first event of the first "
326 "run the file should be called run0evt0.rndm.");
327 restoreRandCmdMT->SetGuidance(
328 "If for a specific run/event the file is not found, "
329 "the standard re-seeding strategy is used.");
330 restoreRandCmdMT->SetGuidance(
331 "This command has meaning only in MT mode for "
332 "strong reproducibility studies.");
333 restoreRandCmdMT->SetGuidance(
334 "Directory of the status file should be set by"
335 " /random/setDirectoryName.");
336 restoreRandCmdMT->SetDefaultValue(false);
338
339 saveEachEventCmd = new G4UIcmdWithABool("/random/saveEachEventFlag", this);
340 saveEachEventCmd->SetGuidance("Save random number status at beginning of each event.");
341 saveEachEventCmd->SetGuidance("File name contains run and event numbers: runXXXevtYYY.rndm");
342 saveEachEventCmd->SetParameterName("flag", true);
343 saveEachEventCmd->SetDefaultValue(true);
344
345 randEvtCmd = new G4UIcmdWithAnInteger("/run/storeRndmStatToEvent", this);
346 randEvtCmd->SetGuidance("Flag to store rndm status to G4Event object.");
347 randEvtCmd->SetGuidance(" flag = 0 : not store (default)");
348 randEvtCmd->SetGuidance(" flag = 1 : status before primary particle generation is stored");
349 randEvtCmd->SetGuidance(
350 " flag = 2 : status before event processing (after primary "
351 "particle generation) is stored");
352 randEvtCmd->SetGuidance(" flag = 3 : both are stored");
353 randEvtCmd->SetGuidance(
354 "Note: Some performance overhead may be seen by storing rndm "
355 "status, in particular");
356 randEvtCmd->SetGuidance(
357 "for the case of simplest geometry and small number of tracks per event.");
358 randEvtCmd->SetParameterName("flag", true);
359 randEvtCmd->SetDefaultValue(0);
360 randEvtCmd->SetRange("flag>=0 && flag<=3");
362
363 procUICmds = new G4UIcmdWithoutParameter("/run/workersProcessCmds", this);
364 procUICmds->SetToBeBroadcasted(false);
365 procUICmds->SetGuidance("Force workers to process current stack of UI commands.");
366 procUICmds->SetGuidance("This commands is meaningful only in MT mode.");
368
369 trajMergeCmd = new G4UIcmdWithABool("/run/trajectoriesToBeMerged",this);
370 trajMergeCmd->SetGuidance("Merge trajectories created in sub-event parallel mode.");
371 trajMergeCmd->SetGuidance("In sub-event parallel mode, trajectories created in worker ");
372 trajMergeCmd->SetGuidance("threads are not merged to the event in the master thread by default ");
373 trajMergeCmd->SetGuidance("due to the performance overhead caused by copying them.");
374 trajMergeCmd->SetGuidance("This command enables the merging.");
375 trajMergeCmd->SetGuidance("/tracking/storeTrajectory command must be set to create trajectories.");
376 trajMergeCmd->SetGuidance("This command is valid only for sub-event parallel mode.");
378 trajMergeCmd->SetParameterName("flag", true);
379 trajMergeCmd->SetDefaultValue(true);
380 trajMergeCmd->SetToBeBroadcasted(false);
381}