62 deCmd->SetGuidance(
"Enable/disable atomic deexcitation");
63 deCmd->SetParameterName(
"fluoFlag",
true);
64 deCmd->SetDefaultValue(
false);
66 deCmd->SetToBeBroadcasted(
false);
69 dirFluoCmd->SetGuidance(
"Enable/disable usage of Bearden fluorescence files");
70 dirFluoCmd->SetParameterName(
"fluoBeardenFlag",
true);
71 dirFluoCmd->SetDefaultValue(
false);
73 dirFluoCmd->SetToBeBroadcasted(
false);
76 dirFluoCmd1->SetGuidance(
"Enable/disable usage of ANSTO fluorescence files");
77 dirFluoCmd1->SetParameterName(
"fluoANSTOFlag",
true);
78 dirFluoCmd1->SetDefaultValue(
false);
80 dirFluoCmd1->SetToBeBroadcasted(
false);
83 auCmd->SetGuidance(
"Enable/disable Auger electrons production");
84 auCmd->SetParameterName(
"augerFlag",
true);
85 auCmd->SetDefaultValue(
false);
87 auCmd->SetToBeBroadcasted(
false);
90 auCascadeCmd->SetGuidance(
"Enable/disable simulation of cascade of Auger electrons");
91 auCascadeCmd->SetParameterName(
"augerCascadeFlag",
true);
92 auCascadeCmd->SetDefaultValue(
false);
94 auCascadeCmd->SetToBeBroadcasted(
false);
97 pixeCmd->SetGuidance(
"Enable/disable PIXE simulation");
98 pixeCmd->SetParameterName(
"pixeFlag",
true);
99 pixeCmd->SetDefaultValue(
false);
101 pixeCmd->SetToBeBroadcasted(
false);
104 dcutCmd->SetGuidance(
"Enable/Disable usage of cuts in de-excitation module");
105 dcutCmd->SetParameterName(
"deexcut",
true);
106 dcutCmd->SetDefaultValue(
false);
108 dcutCmd->SetToBeBroadcasted(
false);
111 dnafCmd->SetGuidance(
"Enable usage of fast sampling for DNA models");
112 dnafCmd->SetParameterName(
"dnaf",
true);
113 dnafCmd->SetDefaultValue(
false);
115 dnafCmd->SetToBeBroadcasted(
false);
118 dnasCmd->SetGuidance(
"Enable usage of Stationary option for DNA models");
119 dnasCmd->SetParameterName(
"dnas",
true);
120 dnasCmd->SetDefaultValue(
false);
122 dnasCmd->SetToBeBroadcasted(
false);
125 dnamscCmd->SetGuidance(
"Enable usage of e- msc for DNA");
126 dnamscCmd->SetParameterName(
"dnamsc",
true);
127 dnamscCmd->SetDefaultValue(
false);
129 dnamscCmd->SetToBeBroadcasted(
false);
132 direFluoCmd->SetGuidance(
"The name of PIXE cross section");
133 direFluoCmd->SetParameterName(
"fluoDirectory",
true);
134 direFluoCmd->SetCandidates(
"Default Bearden ANSTO XDB_EADL");
136 direFluoCmd->SetToBeBroadcasted(
false);
139 pixeXsCmd->SetGuidance(
"The name of PIXE cross section");
140 pixeXsCmd->SetParameterName(
"pixeXS",
true);
141 pixeXsCmd->SetCandidates(
"ECPSSR_Analytical Empirical ECPSSR_FormFactor ECPSSR_ANSTO");
143 pixeXsCmd->SetToBeBroadcasted(
false);
146 pixeeXsCmd->SetGuidance(
"The name of PIXE cross section for electron");
147 pixeeXsCmd->SetParameterName(
"pixeEXS",
true);
148 pixeeXsCmd->SetCandidates(
"ECPSSR_Analytical Empirical Livermore Penelope");
150 pixeeXsCmd->SetToBeBroadcasted(
false);
153 livCmd->SetGuidance(
"The name of Livermore data directory");
154 livCmd->SetParameterName(
"livDir",
true);
155 livCmd->SetCandidates(
"livermore epics_2017");
157 livCmd->SetToBeBroadcasted(
false);
160 dnaSolCmd->SetGuidance(
"The name of e- solvation DNA model");
161 dnaSolCmd->SetParameterName(
"dnaSol",
true);
162 dnaSolCmd->SetCandidates(
"Ritchie1994 Terrisol1990 Meesungnoen2002 Kreipl2009 Meesungnoen2002_amorphous");
164 dnaSolCmd->SetToBeBroadcasted(
false);
167 dnaChemModel->SetGuidance(
"The name of DNA chemistry time step model");
168 dnaChemModel->SetParameterName(
"TimeStepModel",
true);
169 dnaChemModel->SetCandidates(
"SBS IRT IRT_syn");
171 dnaChemModel->SetToBeBroadcasted(
false);
174 meCmd->SetGuidance(
"Activate MicroElec model in the G4Region");
175 meCmd->SetParameterName(
"MicroElec",
true);
177 meCmd->SetToBeBroadcasted(
false);
179 dnaCmd =
new G4UIcommand(
"/process/em/AddDNARegion",
this);
180 dnaCmd->SetGuidance(
"Activate DNA in a G4Region.");
181 dnaCmd->SetGuidance(
" regName : G4Region name");
182 dnaCmd->SetGuidance(
" dnaType : DNA_opt0, DNA_Opt2, DNA_Opt4, DNA_Opt4a, DNA_Opt6, DNA_Opt6a, DNA_Opt7");
184 dnaCmd->SetToBeBroadcasted(
false);
187 dnaCmd->SetParameter(regName);
190 dnaCmd->SetParameter(type);
191 type->SetParameterCandidates(
"DNA_Opt0 DNA_Opt2 DNA_Opt4 DNA_Opt4a DNA_Opt6 DNA_Opt6a DNA_Opt7");
193 deexCmd =
new G4UIcommand(
"/process/em/deexcitation",
this);
194 deexCmd->SetGuidance(
"Set deexcitation flags per G4Region.");
195 deexCmd->SetGuidance(
" regName : G4Region name");
196 deexCmd->SetGuidance(
" flagFluo : Fluorescence");
197 deexCmd->SetGuidance(
" flagAuger : Auger");
198 deexCmd->SetGuidance(
" flagPIXE : PIXE");
200 deexCmd->SetToBeBroadcasted(
false);
203 deexCmd->SetParameter(regNameD);
206 deexCmd->SetParameter(flagFluo);
209 deexCmd->SetParameter(flagAuger);
212 deexCmd->SetParameter(flagPIXE);
246 G4bool physicsModified =
false;
247 if (command == deCmd) {
248 theParameters->SetFluo(deCmd->GetNewBoolValue(newValue));
249 physicsModified =
true;
250 }
else if (command == dirFluoCmd) {
251 theParameters->SetBeardenFluoDir(dirFluoCmd->GetNewBoolValue(newValue));
252 physicsModified =
true;
253 }
else if (command == dirFluoCmd1) {
254 theParameters->SetANSTOFluoDir(dirFluoCmd1->GetNewBoolValue(newValue));
255 physicsModified =
true;
256 }
else if (command == auCmd) {
257 theParameters->SetAuger(auCmd->GetNewBoolValue(newValue));
258 physicsModified =
true;
259 }
else if (command == auCascadeCmd) {
260 theParameters->SetAuger(auCascadeCmd->GetNewBoolValue(newValue));
261 physicsModified =
true;
262 }
else if (command == pixeCmd) {
263 theParameters->SetPixe(pixeCmd->GetNewBoolValue(newValue));
264 physicsModified =
true;
265 }
else if (command == dcutCmd) {
266 theParameters->SetDeexcitationIgnoreCut(dcutCmd->GetNewBoolValue(newValue));
267 physicsModified =
true;
268 }
else if (command == dnafCmd) {
269 theParameters->SetDNAFast(dnafCmd->GetNewBoolValue(newValue));
270 }
else if (command == dnasCmd) {
271 theParameters->SetDNAStationary(dnasCmd->GetNewBoolValue(newValue));
272 }
else if (command == dnamscCmd) {
273 theParameters->SetDNAElectronMsc(dnamscCmd->GetNewBoolValue(newValue));
274 }
else if (command == dnaSolCmd) {
276 if(newValue ==
"Ritchie1994") {
278 }
else if(newValue ==
"Terrisol1990") {
280 }
else if (newValue ==
"Meesungnoen2002") {
282 }
else if (newValue ==
"Meesungnoen2002_amorphous") {
284 }
else if (newValue ==
"Kreipl2009") {
287 theParameters->SetDNAeSolvationSubType(ttt);
288 }
else if (command == dnaChemModel) {
290 if(newValue ==
"IRT") {
292 }
else if(newValue ==
"SBS") {
294 }
else if (newValue ==
"IRT_syn") {
297 theParameters->SetChemTimeStepModel(stepM);
298 }
else if (command == direFluoCmd) {
301 else if(newValue ==
"ANSTO") { ttt =
fluoANSTO; }
303 theParameters->SetFluoDirectory(ttt);
304 }
else if (command == pixeXsCmd) {
305 theParameters->SetPIXECrossSectionModel(newValue);
306 physicsModified =
true;
307 }
else if (command == pixeeXsCmd) {
308 theParameters->SetPIXEElectronCrossSectionModel(newValue);
309 physicsModified =
true;
310 }
else if (command == livCmd) {
311 theParameters->SetLivermoreDataDir(newValue);
312 }
else if (command == meCmd) {
313 theParameters->AddMicroElec(newValue);
314 }
else if (command == dnaCmd) {
316 std::istringstream is(newValue);
318 theParameters->AddDNA(s1, s2);
319 }
else if (command == deexCmd) {
320 G4String s1 (
""), s2(
""), s3(
""), s4(
"");
321 G4bool b2(
false), b3(
false), b4(
false);
322 std::istringstream is(newValue);
323 is >> s1 >> s2 >> s3 >> s4;
324 if(s2 ==
"true") { b2 =
true; }
325 if(s3 ==
"true") { b3 =
true; }
326 if(s4 ==
"true") { b4 =
true; }
327 theParameters->SetDeexActiveRegion(s1,b2,b3,b4);
328 physicsModified =
true;
331 if(physicsModified) {