59 scoreDir->SetGuidance(
"Interactive scoring commands.");
62 listCmd->SetGuidance(
"List scoring worlds.");
65 dumpCmd->SetGuidance(
"Dump results of scorers.");
68 verboseCmd->SetGuidance(
"Verbosity.");
69 verboseCmd->SetGuidance(
" 0) errors or warnings,");
70 verboseCmd->SetGuidance(
" 1) information with 0)");
73 meshCreateDir->SetGuidance(
" Mesh creation commands.");
77 meshBoxCreateCmd->SetGuidance(
"Create scoring box mesh.");
78 meshBoxCreateCmd->SetParameterName(
"MeshName",
false);
80 meshCylinderCreateCmd =
82 meshCylinderCreateCmd->SetGuidance(
"Create scoring mesh.");
83 meshCylinderCreateCmd->SetParameterName(
"MeshName",
false);
85 meshRWLogVolCreateCmd =
86 new G4UIcommand(
"/score/create/realWorldLogVol",
this);
87 meshRWLogVolCreateCmd->SetGuidance(
88 "Define scorers to a logical volume defined in the real world.");
89 meshRWLogVolCreateCmd->SetGuidance(
90 " - Name of the specified logical volume is used as the mesh name.");
91 meshRWLogVolCreateCmd->SetGuidance(
92 " - /score/mesh commands do not affect for this mesh.");
93 meshRWLogVolCreateCmd->SetGuidance(
94 " - If copyNumberLevel is set, the copy number of that-level higher");
95 meshRWLogVolCreateCmd->SetGuidance(
96 " in the geometrical hierarchy is used as the index.");
98 meshRWLogVolCreateCmd->SetParameter(param);
102 meshRWLogVolCreateCmd->SetParameter(param);
104 probeCreateCmd =
new G4UIcommand(
"/score/create/probe",
this);
105 probeCreateCmd->SetGuidance(
"Define scoring probe.");
106 probeCreateCmd->SetGuidance(
107 " halfSize defines the half-width of the probing cube.");
109 probeCreateCmd->SetParameter(param);
111 probeCreateCmd->SetParameter(param);
114 probeCreateCmd->SetParameter(param);
117 probeCreateCmd->SetParameter(param);
120 meshOpnCmd->SetGuidance(
"Open scoring mesh.");
121 meshOpnCmd->SetParameterName(
"MeshName",
false);
124 meshClsCmd->SetGuidance(
"Close scoring mesh.");
127 meshDir->SetGuidance(
" Mesh processing commands.");
130 mBoxSizeCmd->SetGuidance(
"Define size of the scoring mesh.");
131 mBoxSizeCmd->SetGuidance(
"Dx Dy Dz unit");
132 mBoxSizeCmd->SetParameterName(
"Di",
"Dj",
"Dk",
false,
false);
133 mBoxSizeCmd->SetRange(
"Di>0. && Dj>0. && Dk>0.");
134 mBoxSizeCmd->SetDefaultUnit(
"mm");
136 mCylinderSizeCmd =
new G4UIcommand(
"/score/mesh/cylinderSize",
this);
137 mCylinderSizeCmd->SetGuidance(
"Define size of the scoring mesh.");
138 mCylinderSizeCmd->SetGuidance(
"R Dz unit");
141 mCylinderSizeCmd->SetParameter(param);
144 mCylinderSizeCmd->SetParameter(param);
147 mCylinderSizeCmd->SetParameter(param);
151 mCylinderRMinCmd->SetGuidance(
"Define the inner radius of the tube mesh.");
152 mCylinderRMinCmd->SetGuidance(
"This command is not needed for cylinder mesh");
153 mCylinderRMinCmd->SetParameterName(
"RMin",
false,
false);
154 mCylinderRMinCmd->SetRange(
"RMin>=0.");
155 mCylinderRMinCmd->SetDefaultUnit(
"mm");
157 mCylinderAngleCmd =
new G4UIcommand(
"/score/mesh/cylinderAngles",
this);
158 mCylinderAngleCmd->SetGuidance(
159 "Define starting angle and span for tube segment mesh.");
160 mCylinderAngleCmd->SetGuidance(
161 "This command is not needed for cylinder mesh");
163 mCylinderAngleCmd->SetParameter(param);
166 mCylinderAngleCmd->SetParameter(param);
169 mCylinderAngleCmd->SetParameter(param);
172 mBinCmd =
new G4UIcommand(
"/score/mesh/nBin",
this);
173 mBinCmd->SetGuidance(
"Define segments of the scoring mesh.");
174 mBinCmd->SetGuidance(
"[usage] /score/mesh/nBin");
175 mBinCmd->SetGuidance(
" In case of boxMesh, parameters are given in");
176 mBinCmd->SetGuidance(
" Ni :(int) Number of bins i (in x-axis) ");
177 mBinCmd->SetGuidance(
" Nj :(int) Number of bins j (in y-axis) ");
178 mBinCmd->SetGuidance(
" Nk :(int) Number of bins k (in z-axis) ");
179 mBinCmd->SetGuidance(
" In case of cylinderMesh, parameters are given in");
180 mBinCmd->SetGuidance(
" Nr :(int) Number of bins in radial axis ");
181 mBinCmd->SetGuidance(
" Nz :(int) Number of bins in z axis ");
182 mBinCmd->SetGuidance(
" Nphi:(int) Number of bins in phi axis ");
187 mBinCmd->SetParameter(param);
191 mBinCmd->SetParameter(param);
194 mBinCmd->SetParameter(param);
199 mTransDir->SetGuidance(
"Mesh translation commands.");
202 mTResetCmd->SetGuidance(
"Reset translated position of the scoring mesh.");
205 mTXyzCmd->SetGuidance(
"Translate the scoring mesh.");
206 mTXyzCmd->SetParameterName(
"X",
"Y",
"Z",
false,
false);
207 mTXyzCmd->SetDefaultUnit(
"mm");
210 mRotDir->SetGuidance(
"Mesh rotation commands.");
213 mRotXCmd->SetGuidance(
"Rotate the scoring mesh in X axis.");
214 mRotXCmd->SetParameterName(
"Rx",
false);
215 mRotXCmd->SetDefaultUnit(
"deg");
218 mRotYCmd->SetGuidance(
"Rotate the scoring mesh in Y axis.");
219 mRotYCmd->SetParameterName(
"Ry",
false);
220 mRotYCmd->SetDefaultUnit(
"deg");
223 mRotZCmd->SetGuidance(
"Rotate the scoring mesh in Z axis.");
224 mRotZCmd->SetParameterName(
"Rz",
false);
225 mRotZCmd->SetDefaultUnit(
"deg");
228 probeDir->SetGuidance(
"Probe commands");
231 probeMatCmd->SetGuidance(
"Specify a material to the probe cube.");
232 probeMatCmd->SetGuidance(
"Material name has to be taken from G4NistManager.");
233 probeMatCmd->SetGuidance(
"Once this command is used, the specified material "
234 "overlays the material in the mass geometry");
235 probeMatCmd->SetGuidance(
"with \"Layered Mass Geometry\" mechanism so that "
236 "physics quantities such as energy deposition");
237 probeMatCmd->SetGuidance(
"or dose will be calculated with this material.");
238 probeMatCmd->SetGuidance(
"To switch-off this overlaying, use \"none\".");
239 probeMatCmd->SetParameterName(
"matName",
true);
240 probeMatCmd->SetDefaultValue(
"none");
243 probeLocateCmd->SetGuidance(
244 "Locate a probe in the global coordinate system.");
245 probeLocateCmd->SetParameterName(
"x",
"y",
"z",
false);
246 probeLocateCmd->SetDefaultUnit(
"mm");
249 drawCmd =
new G4UIcommand(
"/score/drawProjection",
this);
250 drawCmd->SetGuidance(
"Draw projection(s) of scored quantities.");
251 drawCmd->SetGuidance(
252 "Parameter <proj> specified which projection(s) to be drawn.");
253 drawCmd->SetGuidance(
254 " 100 : xy-plane, 010 : yz-plane, 001 : zx-plane -- default 111");
255 drawCmd->SetGuidance(
256 " 100 : N/A, 010 : z_phi-plane, 001 : r_phi-plane -- default 111");
258 drawCmd->SetParameter(param);
260 drawCmd->SetParameter(param);
263 drawCmd->SetParameter(param);
266 drawCmd->SetParameter(param);
267 drawCmd->SetToBeBroadcasted(
false);
270 drawColumnCmd =
new G4UIcommand(
"/score/drawColumn",
this);
271 drawColumnCmd->SetGuidance(
"Draw a cell column.");
272 drawColumnCmd->SetGuidance(
" plane = 0 : x-y, 1: y-z, 2: z-x for box mesh");
273 drawColumnCmd->SetGuidance(
274 " 0 : z-phi, 1: r-phi, 2: r-z for cylinder mesh");
276 drawColumnCmd->SetParameter(param);
278 drawColumnCmd->SetParameter(param);
281 drawColumnCmd->SetParameter(param);
283 drawColumnCmd->SetParameter(param);
286 drawColumnCmd->SetParameter(param);
287 drawColumnCmd->SetToBeBroadcasted(
false);
290 colorMapDir->SetGuidance(
"Color map commands.");
294 listColorMapCmd->SetGuidance(
"List registered score color maps.");
295 listColorMapCmd->SetToBeBroadcasted(
false);
298 floatMinMaxCmd->SetGuidance(
299 "Min/Max of the color map is calculated according to the actual scores.");
300 floatMinMaxCmd->SetParameterName(
"colorMapName",
true,
false);
301 floatMinMaxCmd->SetDefaultValue(
"defaultLinearColorMap");
302 floatMinMaxCmd->SetToBeBroadcasted(
false);
304 colorMapMinMaxCmd =
new G4UIcommand(
"/score/colorMap/setMinMax",
this);
305 colorMapMinMaxCmd->SetGuidance(
"Define min/max value of the color map.");
308 colorMapMinMaxCmd->SetParameter(param);
310 colorMapMinMaxCmd->SetParameter(param);
312 colorMapMinMaxCmd->SetParameter(param);
313 colorMapMinMaxCmd->SetToBeBroadcasted(
false);
316 dumpQtyToFileCmd =
new G4UIcommand(
"/score/dumpQuantityToFile",
this);
317 dumpQtyToFileCmd->SetGuidance(
"Dump one scored quantity to file.");
319 dumpQtyToFileCmd->SetParameter(param);
321 dumpQtyToFileCmd->SetParameter(param);
323 dumpQtyToFileCmd->SetParameter(param);
325 dumpQtyToFileCmd->SetParameter(param);
326 dumpQtyToFileCmd->SetToBeBroadcasted(
false);
328 dumpQtyWithFactorCmd =
new G4UIcommand(
"/score/dumpQuantityWithFactor",
this);
329 dumpQtyWithFactorCmd->SetGuidance(
"Dump one scored quantity to file.");
330 dumpQtyWithFactorCmd->SetGuidance(
331 "Each value is multiplied by the specified factor.");
333 dumpQtyWithFactorCmd->SetParameter(param);
335 dumpQtyWithFactorCmd->SetParameter(param);
337 dumpQtyWithFactorCmd->SetParameter(param);
340 dumpQtyWithFactorCmd->SetParameter(param);
342 dumpQtyWithFactorCmd->SetParameter(param);
343 dumpQtyWithFactorCmd->SetToBeBroadcasted(
false);
346 dumpAllQtsToFileCmd =
new G4UIcommand(
"/score/dumpAllQuantitiesToFile",
this);
347 dumpAllQtsToFileCmd->SetGuidance(
"Dump all quantities of the mesh to file.");
349 dumpAllQtsToFileCmd->SetParameter(param);
351 dumpAllQtsToFileCmd->SetParameter(param);
353 dumpAllQtsToFileCmd->SetParameter(param);
354 dumpAllQtsToFileCmd->SetToBeBroadcasted(
false);
356 dumpAllQtsWithFactorCmd =
357 new G4UIcommand(
"/score/dumpAllQuantitiesWithFactor",
this);
358 dumpAllQtsWithFactorCmd->SetGuidance(
359 "Dump all quantities of the mesh to file.");
360 dumpAllQtsWithFactorCmd->SetGuidance(
361 "Each value is multiplied by the specified factor.");
363 dumpAllQtsWithFactorCmd->SetParameter(param);
365 dumpAllQtsWithFactorCmd->SetParameter(param);
368 dumpAllQtsWithFactorCmd->SetParameter(param);
370 dumpAllQtsWithFactorCmd->SetParameter(param);
371 dumpAllQtsWithFactorCmd->SetToBeBroadcasted(
false);
373 fill1DCmd =
new G4UIcommand(
"/score/fill1D",
this);
374 fill1DCmd->SetGuidance(
"Let a primitive scorer fill 1-D histogram");
375 fill1DCmd->SetGuidance(
"Before using this command, primitive scorer must be "
376 "defined and assigned.");
377 fill1DCmd->SetGuidance(
"Also before using this command, a histogram has to "
378 "be defined by /analysis/h1/create command.");
379 fill1DCmd->SetGuidance(
380 "This command is available only for real-world volume or probe.");
381 fill1DCmd->SetGuidance(
"Please note that this command has to be applied to "
382 "each copy number of the scoring volume.");
383 fill1DCmd->SetGuidance(
"If same histogram ID is used more than once, more "
384 "than one scorers fill that histogram.");
386 fill1DCmd->SetParameter(param);
388 fill1DCmd->SetParameter(param);
390 fill1DCmd->SetParameter(param);
393 fill1DCmd->SetParameter(param);
451 if(command == listCmd)
455 else if(command == dumpCmd)
459 else if(command == drawCmd)
466 fSMan->DrawMesh(meshName, psName, colorMapName, axflg);
468 else if(command == drawColumnCmd)
476 fSMan->DrawMesh(meshName, psName, iPlane, iColumn, colorMapName);
478 else if(command == dumpQtyToFileCmd)
485 auto mesh = fSMan->FindMesh(meshName);
489 ed <<
"Mesh name <" << meshName <<
"> is not found. Command ignored.";
493 fSMan->DumpQuantityToFile(meshName, psName, fileName, option);
495 else if(command == dumpQtyWithFactorCmd)
503 auto mesh = fSMan->FindMesh(meshName);
507 ed <<
"Mesh name <" << meshName <<
"> is not found. Command ignored.";
511 fSMan->SetFactor(fac);
512 fSMan->DumpQuantityToFile(meshName, psName, fileName, option);
513 fSMan->SetFactor(1.0);
515 else if(command == dumpAllQtsToFileCmd)
521 auto mesh = fSMan->FindMesh(meshName);
525 ed <<
"Mesh name <" << meshName <<
"> is not found. Command ignored.";
529 fSMan->DumpAllQuantitiesToFile(meshName, fileName, option);
531 else if(command == dumpAllQtsWithFactorCmd)
538 auto mesh = fSMan->FindMesh(meshName);
542 ed <<
"Mesh name <" << meshName <<
"> is not found. Command ignored.";
546 fSMan->SetFactor(fac);
547 fSMan->DumpAllQuantitiesToFile(meshName, fileName, option);
548 fSMan->SetFactor(1.0);
550 else if(command == fill1DCmd)
554 else if(command == verboseCmd)
556 fSMan->SetVerboseLevel(verboseCmd->GetNewIntValue(newVal));
558 else if(command == meshBoxCreateCmd)
561 if(currentmesh !=
nullptr)
564 ed <<
"ERROR[" << meshBoxCreateCmd->GetCommandPath() <<
"] : Mesh <"
566 <<
"> is still open. Close it first. Command ignored.";
575 fSMan->RegisterScoringMesh(mesh);
580 ed <<
"ERROR[" << meshBoxCreateCmd->GetCommandPath()
581 <<
"] : Scoring mesh <" << newVal
582 <<
"> already exists. Command ignored.";
587 else if(command == meshCylinderCreateCmd)
590 if(currentmesh !=
nullptr)
593 ed <<
"ERROR[" << meshCylinderCreateCmd->GetCommandPath() <<
"] : Mesh <"
595 <<
"> is still open. Close it first. Command ignored.";
604 fSMan->RegisterScoringMesh(mesh);
609 ed <<
"ERROR[" << meshCylinderCreateCmd->GetCommandPath()
610 <<
"] : Scoring mesh <" << newVal
611 <<
"> already exists. Command ignored.";
616 else if(command == meshRWLogVolCreateCmd)
618 auto mesh = fSMan->GetCurrentMesh();
622 ed <<
"ERROR[" << meshRWLogVolCreateCmd->GetCommandPath() <<
"] : Mesh <"
623 << mesh->GetWorldName()
624 <<
"> is still open. Close it first. Command ignored.";
632 mesh = fSMan->FindMesh(meshName);
636 mesh->SetCopyNumberLevel(idx);
637 fSMan->RegisterScoringMesh(mesh);
642 ed <<
"ERROR[" << meshRWLogVolCreateCmd->GetCommandPath()
643 <<
"] : Scoring mesh <" << meshName
644 <<
"> already exists. Command ignored.";
649 else if(command == probeCreateCmd)
651 auto mesh = fSMan->GetCurrentMesh();
655 ed <<
"ERROR[" << meshRWLogVolCreateCmd->GetCommandPath() <<
"] : Mesh <"
656 << mesh->GetWorldName()
657 <<
"> is still open. Close it first. Command ignored.";
667 mesh = fSMan->FindMesh(qname);
671 fSMan->RegisterScoringMesh(mesh);
676 ed <<
"ERROR[" << probeCreateCmd->GetCommandPath() <<
"] : Mesh name <"
677 << qname <<
"> already exists. Use another name.";
682 else if(command == probeMatCmd || command == probeLocateCmd)
684 auto mesh = fSMan->GetCurrentMesh();
688 ed <<
"ERROR : No mesh is currently open. Open/create a mesh first. "
693 if(mesh->GetShape() != MeshShape::probe)
696 ed <<
"ERROR : Inconsistent mesh type. Close current mesh and open "
702 if(command == probeMatCmd)
708 ed <<
"Material <" << newVal
709 <<
"> is not defind in G4NistManager. Command is ignored.\n"
710 <<
"Use /material/nist/listMaterials command to see the available "
716 else if(command == probeLocateCmd)
718 G4ThreeVector loc = probeLocateCmd->GetNew3VectorValue(newVal);
722 else if(command == listColorMapCmd)
724 fSMan->ListScoreColorMaps();
726 else if(command == floatMinMaxCmd)
729 if(colorMap !=
nullptr)
736 ed <<
"ERROR[" << floatMinMaxCmd->GetCommandPath() <<
"] : color map <"
737 << newVal <<
"> is not defined. Command ignored.";
741 else if(command == colorMapMinMaxCmd)
748 if(colorMap !=
nullptr)
756 ed <<
"ERROR[" << colorMapMinMaxCmd->GetCommandPath() <<
"] : color map <"
757 << newVal <<
"> is not defined. Command ignored." <<
G4endl;
761 else if(command == meshOpnCmd)
764 if(currentmesh !=
nullptr)
767 ed <<
"ERROR[" << meshOpnCmd->GetCommandPath() <<
"] : Mesh <"
769 <<
"> is still open. Close it first. Command ignored.";
778 ed <<
"ERROR[" << meshOpnCmd->GetCommandPath() <<
"] : Scoring mesh <"
779 << newVal <<
"> does not exist. Command ignored.";
784 fSMan->SetCurrentMesh(mesh);
788 else if(command == meshClsCmd)
790 fSMan->CloseCurrentMesh();
803 if(shape == MeshShape::realWorldLogVol)
806 ed <<
"ERROR[" << mBinCmd->GetCommandPath()
807 <<
"] : Number of mesh command cannot be set for this type of mesh. "
818 if(command == mBoxSizeCmd)
820 if(shape == MeshShape::box)
822 G4ThreeVector size = mBoxSizeCmd->GetNew3VectorValue(newVal);
832 ed <<
"ERROR[" << mBoxSizeCmd->GetCommandPath()
833 <<
"] : This mesh is not Box. Command ignored.";
837 else if(command == mCylinderSizeCmd || command == mCylinderRMinCmd ||
838 command == mCylinderAngleCmd)
840 if(shape != MeshShape::cylinder)
844 <<
"] : This mesh is not Cylinder. Command ignored.";
849 if(command == mCylinderSizeCmd)
852 vsize[0] = (mesh->
GetSize()).x();
853 vsize[1] =
StoD(token[0]);
854 vsize[2] =
StoD(token[1]);
855 G4double unt = mCylinderSizeCmd->ValueOf(token[2]);
860 else if(command == mCylinderRMinCmd)
863 vsize[0] = mCylinderRMinCmd->GetNewDoubleValue(newVal);
864 vsize[1] = (mesh->
GetSize()).y();
865 vsize[2] = (mesh->
GetSize()).z();
868 else if(command == mCylinderAngleCmd)
872 G4double unt = mCylinderAngleCmd->ValueOf(token[2]);
873 mesh->
SetAngles(stphi * unt, spphi * unt);
877 else if(command == mBinCmd)
881 else if(command == mTResetCmd)
883 G4double centerPosition[3] = { 0., 0., 0. };
886 else if(command == mTXyzCmd)
890 centerPosition[0] = xyz.
x();
891 centerPosition[1] = xyz.
y();
892 centerPosition[2] = xyz.
z();
895 else if(command == mRotXCmd)
897 G4double value = mRotXCmd->GetNewDoubleValue(newVal);
900 else if(command == mRotYCmd)
902 G4double value = mRotYCmd->GetNewDoubleValue(newVal);
905 else if(command == mRotZCmd)
907 G4double value = mRotZCmd->GetNewDoubleValue(newVal);
915 ed <<
"ERROR: No mesh is currently open. Open/create a mesh first. "