61 paiCmd =
new G4UIcommand(
"/process/em/AddPAIRegion",
this);
62 paiCmd->SetGuidance(
"Activate PAI in the G4Region.");
63 paiCmd->SetGuidance(
" partName : particle name (default - all)");
64 paiCmd->SetGuidance(
" regName : G4Region name");
65 paiCmd->SetGuidance(
" paiType : PAI, PAIphoton");
67 paiCmd->SetToBeBroadcasted(
false);
70 paiCmd->SetParameter(part);
73 paiCmd->SetParameter(pregName);
76 paiCmd->SetParameter(ptype);
77 ptype->SetParameterCandidates(
"pai PAI PAIphoton");
79 mscoCmd =
new G4UIcommand(
"/process/em/AddEmRegion",
this);
80 mscoCmd->SetGuidance(
"Add optional EM configuration for a G4Region.");
81 mscoCmd->SetGuidance(
" regName : G4Region name");
82 mscoCmd->SetGuidance(
" emType : G4EmStandard, G4EmStandard_opt1, ...");
84 mscoCmd->SetToBeBroadcasted(
false);
87 mscoCmd->SetParameter(mregName);
90 mscoCmd->SetParameter(mtype);
91 mtype->SetParameterCandidates(
"G4EmStandard G4EmStandard_opt1 G4EmStandard_opt2 G4EmStandard_opt3 G4EmStandard_opt4 G4EmStandardGS G4EmStandardSS G4EmLivermore G4EmPenelope G4RadioactiveDecay");
94 SubSecCmd->SetGuidance(
"Enable subcut generation per region.");
95 SubSecCmd->SetGuidance(
" Region : region name");
97 SubSecCmd->SetToBeBroadcasted(
false);
99 StepFuncCmd =
new G4UIcommand(
"/process/eLoss/StepFunction",
this);
100 StepFuncCmd->SetGuidance(
"Set the energy loss step limitation parameters for e+-.");
101 StepFuncCmd->SetGuidance(
" dRoverR : max Range variation per step");
102 StepFuncCmd->SetGuidance(
" finalRange: range for final step");
103 StepFuncCmd->SetGuidance(
" unit : unit of finalRange");
105 StepFuncCmd->SetToBeBroadcasted(
false);
108 dRoverRPrm->SetParameterRange(
"dRoverR>0. && dRoverR<=1.");
109 StepFuncCmd->SetParameter(dRoverRPrm);
111 auto finalRangePrm =
new G4UIparameter(
"finalRange",
'd',
false);
112 finalRangePrm->SetParameterRange(
"finalRange>0.");
113 StepFuncCmd->SetParameter(finalRangePrm);
116 unitPrm->SetDefaultUnit(
"mm");
117 StepFuncCmd->SetParameter(unitPrm);
119 StepFuncCmd1 =
new G4UIcommand(
"/process/eLoss/StepFunctionMuHad",
this);
120 StepFuncCmd1->SetGuidance(
"Set the energy loss step limitation parameters for muon/hadron.");
121 StepFuncCmd1->SetGuidance(
" dRoverR : max Range variation per step");
122 StepFuncCmd1->SetGuidance(
" finalRange: range for final step");
124 StepFuncCmd1->SetToBeBroadcasted(
false);
126 auto dRoverRPrm1 =
new G4UIparameter(
"dRoverRMuHad",
'd',
false);
127 dRoverRPrm1->SetParameterRange(
"dRoverRMuHad>0. && dRoverRMuHad<=1.");
128 StepFuncCmd1->SetParameter(dRoverRPrm1);
130 auto finalRangePrm1 =
new G4UIparameter(
"finalRangeMuHad",
'd',
false);
131 finalRangePrm1->SetParameterRange(
"finalRangeMuHad>0.");
132 StepFuncCmd1->SetParameter(finalRangePrm1);
135 unitPrm1->SetDefaultValue(
"mm");
136 StepFuncCmd1->SetParameter(unitPrm1);
138 StepFuncCmd2 =
new G4UIcommand(
"/process/eLoss/StepFunctionLightIons",
this);
139 StepFuncCmd2->SetGuidance(
"Set the energy loss step limitation parameters for light ions.");
140 StepFuncCmd2->SetGuidance(
" dRoverR : max Range variation per step");
141 StepFuncCmd2->SetGuidance(
" finalRange: range for final step");
143 StepFuncCmd2->SetToBeBroadcasted(
false);
145 auto dRoverRPrm2 =
new G4UIparameter(
"dRoverRLIons",
'd',
false);
146 dRoverRPrm2->SetParameterRange(
"dRoverRLIons>0. && dRoverRLIons<=1.");
147 StepFuncCmd2->SetParameter(dRoverRPrm2);
149 auto finalRangePrm2 =
new G4UIparameter(
"finalRangeLIons",
'd',
false);
150 finalRangePrm2->SetParameterRange(
"finalRangeLIons>0.");
151 StepFuncCmd2->SetParameter(finalRangePrm2);
154 unitPrm2->SetDefaultValue(
"mm");
155 StepFuncCmd2->SetParameter(unitPrm2);
157 StepFuncCmd3 =
new G4UIcommand(
"/process/eLoss/StepFunctionIons",
this);
158 StepFuncCmd3->SetGuidance(
"Set the energy loss step limitation parameters for ions.");
159 StepFuncCmd3->SetGuidance(
" dRoverR : max Range variation per step");
160 StepFuncCmd3->SetGuidance(
" finalRange: range for final step");
162 StepFuncCmd3->SetToBeBroadcasted(
false);
164 auto dRoverRPrm3 =
new G4UIparameter(
"dRoverRIons",
'd',
false);
165 dRoverRPrm3->SetParameterRange(
"dRoverRIons>0. && dRoverRIons<=1.");
166 StepFuncCmd3->SetParameter(dRoverRPrm3);
168 auto finalRangePrm3 =
new G4UIparameter(
"finalRangeIons",
'd',
false);
169 finalRangePrm3->SetParameterRange(
"finalRangeIons>0.");
170 StepFuncCmd3->SetParameter(finalRangePrm3);
173 unitPrm3->SetDefaultValue(
"mm");
174 StepFuncCmd3->SetParameter(unitPrm3);
176 bfCmd =
new G4UIcommand(
"/process/em/setBiasingFactor",
this);
177 bfCmd->SetGuidance(
"Set factor for the process cross section.");
178 bfCmd->SetGuidance(
" procName : process name");
179 bfCmd->SetGuidance(
" procFact : factor");
180 bfCmd->SetGuidance(
" flagFact : flag to change weight");
182 bfCmd->SetToBeBroadcasted(
false);
185 bfCmd->SetParameter(procName);
188 bfCmd->SetParameter(procFact);
191 bfCmd->SetParameter(flagFact);
193 fiCmd =
new G4UIcommand(
"/process/em/setForcedInteraction",
this);
194 fiCmd->SetGuidance(
"Set factor for the process cross section.");
195 fiCmd->SetGuidance(
" procNam : process name");
196 fiCmd->SetGuidance(
" regNam : region name");
197 fiCmd->SetGuidance(
" tlength : fixed target length");
198 fiCmd->SetGuidance(
" unitT : length unit");
199 fiCmd->SetGuidance(
" tflag : flag to change weight");
201 fiCmd->SetToBeBroadcasted(
false);
204 fiCmd->SetParameter(procNam);
207 fiCmd->SetParameter(regNam);
210 tlength->SetParameterRange(
"tlength>0");
211 fiCmd->SetParameter(tlength);
214 unitT->SetDefaultUnit(
"mm");
215 fiCmd->SetParameter(unitT);
218 flagT->SetDefaultValue(
true);
219 fiCmd->SetParameter(flagT);
221 bsCmd =
new G4UIcommand(
"/process/em/setSecBiasing",
this);
222 bsCmd->SetGuidance(
"Set bremsstrahlung or delta-e- splitting/Russian roulette per region.");
223 bsCmd->SetGuidance(
" bProcNam : process name");
224 bsCmd->SetGuidance(
" bRegNam : region name");
225 bsCmd->SetGuidance(
" bFactor : number of split gamma or probability of Russian roulette");
226 bsCmd->SetGuidance(
" bEnergy : max energy of a secondary for this biasing method");
227 bsCmd->SetGuidance(
" bUnit : energy unit");
229 bsCmd->SetToBeBroadcasted(
false);
232 bsCmd->SetParameter(bProcNam);
235 bsCmd->SetParameter(bRegNam);
238 bsCmd->SetParameter(bFactor);
241 bsCmd->SetParameter(bEnergy);
244 bUnit->SetDefaultUnit(
"MeV");
245 bsCmd->SetParameter(bUnit);
247 dirSplitCmd =
new G4UIcmdWithABool(
"/process/em/setDirectionalSplitting",
this);
248 dirSplitCmd->SetGuidance(
"Enable directional brem splitting");
250 dirSplitCmd->SetToBeBroadcasted(
false);
253 qeCmd->SetGuidance(
"Enable quantum entanglement");
255 qeCmd->SetToBeBroadcasted(
false);
258 dirSplitTargetCmd->SetGuidance(
"Position of arget for directional splitting");
262 dirSplitRadiusCmd->SetGuidance(
"Radius of target for directional splitting");
264 dirSplitRadiusCmd->SetToBeBroadcasted(
false);
292 G4bool physicsModified =
false;
294 if (command == paiCmd) {
296 std::istringstream is(newValue);
297 is >> s1 >> s2 >> s3;
298 theParameters->AddPAIModel(s1, s2, s3);
299 }
else if (command == mscoCmd) {
301 std::istringstream is(newValue);
303 theParameters->AddPhysics(s1, s2);
304 }
else if (command == StepFuncCmd || command == StepFuncCmd1 || command == StepFuncCmd2 || command == StepFuncCmd3) {
307 std::istringstream is(newValue);
308 is >> v1 >> v2 >> unt;
310 if(command == StepFuncCmd) {
311 theParameters->SetStepFunction(v1,v2);
312 }
else if(command == StepFuncCmd1) {
313 theParameters->SetStepFunctionMuHad(v1,v2);
314 }
else if(command == StepFuncCmd2) {
315 theParameters->SetStepFunctionLightIons(v1,v2);
317 theParameters->SetStepFunctionIons(v1,v2);
319 physicsModified =
true;
320 }
else if (command == SubSecCmd) {
321 theParameters->SetSubCutRegion(newValue);
322 }
else if (command == bfCmd) {
325 std::istringstream is(newValue);
326 is >> s0 >> v1 >> s1;
328 if(s1 ==
"true") { yes =
true; }
329 theParameters->SetProcessBiasingFactor(s0,v1,yes);
330 physicsModified =
true;
331 }
else if (command == fiCmd) {
333 G4String s1(
""),s2(
""),s3(
""),unt(
"mm");
334 std::istringstream is(newValue);
335 is >> s1 >> s2 >> v1 >> unt >> s3;
337 if(s3 ==
"true") { yes =
true; }
339 theParameters->ActivateForcedInteraction(s1,s2,v1,yes);
340 physicsModified =
true;
341 }
else if (command == bsCmd) {
344 std::istringstream is(newValue);
345 is >> s1 >> s2 >> fb >> en >> unt;
347 theParameters->ActivateSecondaryBiasing(s1,s2,fb,en);
348 physicsModified =
true;
349 }
else if (command == qeCmd) {
350 theParameters->SetQuantumEntanglement(qeCmd->GetNewBoolValue(newValue));
351 }
else if (command == dirSplitCmd) {
352 theParameters->SetDirectionalSplitting(
353 dirSplitCmd->GetNewBoolValue(newValue));
354 physicsModified =
true;
355 }
else if (command == dirSplitTargetCmd) {
356 G4ThreeVector t = dirSplitTargetCmd->GetNew3VectorValue(newValue);
357 theParameters->SetDirectionalSplittingTarget(t);
358 physicsModified =
true;
359 }
else if (command == dirSplitRadiusCmd) {
360 G4double r = dirSplitRadiusCmd->GetNewDoubleValue(newValue);
361 theParameters->SetDirectionalSplittingRadius(r);
362 physicsModified =
true;
365 if(physicsModified) {