56 : params(opticalParameters)
59 G4bool toBeBroadcasted =
false;
60 fDir =
new G4UIdirectory(
"/process/optical/", toBeBroadcasted);
62 "Commands related to the optical physics simulation engine.");
65 new G4UIdirectory(
"/process/optical/cerenkov/", toBeBroadcasted);
66 fCerenkovDir->SetGuidance(
"Cerenkov process commands");
68 new G4UIdirectory(
"/process/optical/scintillation/", toBeBroadcasted);
69 fScintDir->SetGuidance(
"Scintillation process commands");
70 fWlsDir =
new G4UIdirectory(
"/process/optical/wls/", toBeBroadcasted);
71 fWlsDir->SetGuidance(
"Wave length shifting process commands");
72 fWls2Dir =
new G4UIdirectory(
"/process/optical/wls2/", toBeBroadcasted);
73 fWls2Dir->SetGuidance(
"Second Wave length shifting process commands");
75 new G4UIdirectory(
"/process/optical/boundary/", toBeBroadcasted);
76 fBoundaryDir->SetGuidance(
"Boundary scattering commands");
77 fMieDir =
new G4UIdirectory(
"/process/optical/mie/", toBeBroadcasted);
78 fMieDir->SetGuidance(
"Mie scattering process commands");
79 fAbsDir =
new G4UIdirectory(
"/process/optical/absorption/", toBeBroadcasted);
80 fAbsDir->SetGuidance(
"absorption process commands");
81 fRaylDir =
new G4UIdirectory(
"/process/optical/rayleigh/", toBeBroadcasted);
82 fRaylDir->SetGuidance(
"Rayleigh scattering commands");
86 new G4UIcommand(
"/process/optical/processActivation",
this);
87 fActivateProcessCmd->SetGuidance(
88 "Activate/deactivate the specified optical process");
96 par->SetParameterCandidates(candidates);
97 par->SetGuidance(
"the process name");
98 fActivateProcessCmd->SetParameter(par);
100 par->SetDefaultValue(
true);
101 par->SetGuidance(
"activation flag");
102 fActivateProcessCmd->SetParameter(par);
106 fVerboseCmd->SetGuidance(
"Set default verbose level for optical processes");
107 fVerboseCmd->SetParameterName(
"ver",
true);
108 fVerboseCmd->SetDefaultValue(1);
109 fVerboseCmd->SetRange(
"ver>=0");
112 fDumpCmd =
new G4UIcommand(
"/process/optical/printParameters",
this);
113 fDumpCmd->SetGuidance(
"Print all optical parameters.");
116 fCerenkovMaxPhotonsCmd =
118 fCerenkovMaxPhotonsCmd->SetGuidance(
"Set maximum number of photons per step");
119 fCerenkovMaxPhotonsCmd->SetParameterName(
"CerenkovMaxPhotons",
false);
120 fCerenkovMaxPhotonsCmd->SetRange(
"CerenkovMaxPhotons>=0");
123 fCerenkovMaxBetaChangeCmd =
125 fCerenkovMaxBetaChangeCmd->SetGuidance(
126 "Set maximum change of beta of parent particle per step (in percent)");
127 fCerenkovMaxBetaChangeCmd->SetParameterName(
"CerenkovMaxBetaChange",
false);
128 fCerenkovMaxBetaChangeCmd->SetRange(
"CerenkovMaxBetaChange>=0");
131 fCerenkovStackPhotonsCmd =
133 fCerenkovStackPhotonsCmd->SetGuidance(
134 "Set whether or not to stack secondary Cerenkov photons");
138 "/process/optical/cerenkov/setTrackSecondariesFirst",
this);
139 fCerenkovTrackSecondariesFirstCmd->SetGuidance(
140 "Whether to track secondary Cerenkov photons before the primary.");
144 fCerenkovVerboseLevelCmd =
146 fCerenkovVerboseLevelCmd->SetGuidance(
"Verbose level for Cerenkov process.");
147 fCerenkovVerboseLevelCmd->SetParameterName(
"verbose",
true);
148 fCerenkovVerboseLevelCmd->SetRange(
"verbose >= 0 && verbose <= 2");
149 fCerenkovVerboseLevelCmd->SetDefaultValue(2);
154 "/process/optical/scintillation/setByParticleType",
this);
155 fScintByParticleTypeCmd->SetGuidance(
156 "Activate/Inactivate scintillation process by particle type");
157 fScintByParticleTypeCmd->SetParameterName(
158 "ScintillationByParticleTypeActivation",
false);
163 fScintTrackInfoCmd->SetGuidance(
164 "Activate/Inactivate scintillation TrackInformation");
165 fScintTrackInfoCmd->SetParameterName(
"ScintillationTrackInfo",
false);
169 "/process/optical/scintillation/setFiniteRiseTime",
this);
170 fScintFiniteRiseTimeCmd->SetGuidance(
171 "Set option of a finite rise-time for G4Scintillation");
172 fScintFiniteRiseTimeCmd->SetGuidance(
173 "If set, the G4Scintillation process expects the user to have set the");
174 fScintFiniteRiseTimeCmd->SetGuidance(
175 "constant material property SCINTILLATIONRISETIME{1,2,3}");
176 fScintFiniteRiseTimeCmd->SetParameterName(
"FiniteRiseTime",
false);
180 "/process/optical/scintillation/setStackPhotons",
this);
181 fScintStackPhotonsCmd->SetGuidance(
182 "Set whether or not to stack secondary Scintillation photons");
183 fScintStackPhotonsCmd->SetParameterName(
"ScintillationStackPhotons",
true);
184 fScintStackPhotonsCmd->SetDefaultValue(
true);
188 "/process/optical/scintillation/setTrackSecondariesFirst",
this);
189 fScintTrackSecondariesFirstCmd->SetGuidance(
190 "Whether to track scintillation secondaries before primary.");
194 fScintVerboseLevelCmd =
196 fScintVerboseLevelCmd->SetGuidance(
197 "Verbose level for scintillation process.");
198 fScintVerboseLevelCmd->SetParameterName(
"verbose",
true);
199 fScintVerboseLevelCmd->SetRange(
"verbose >= 0 && verbose <= 2");
205 fWLSTimeProfileCmd->SetGuidance(
206 "Set the WLS time profile (delta or exponential)");
207 fWLSTimeProfileCmd->SetParameterName(
"WLSTimeProfile",
false);
208 fWLSTimeProfileCmd->SetCandidates(
"delta exponential");
211 fWLSVerboseLevelCmd =
213 fWLSVerboseLevelCmd->SetGuidance(
"Verbose level for WLS process.");
214 fWLSVerboseLevelCmd->SetParameterName(
"verbose",
true);
215 fWLSVerboseLevelCmd->SetRange(
"verbose >= 0 && verbose <= 2");
216 fWLSVerboseLevelCmd->SetDefaultValue(1);
220 fWLS2TimeProfileCmd =
222 fWLS2TimeProfileCmd->SetGuidance(
223 "Set the WLS2 time profile (delta or exponential)");
224 fWLS2TimeProfileCmd->SetParameterName(
"WLS2TimeProfile",
false);
225 fWLS2TimeProfileCmd->SetCandidates(
"delta exponential");
228 fWLS2VerboseLevelCmd =
230 fWLS2VerboseLevelCmd->SetGuidance(
"Verbose level for WLS2 process.");
231 fWLS2VerboseLevelCmd->SetParameterName(
"verbose",
true);
232 fWLS2VerboseLevelCmd->SetRange(
"verbose >= 0 && verbose <= 2");
233 fWLS2VerboseLevelCmd->SetDefaultValue(1);
237 fBoundaryInvokeSDCmd =
239 fBoundaryInvokeSDCmd->SetGuidance(
240 "Set option for calling InvokeSD in G4OpBoundaryProcess");
241 fBoundaryInvokeSDCmd->SetParameterName(
"InvokeSD",
false);
244 fBoundaryVerboseLevelCmd =
246 fBoundaryVerboseLevelCmd->SetGuidance(
"Verbose level for boundary process.");
247 fBoundaryVerboseLevelCmd->SetParameterName(
"verbose",
true);
248 fBoundaryVerboseLevelCmd->SetRange(
"verbose >= 0 && verbose <= 2");
249 fBoundaryVerboseLevelCmd->SetDefaultValue(1);
253 fAbsorptionVerboseLevelCmd =
255 fAbsorptionVerboseLevelCmd->SetGuidance(
256 "Verbose level for absorption process.");
257 fAbsorptionVerboseLevelCmd->SetParameterName(
"verbose",
true);
258 fAbsorptionVerboseLevelCmd->SetRange(
"verbose >= 0 && verbose <= 2");
259 fAbsorptionVerboseLevelCmd->SetDefaultValue(1);
263 fRayleighVerboseLevelCmd =
265 fRayleighVerboseLevelCmd->SetGuidance(
"Verbose level for Rayleigh process.");
266 fRayleighVerboseLevelCmd->SetParameterName(
"verbose",
true);
267 fRayleighVerboseLevelCmd->SetRange(
"verbose >= 0 && verbose <= 2");
268 fRayleighVerboseLevelCmd->SetDefaultValue(1);
272 fMieVerboseLevelCmd =
274 fMieVerboseLevelCmd->SetGuidance(
"Verbose level for Mie process.");
275 fMieVerboseLevelCmd->SetParameterName(
"verbose",
true);
276 fMieVerboseLevelCmd->SetRange(
"verbose >= 0 && verbose <= 2");
277 fMieVerboseLevelCmd->SetDefaultValue(1);
320 G4bool physicsModified =
true;
323 if(command == fActivateProcessCmd)
325 std::istringstream is(newValue.data());
330 params->SetProcessActivation(pn, value);
332 else if(command == fVerboseCmd)
334 params->SetVerboseLevel(fVerboseCmd->GetNewIntValue(newValue));
336 else if(command == fDumpCmd)
340 else if(command == fCerenkovMaxPhotonsCmd)
342 params->SetCerenkovMaxPhotonsPerStep(
343 fCerenkovMaxPhotonsCmd->GetNewIntValue(newValue));
344 G4cout <<
"Cerenkov max photons: " << params->GetCerenkovMaxPhotonsPerStep()
347 else if(command == fCerenkovMaxBetaChangeCmd)
349 params->SetCerenkovMaxBetaChange(
350 fCerenkovMaxBetaChangeCmd->GetNewDoubleValue(newValue));
352 else if(command == fCerenkovStackPhotonsCmd)
354 params->SetCerenkovStackPhotons(
355 fCerenkovStackPhotonsCmd->GetNewBoolValue(newValue));
357 else if(command == fCerenkovTrackSecondariesFirstCmd)
359 params->SetCerenkovTrackSecondariesFirst(
360 fCerenkovTrackSecondariesFirstCmd->GetNewBoolValue(newValue));
362 else if(command == fCerenkovVerboseLevelCmd)
364 params->SetCerenkovVerboseLevel(
365 fCerenkovVerboseLevelCmd->GetNewIntValue(newValue));
367 else if(command == fScintByParticleTypeCmd)
369 params->SetScintByParticleType(
370 fScintByParticleTypeCmd->GetNewBoolValue(newValue));
372 else if(command == fScintTrackInfoCmd)
374 params->SetScintTrackInfo(fScintTrackInfoCmd->GetNewBoolValue(newValue));
376 else if(command == fScintFiniteRiseTimeCmd)
378 params->SetScintFiniteRiseTime(
379 fScintFiniteRiseTimeCmd->GetNewBoolValue(newValue));
381 else if(command == fScintStackPhotonsCmd)
383 params->SetScintStackPhotons(
384 fScintStackPhotonsCmd->GetNewBoolValue(newValue));
386 else if(command == fScintTrackSecondariesFirstCmd)
388 params->SetScintTrackSecondariesFirst(
389 fScintTrackSecondariesFirstCmd->GetNewBoolValue(newValue));
391 else if(command == fScintVerboseLevelCmd)
393 params->SetScintVerboseLevel(
394 fScintVerboseLevelCmd->GetNewIntValue(newValue));
396 else if(command == fWLSTimeProfileCmd)
398 params->SetWLSTimeProfile(newValue);
400 else if(command == fWLSVerboseLevelCmd)
402 params->SetWLSVerboseLevel(fWLSVerboseLevelCmd->GetNewIntValue(newValue));
404 else if(command == fWLS2TimeProfileCmd)
406 params->SetWLS2TimeProfile(newValue);
408 else if(command == fWLS2VerboseLevelCmd)
410 params->SetWLS2VerboseLevel(fWLS2VerboseLevelCmd->GetNewIntValue(newValue));
412 else if(command == fAbsorptionVerboseLevelCmd)
414 params->SetAbsorptionVerboseLevel(
415 fAbsorptionVerboseLevelCmd->GetNewIntValue(newValue));
417 else if(command == fRayleighVerboseLevelCmd)
419 params->SetRayleighVerboseLevel(
420 fRayleighVerboseLevelCmd->GetNewIntValue(newValue));
422 else if(command == fMieVerboseLevelCmd)
424 params->SetMieVerboseLevel(fMieVerboseLevelCmd->GetNewIntValue(newValue));
426 else if(command == fBoundaryVerboseLevelCmd)
428 params->SetBoundaryVerboseLevel(
429 fBoundaryVerboseLevelCmd->GetNewIntValue(newValue));
431 else if(command == fBoundaryInvokeSDCmd)
433 params->SetBoundaryInvokeSD(
434 fBoundaryInvokeSDCmd->GetNewBoolValue(newValue));