50{
51 G4UIparameter* param = nullptr;
52
53 theDirectory = new G4UIdirectory("/run/particle/");
54 theDirectory->SetGuidance("Commands for G4VUserPhysicsList.");
55
56
57 verboseCmd = new G4UIcmdWithAnInteger("/run/particle/verbose", this);
58 verboseCmd->SetGuidance("Set the Verbose level of G4VUserPhysicsList.");
59 verboseCmd->SetGuidance(" 0 : Silent (default)");
60 verboseCmd->SetGuidance(" 1 : Display warning messages");
61 verboseCmd->SetGuidance(" 2 : Display more");
62 verboseCmd->SetParameterName("level", true);
63 verboseCmd->SetDefaultValue(0);
64 verboseCmd->SetRange("level >=0 && level <=3");
65
66
67 setCutCmd = new G4UIcmdWithADoubleAndUnit("/run/setCut", this);
68 setCutCmd->SetGuidance("Set default cut value ");
69 setCutCmd->SetParameterName("cut", false);
70 setCutCmd->SetDefaultValue(1.0);
71 setCutCmd->SetRange("cut >=0.0");
72 setCutCmd->SetDefaultUnit("mm");
74
75
76 setCutForAGivenParticleCmd = new G4UIcommand("/run/setCutForAGivenParticle", this);
77 setCutForAGivenParticleCmd->SetGuidance("Set a cut value to a specific particle ");
78 setCutForAGivenParticleCmd->SetGuidance("Usage: /run/setCutForAGivenParticle gamma 1. mm");
79 param = new G4UIparameter("particleName", 's', false);
81 setCutForAGivenParticleCmd->SetParameter(param);
82 param = new G4UIparameter("cut", 'd', false);
85 setCutForAGivenParticleCmd->SetParameter(param);
86 param = new G4UIparameter("unit", 's', false);
88 setCutForAGivenParticleCmd->SetParameter(param);
90
91
92 getCutForAGivenParticleCmd = new G4UIcmdWithAString("/run/getCutForAGivenParticle", this);
93 getCutForAGivenParticleCmd->SetGuidance("Get a cut value to a specific particle ");
94 getCutForAGivenParticleCmd->SetGuidance("Usage: /run/getCutForAGivenParticle gamma ");
95 getCutForAGivenParticleCmd->SetParameterName("particleName", false, false);
96 getCutForAGivenParticleCmd->SetCandidates("e- e+ gamma proton");
99
100
101 setCutRCmd = new G4UIcommand("/run/setCutForRegion", this);
102 setCutRCmd->SetGuidance("Set cut value for a region");
103 param = new G4UIparameter("Region", 's', false);
104 setCutRCmd->SetParameter(param);
105 param = new G4UIparameter("cut", 'd', false);
107 setCutRCmd->SetParameter(param);
108 param = new G4UIparameter("Unit", 's', true);
111 setCutRCmd->SetParameter(param);
113
114
115 dumpListCmd = new G4UIcmdWithoutParameter("/run/particle/dumpList", this);
116 dumpListCmd->SetGuidance("Dump List of particles in G4VUserPhysicsList. ");
117
118
119 addProcManCmd = new G4UIcmdWithAString("/run/particle/addProcManager", this);
120 addProcManCmd->SetToBeBroadcasted(false);
121 addProcManCmd->SetGuidance("add process manager to specified particle type");
122 addProcManCmd->SetParameterName("particleType", true);
123 addProcManCmd->SetDefaultValue("");
126
127
128 buildPTCmd = new G4UIcmdWithAString("/run/particle/buildPhysicsTable", this);
129 buildPTCmd->SetGuidance("build physics table of specified particle type");
130 buildPTCmd->SetParameterName("particleType", true);
131 buildPTCmd->SetDefaultValue("");
133
134
135 storeCmd = new G4UIcmdWithAString("/run/particle/storePhysicsTable", this);
136 storeCmd->SetGuidance("Store Physics Table");
137 storeCmd->SetGuidance(" Enter directory name");
138 storeCmd->SetParameterName("dirName", true);
139 storeCmd->SetDefaultValue("");
141
142
143 retrieveCmd = new G4UIcmdWithAString("/run/particle/retrievePhysicsTable", this);
144 retrieveCmd->SetGuidance("Retrieve Physics Table");
145 retrieveCmd->SetGuidance(" Enter directory name or OFF to switch off");
146 retrieveCmd->SetParameterName("dirName", true);
147 retrieveCmd->SetDefaultValue("");
149
150
151 asciiCmd = new G4UIcmdWithAnInteger("/run/particle/setStoredInAscii", this);
152 asciiCmd->SetGuidance("Switch on/off ascii mode in store/retrieve Physics Table");
153 asciiCmd->SetGuidance(" Enter 0(binary) or 1(ascii)");
154 asciiCmd->SetParameterName("ascii", true);
155 asciiCmd->SetDefaultValue(0);
157 asciiCmd->SetRange("ascii ==0 || ascii ==1");
158
159
160 applyCutsCmd = new G4UIcommand("/run/particle/applyCuts", this);
161 applyCutsCmd->SetGuidance("Set applyCuts flag for a particle.");
162 applyCutsCmd->SetGuidance(" Some EM processes which do not have infrared divergence");
163 applyCutsCmd->SetGuidance("may generate gamma, e- and/or e+ with kinetic energies");
164 applyCutsCmd->SetGuidance("below the production threshold. By setting this flag,");
165 applyCutsCmd->SetGuidance("such secondaries below threshold are eliminated and");
166 applyCutsCmd->SetGuidance("kinetic energies of such secondaries are accumulated");
167 applyCutsCmd->SetGuidance("to the energy deposition of their mother.");
168 applyCutsCmd->SetGuidance(" Note that 'applyCuts' makes sense only for gamma,");
169 applyCutsCmd->SetGuidance("e- and e+. If this command is issued for other particle,");
170 applyCutsCmd->SetGuidance("a warning message is displayed and the command is");
171 applyCutsCmd->SetGuidance("ignored.");
172 applyCutsCmd->SetGuidance(" If particle name is 'all', this command affects on");
173 applyCutsCmd->SetGuidance("gamma, e- and e+.");
174 param = new G4UIparameter("Flag", 's', true);
176 applyCutsCmd->SetParameter(param);
177 param = new G4UIparameter("Particle", 's', true);
179 applyCutsCmd->SetParameter(param);
181
182
183 dumpCutValuesCmd = new G4UIcmdWithAString("/run/particle/dumpCutValues", this);
184 dumpCutValuesCmd->SetGuidance("Dump a list of production threshold values in range and energy");
185 dumpCutValuesCmd->SetGuidance("for all registered material-cuts-couples.");
186 dumpCutValuesCmd->SetGuidance("Dumping a list takes place when you issue 'beamOn' and");
187 dumpCutValuesCmd->SetGuidance("actual conversion tables from range to energy are available.");
188 dumpCutValuesCmd->SetGuidance(
189 "If you want a list 'immediately', use '/run/dumpRegion' for threshold");
190 dumpCutValuesCmd->SetGuidance("list given in range only. Also, '/run/dumpCouples' gives you the");
191 dumpCutValuesCmd->SetGuidance(
192 "current list if you have already issued 'run/beamOn' at least once.");
193 dumpCutValuesCmd->SetParameterName("particle", true);
194 dumpCutValuesCmd->SetDefaultValue("all");
196
197
198 dumpOrdParamCmd = new G4UIcmdWithAnInteger("/run/particle/dumpOrderingParam", this);
199 dumpOrdParamCmd->SetGuidance("Dump a list of ordering parameter ");
200 dumpOrdParamCmd->SetParameterName("subtype", true);
201 dumpOrdParamCmd->SetDefaultValue(-1);
203}
void SetDefaultValue(const char *theDefaultValue)
void SetParameterRange(const char *theRange)
void SetParameterCandidates(const char *theString)
void SetDefaultUnit(const char *theDefaultUnit)
G4VUserPhysicsList * thePhysicsList