43 : suffix (
""), geometry(true), pointAttributes(false), solids(true), invisibles(true),
44 kgMocrenVolumeName(
"gMocrenVolume"),
45 kgMocrenScoringMeshName(
"gMocrenScoringMesh"),
46 kDrawVolumeGrid(false) {
49 kgMocrenDirectory->SetGuidance(
"gMocren commands.");
51 setEventNumberSuffixCommand =
new G4UIcmdWithAString(
"/vis/gMocren/setEventNumberSuffix",
this);
52 setEventNumberSuffixCommand->SetGuidance(
"Write separate event files, appended with given suffix.");
53 setEventNumberSuffixCommand->SetGuidance(
"Define the suffix with a pattern such as '-0000'.");
54 setEventNumberSuffixCommand->SetParameterName(
"suffix",
false);
55 setEventNumberSuffixCommand->SetDefaultValue(
"");
56 setEventNumberSuffixCommand->AvailableForStates(
G4State_Idle);
58 appendGeometryCommand =
new G4UIcmdWithABool(
"/vis/gMocren/appendGeometry",
this);
59 appendGeometryCommand->SetGuidance(
"Appends copy of geometry to every event.");
60 appendGeometryCommand->SetParameterName(
"flag",
false);
61 appendGeometryCommand->SetDefaultValue(
true);
64 addPointAttributesCommand =
new G4UIcmdWithABool(
"/vis/gMocren/addPointAttributes",
this);
65 addPointAttributesCommand->SetGuidance(
"Adds point attributes to the points of trajectories.");
66 addPointAttributesCommand->SetParameterName(
"flag",
false);
67 addPointAttributesCommand->SetDefaultValue(
false);
68 addPointAttributesCommand->AvailableForStates(
G4State_Idle);
71 useSolidsCommand->SetGuidance(
"Use GMocren Solids, rather than Geant4 Primitives.");
72 useSolidsCommand->SetParameterName(
"flag",
false);
73 useSolidsCommand->SetDefaultValue(
true);
84 kSetgMocrenVolumeNameCommand =
new G4UIcmdWithAString(
"/vis/gMocren/setVolumeName",
this);
85 kSetgMocrenVolumeNameCommand->SetGuidance(
"detector name for a volume data in gMocren data.");
86 kSetgMocrenVolumeNameCommand->SetParameterName(
"kgMocrenVolumeName",
false);
87 kSetgMocrenVolumeNameCommand->SetDefaultValue(
"gMocrenVolume");
88 kSetgMocrenVolumeNameCommand->AvailableForStates(
G4State_Idle);
91 kAddgMocrenHitNameCommand->SetGuidance(
"hit name for a dose distribution in gMocren data.");
92 kAddgMocrenHitNameCommand->SetParameterName(
"kgMocrenHitName",
false);
93 kAddgMocrenHitNameCommand->AvailableForStates(
G4State_Idle);
96 kResetgMocrenHitNameCommand->SetGuidance(
"reset all hit names.");
97 kResetgMocrenHitNameCommand->AvailableForStates(
G4State_Idle);
99 kSetgMocrenScoringMeshNameCommand =
new G4UIcmdWithAString(
"/vis/gMocren/setScoringMeshName",
this);
100 kSetgMocrenScoringMeshNameCommand->SetGuidance(
"scoring mesh name for a dose distribution in gMocren data.");
101 kSetgMocrenScoringMeshNameCommand->SetParameterName(
"kgMocrenScoringMeshName",
false);
102 kSetgMocrenScoringMeshNameCommand->SetDefaultValue(
"gMocrenScoringMesh");
103 kSetgMocrenScoringMeshNameCommand->AvailableForStates(
G4State_Idle);
105 kAddgMocrenHitScorerNameCommand =
new G4UIcmdWithAString(
"/vis/gMocren/addHitScorerName",
this);
106 kAddgMocrenHitScorerNameCommand->SetGuidance(
"hit scorer name for a dose distribution in gMocren data.");
107 kAddgMocrenHitScorerNameCommand->SetParameterName(
"kgMocrenHitScorerNames",
false);
108 kAddgMocrenHitScorerNameCommand->AvailableForStates(
G4State_Idle);
111 kResetgMocrenHitScorerNameCommand->SetGuidance(
"reset all hit scorer names.");
112 kResetgMocrenHitScorerNameCommand->AvailableForStates(
G4State_Idle);
114 kSetgMocrenNoVoxelsCommand =
new G4UIcommand(
"/vis/gMocren/setNumberOfVoxels",
this);
115 kSetgMocrenNoVoxelsCommand->SetGuidance(
"set number of voxels.");
116 kSetgMocrenNoVoxelsCommand->AvailableForStates(
G4State_Idle);
120 kSetgMocrenNoVoxelsCommand->SetParameter(param);
124 kSetgMocrenNoVoxelsCommand->SetParameter(param);
128 kSetgMocrenNoVoxelsCommand->SetParameter(param);
131 kListgMocrenCommand->SetGuidance(
"list gMocren command parameters.");
134 kDrawVolumeGridCommand =
new G4UIcmdWithABool(
"/vis/gMocren/drawVolumeGrid",
this);
135 kDrawVolumeGridCommand->SetGuidance(
"Add grid of the volume.");
136 kDrawVolumeGridCommand->SetParameterName(
"kDrawVolumeGrid",
false);
137 kDrawVolumeGridCommand->SetDefaultValue(
false);
138 kDrawVolumeGridCommand->AvailableForStates(
G4State_Idle);
143 delete setEventNumberSuffixCommand;
144 delete appendGeometryCommand;
145 delete addPointAttributesCommand;
146 delete useSolidsCommand;
148 delete kSetgMocrenVolumeNameCommand;
149 delete kAddgMocrenHitNameCommand;
150 delete kResetgMocrenHitNameCommand;
152 delete kSetgMocrenScoringMeshNameCommand;
153 delete kAddgMocrenHitScorerNameCommand;
154 delete kResetgMocrenHitScorerNameCommand;
156 delete kSetgMocrenNoVoxelsCommand;
158 delete kgMocrenDirectory;
160 delete kDrawVolumeGridCommand;
164 if (command==setEventNumberSuffixCommand) {
166 }
else if (command==appendGeometryCommand) {
167 return appendGeometryCommand->ConvertToString(geometry);
168 }
else if (command==addPointAttributesCommand) {
169 return addPointAttributesCommand->ConvertToString(pointAttributes);
170 }
else if (command==useSolidsCommand) {
171 return useSolidsCommand->ConvertToString(solids);
174 }
else if (command == kSetgMocrenVolumeNameCommand) {
175 return kgMocrenVolumeName;
176 }
else if (command == kAddgMocrenHitNameCommand) {
178 std::vector<G4String>::iterator itr = kgMocrenHitNames.begin();
179 for(; itr != kgMocrenHitNames.end(); itr++) {
184 }
else if (command == kSetgMocrenScoringMeshNameCommand) {
185 return kgMocrenScoringMeshName;
186 }
else if (command == kAddgMocrenHitScorerNameCommand) {
188 std::vector<G4String>::iterator itr = kgMocrenHitScorerNames.begin();
189 for(; itr != kgMocrenHitScorerNames.end(); itr++) {
194 }
else if (command==kDrawVolumeGridCommand) {
195 return kDrawVolumeGridCommand->ConvertToString(kDrawVolumeGrid);
202 if (command==setEventNumberSuffixCommand) {
203 suffix = std::move(newValue);
204 }
else if (command==appendGeometryCommand) {
205 geometry = appendGeometryCommand->GetNewBoolValue(newValue);
206 }
else if (command==addPointAttributesCommand) {
207 pointAttributes = addPointAttributesCommand->GetNewBoolValue(newValue);
208 }
else if (command==useSolidsCommand) {
209 solids = useSolidsCommand->GetNewBoolValue(newValue);
212 }
else if (command == kSetgMocrenVolumeNameCommand) {
213 kgMocrenVolumeName = std::move(newValue);
214 }
else if (command == kAddgMocrenHitNameCommand) {
215 kgMocrenHitNames.push_back(std::move(newValue));
216 }
else if (command == kResetgMocrenHitNameCommand) {
217 kgMocrenHitNames.clear();
218 }
else if (command == kSetgMocrenScoringMeshNameCommand) {
219 kgMocrenScoringMeshName = std::move(newValue);
220 }
else if (command == kAddgMocrenHitScorerNameCommand) {
221 kgMocrenHitScorerNames.push_back(std::move(newValue));
222 }
else if (command == kResetgMocrenHitScorerNameCommand) {
223 kgMocrenHitScorerNames.clear();
224 }
else if (command == kListgMocrenCommand) {
226 }
else if (command == kSetgMocrenNoVoxelsCommand) {
228 for(
int i = 0; i < 3; i++) {
229 kgMocrenNoVoxels[i] =
StoI(next());
231 }
else if (command==kDrawVolumeGridCommand) {
232 kDrawVolumeGrid = kDrawVolumeGridCommand->GetNewBoolValue(newValue);