841{
844
846 G4cout <<
"G4GMocrenFileSceneHandler::AddSolid(const G4Box&) : "
848
849
850 if( !IsVisible() ) { return ; }
851
852
854
855
856
862
865
866 for(
G4int i = 0; i < 12; i++) {
868 if(next == 0) break;
869 G4cout <<
" (" << v1.
x() <<
", "
874 << v2.
z() <<
") [" << next <<
"]"
876 }
877 delete poly;
878 }
879
880
881
882 G4String volName = kMessenger.getVolumeName();
883
884
885 if(kFlagParameterization != 2) {
887 if(pScrMan) {
888 G4ScoringBox * pScBox =
dynamic_cast<G4ScoringBox*
>(pScrMan->
FindMesh(volName));
890 if(pScBox != NULL) bMesh = true;
891 if(bMesh) kFlagParameterization = 2;
893 << volName <<
" - " << bMesh <<
G4endl;
894 }
895 }
896
897 const G4VModel* pv_model =
GetModel();
898 if (!pv_model) { return ; }
899 G4PhysicalVolumeModel* pPVModel =
900 dynamic_cast<G4PhysicalVolumeModel*
>(
fpModel);
901 if (!pPVModel) { return ; }
902
903
904
913 G4cout <<
" density : " << dens <<
" [g/cm3]" <<
G4endl;
919 }
920
921
923
925
933 }
934 kVolumeTrans3D = kVolumeTrans3D*trot;
936
937
938
939
940 G4VPhysicalVolume * pv[3] = {0,0,0};
942 if(!pv[0]) {
943 G4Exception(
"G4GMocrenFileSceneHandler::AddSolid( const G4Box& box )",
945 }
946 G4int dirAxis[3] = {-1,-1,-1};
947 G4int nDaughters[3] = {0,0,0};
948
951 nDaughters[0] = nReplicas;
952 switch(axis) {
953 case kXAxis: dirAxis[0] = 0;
break;
954 case kYAxis: dirAxis[0] = 1;
break;
955 case kZAxis: dirAxis[0] = 2;
break;
956 default:
957 G4Exception(
"G4GMocrenFileSceneHandler::AddSolid( const G4Box& box )",
959 }
960 kNestedVolumeNames.push_back(pv[0]->
GetName());
963 <<
" # : " << nDaughters[0] <<
G4endl;
964
965
967 if(pv[0]->GetLogicalVolume()->GetNoDaughters()) {
968 G4cout <<
"# of daughters : "
970 } else {
971
972
973 }
974 }
975
976
979 if(pv[0]->GetLogicalVolume()->GetNoDaughters() == 0) {
980 kFlagParameterization = 1;
981
982
983 }
984
985 if(kFlagParameterization == 0) {
986
988 if(pv[1]) {
990 nDaughters[1] = nReplicas;
991 switch(axis) {
992 case kXAxis: dirAxis[1] = 0;
break;
993 case kYAxis: dirAxis[1] = 1;
break;
994 case kZAxis: dirAxis[1] = 2;
break;
995 default:
996 G4Exception(
"G4GMocrenFileSceneHandler::AddSolid( const G4Box& box )",
998 }
999 kNestedVolumeNames.push_back(pv[1]->
GetName());
1002 <<
" # : " << nDaughters[1]<<
G4endl;
1003
1004
1006 if(pv[2]) {
1008 kNestedVolumeNames.push_back(pv[2]->
GetName());
1011 <<
" # : " << nDaughters[2] <<
G4endl;
1012
1013 if(nDaughters[2] > 1) {
1014 G4VNestedParameterisation * nestPara
1016 if(nestPara == NULL)
1017 G4Exception(
"G4GMocrenFileSceneHandler::AddSolid( const G4Box& box )",
1019
1026 G4cout << trans0 <<
" - " << trans1 <<
" - " << diff <<
G4endl;
1027
1028 if(diff.x() != 0.) dirAxis[2] = 0;
1029 else if(diff.y() != 0.) dirAxis[2] = 1;
1030 else if(diff.z() != 0.) dirAxis[2] = 2;
1031 else
1032 G4Exception(
"G4GMocrenFileSceneHandler::AddSolid( const G4Box& box )",
1033 "gMocren0009",
FatalException,
"Unexpected nested parameterisation");
1034 }
1035 }
1036 }
1037
1038 for(
G4int i = 0; i < 3; i++) {
1039 kNestedVolumeDimension[i] = nDaughters[i];
1040
1041 kNestedVolumeDirAxis[i] = dirAxis[i];
1042 }
1043
1044
1045
1046
1047 G4VNestedParameterisation * nestPara
1049 if(nestPara != NULL) {
1050 G4double prexyz[3] = {0.,0.,0.}, xyz[3] = {0.,0.,0.};
1051 for(
G4int n0 = 0; n0 < nDaughters[0]; n0++) {
1052 for(
G4int n1 = 0; n1 < nDaughters[1]; n1++) {
1053 for(
G4int n2 = 0; n2 < nDaughters[2]; n2++) {
1054
1055 G4GMocrenTouchable * touch = new G4GMocrenTouchable(n1, n0);
1057 G4cout <<
" retrieve volume : copy # : " << n0
1058 <<
", " << n1 <<
", " << n2 <<
G4endl;
1060 delete touch;
1062
1064 G4cout <<
" density :" << dens <<
" [g/cm3]" <<
G4endl;
1065
1066 G4Box tbox(box);
1068 xyz[0] = tbox.GetXHalfLength()/mm;
1069 xyz[1] = tbox.GetYHalfLength()/mm;
1070 xyz[2] = tbox.GetZHalfLength()/mm;
1071 if(n0 != 0 || n1 != 0 || n2 != 0) {
1072 for(
G4int i = 0; i < 3; i++) {
1073 if(xyz[i] != prexyz[i])
1074 G4Exception(
"G4GMocrenFileSceneHandler::AddSolid( const G4Box& box )",
1076 }
1077 }
1079 G4cout <<
" size : " << tbox.GetXHalfLength()/mm <<
" x "
1080 << tbox.GetYHalfLength()/mm << " x "
1081 << tbox.GetZHalfLength()/mm <<
" [mm3]" <<
G4endl;
1082
1084 idx[dirAxis[0]] = n0;
1085 idx[dirAxis[1]] = n1;
1086 idx[dirAxis[2]] = n2;
1087 Index3D i3d(idx[0],idx[1],idx[2]);
1088 kNestedModality[i3d] = dens;
1090 G4cout <<
" index: " << idx[0] <<
", " << idx[1] <<
", " << idx[2]
1091 <<
" density: " << dens <<
G4endl;
1092
1093 for(
G4int i = 0; i < 3; i++) prexyz[i] = xyz[i];
1094 }
1095 }
1096 }
1097
1101
1102 if(!kbSetModalityVoxelSize) {
1104 static_cast<G4float>(2*xyz[1]),
1105 static_cast<G4float>(2*xyz[2])};
1106 kgMocrenIO->setVoxelSpacing(spacing);
1107 kVoxelDimension.set(spacing[0], spacing[1], spacing[2]);
1108 kbSetModalityVoxelSize = true;
1109 }
1110
1111 } else {
1114 G4Exception(
"G4GMocrenFileSceneHandler::AddSolid( const G4Box& box )",
1116 }
1117
1118
1119
1120
1125
1126
1128 G4cout <<
" physical volume node id : "
1129 << "size: " << npvp << ", PV name: ";
1130 for(
G4int i = 0; i < npvp; i++) {
1132 << " [param:"
1133 << pPVModel->
GetDrawnPVPath()[i].GetPhysicalVolume()->IsParameterised()
1134 << ",rep:"
1135 << pPVModel->
GetDrawnPVPath()[i].GetPhysicalVolume()->IsReplicated();
1136 if(pPVModel->
GetDrawnPVPath()[i].GetPhysicalVolume()->GetParameterisation()) {
1138 << pPVModel->
GetDrawnPVPath()[i].GetPhysicalVolume()->GetParameterisation()->IsNested();
1139 }
1141 << pPVModel->
GetDrawnPVPath()[i].GetPhysicalVolume()->GetCopyNo();
1143 }
1145
1146
1150 G4Box * pbox =
dynamic_cast<G4Box *
>(pPVModel->
GetDrawnPVPath()[npvp-2].GetPhysicalVolume()->GetLogicalVolume()->GetSolid());
1151 if(pbox) {
1155 G4cout <<
" mother size ["
1156 << pPVModel->
GetDrawnPVPath()[npvp-2].GetPhysicalVolume()->GetName()
1157 << "] : "
1158 << pareDims[0] << " x "
1159 << pareDims[1] << " x "
1160 << pareDims[2] << " [mm3]"
1162 }
1164 G4Box * boxP =
dynamic_cast<G4Box *
>(pPVModel->
GetDrawnPVPath()[npvp-1].GetPhysicalVolume()->GetLogicalVolume()->GetSolid());
1165 if(boxP) {
1169 G4cout <<
" parameterised volume? ["
1170 << pPVModel->
GetDrawnPVPath()[npvp-1].GetPhysicalVolume()->GetName()
1171 << "] : "
1172 << paraDims[0] << " x "
1173 << paraDims[1] << " x "
1174 << paraDims[2] << " [mm3] : "
1175 <<
G4int(pareDims[0]/paraDims[0]) <<
" x "
1176 <<
G4int(pareDims[1]/paraDims[1]) <<
" x "
1178 } else {
1180 <<
" isn't a G4Box." <<
G4endl;
1181 }
1182 }
1183 }
1184
1185
1186 } else if(kFlagParameterization == 1) {
1187
1188
1189 G4PhantomParameterisation * phantomPara
1191 if(phantomPara == NULL) {
1192 G4Exception(
"G4GMocrenFileSceneHandler::AddSolid( const G4Box& box )",
1194 } else {
1195 ;
1196 }
1197
1201 kNestedVolumeDirAxis[0] = 0;
1202 kNestedVolumeDirAxis[1] = 1;
1203 kNestedVolumeDirAxis[2] = 2;
1204
1205
1206 G4int nX = kNestedVolumeDimension[0];
1207 G4int nXY = kNestedVolumeDimension[0]*kNestedVolumeDimension[1];
1208
1209 for(
G4int n0 = 0; n0 < kNestedVolumeDimension[0]; n0++) {
1210 for(
G4int n1 = 0; n1 < kNestedVolumeDimension[1]; n1++) {
1211 for(
G4int n2 = 0; n2 < kNestedVolumeDimension[2]; n2++) {
1212
1213 G4int repNo = n0 + n1*nX + n2*nXY;
1216
1217
1219 idx[kNestedVolumeDirAxis[0]] = n0;
1220 idx[kNestedVolumeDirAxis[1]] = n1;
1221 idx[kNestedVolumeDirAxis[2]] = n2;
1222 Index3D i3d(idx[0],idx[1],idx[2]);
1223 kNestedModality[i3d] = dens;
1224
1226 G4cout <<
" index: " << idx[0] <<
", " << idx[1] <<
", " << idx[2]
1227 <<
" density: " << dens <<
G4endl;
1228
1229 }
1230 }
1231 }
1232
1236
1237
1238 if(!kbSetModalityVoxelSize) {
1242 kgMocrenIO->setVoxelSpacing(spacing);
1243 kVoxelDimension.set(spacing[0], spacing[1], spacing[2]);
1244 kbSetModalityVoxelSize = true;
1245 }
1246 }
1247
1248 }
1249
1250
1251
1252 if(!kFlagProcessedInteractiveScorer) {
1253
1254
1255
1257
1258 if(pScrMan) {
1259 G4ScoringBox * scoringBox
1260 =
dynamic_cast<G4ScoringBox*
>(pScrMan->
FindMesh(volName));
1261
1262 if(scoringBox) {
1263
1264
1265
1268
1269 kNestedVolumeDimension[0] = nVoxels[2];
1270 kNestedVolumeDimension[1] = nVoxels[1];
1271 kNestedVolumeDimension[2] = nVoxels[0];
1272 kNestedVolumeDirAxis[0] = 2;
1273 kNestedVolumeDirAxis[1] = 1;
1274 kNestedVolumeDirAxis[2] = 0;
1275
1276
1277 for(
G4int n0 = 0; n0 < kNestedVolumeDimension[0]; n0++) {
1278 for(
G4int n1 = 0; n1 < kNestedVolumeDimension[1]; n1++) {
1279 for(
G4int n2 = 0; n2 < kNestedVolumeDimension[2]; n2++) {
1280
1282
1284 idx[kNestedVolumeDirAxis[0]] = n0;
1285 idx[kNestedVolumeDirAxis[1]] = n1;
1286 idx[kNestedVolumeDirAxis[2]] = n2;
1287 Index3D i3d(idx[0],idx[1],idx[2]);
1288 kNestedModality[i3d] = dens;
1289
1290 }
1291 }
1292 }
1293
1296 G4cout <<
"Interactive Scorer : size - "
1297 << boxSize.
x()/cm <<
" x "
1298 << boxSize.
y()/cm <<
" x "
1299 << boxSize.
z()/cm <<
" [cm3]" <<
G4endl;
1300 G4cout <<
"Interactive Scorer : # voxels - "
1301 << nVoxels[0] << " x "
1302 << nVoxels[1] << " x "
1304 }
1305 kVolumeSize.
set(boxSize.
x()*2,
1308
1309
1310 if(!kbSetModalityVoxelSize) {
1312 static_cast<G4float>(boxSize.
y()*2/nVoxels[1]),
1313 static_cast<G4float>(boxSize.
z()*2/nVoxels[2])};
1314
1315 kgMocrenIO->setVoxelSpacing(spacing);
1316 kVoxelDimension.set(spacing[0], spacing[1], spacing[2]);
1317 kbSetModalityVoxelSize = true;
1318
1319 }
1320
1321
1323
1324
1327 kVolumeTrans3D = kVolumeTrans3D*sbtranslate;
1328
1329
1335 kVolumeTrans3D = kVolumeTrans3D*sbrotate;
1336 }
1337
1338
1339
1346
1347 kVolumeTrans3D = kVolumeTrans3D*trotY*trotZ;
1348
1349 }
1350 }
1351
1352 kFlagProcessedInteractiveScorer = true;
1353 }
1354
1355
1356 static G4VPhysicalVolume * volPV = NULL;
1359 }
1360
1361
1363 if(!kMessenger.getDrawVolumeGrid()) {
1364
1365 if(kFlagParameterization == 0) {
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384 if(volName == box.
GetName()) {
1385 bAddDet = false;
1386 }
1387
1388 std::vector<G4String>::iterator itr = kNestedVolumeNames.begin();
1389 for(; itr != kNestedVolumeNames.end(); itr++) {
1391 bAddDet = false;
1392 break;
1393 }
1394 }
1395 } else if(kFlagParameterization == 1) {
1396
1397 G4String volDSolidName;
1398 if(volPV) {
1401 }
1402
1403
1404
1405
1406 if(volDSolidName == box.
GetName()) {
1407 bAddDet = false;
1408 }
1409
1410 } else if(kFlagParameterization == 2) {
1411
1412 }
1413
1414 }
1415 if(bAddDet) AddDetector(box);
1416
1417
1418}
G4ThreadLocal T * G4GeomSplitter< T >::offset
HepGeom::Point3D< G4double > G4Point3D
void set(double x, double y, double z)
G4double GetYHalfLength() const
G4Polyhedron * CreatePolyhedron() const override
G4double GetZHalfLength() const
G4double GetXHalfLength() const
std::size_t GetNoDaughters() const
G4VPhysicalVolume * GetDaughter(const std::size_t i) const
G4double GetDensity() const
const G4String & GetName() const
G4Material * ComputeMaterial(const G4int repNo, G4VPhysicalVolume *currentVol, const G4VTouchable *parentTouch=nullptr) override
G4double GetVoxelHalfZ() const
std::size_t GetNoVoxelsX() const
G4double GetVoxelHalfY() const
G4double GetVoxelHalfX() const
std::size_t GetNoVoxelsZ() const
std::size_t GetNoVoxelsY() const
const std::vector< G4PhysicalVolumeNodeID > & GetDrawnPVPath() const
G4VPhysicalVolume * GetTopPhysicalVolume() const
G4Material * GetCurrentMaterial() const
G4int GetCurrentDepth() const
static G4ScoringManager * GetScoringManager()
G4VScoringMesh * FindMesh(G4VHitsCollection *map)
void ComputeTransformation(const G4int no, G4VPhysicalVolume *currentPV) const override=0
void ComputeDimensions(G4Box &, const G4int, const G4VPhysicalVolume *) const override
virtual G4Material * ComputeMaterial(G4VPhysicalVolume *currentVol, const G4int repNo, const G4VTouchable *parentTouch=nullptr)=0
virtual G4bool IsNested() const
virtual G4bool IsReplicated() const =0
virtual G4int GetMultiplicity() const
virtual void GetReplicationData(EAxis &axis, G4int &nReplicas, G4double &width, G4double &offset, G4bool &consuming) const =0
virtual G4int GetCopyNo() const =0
virtual G4VPVParameterisation * GetParameterisation() const =0
G4ThreeVector GetObjectTranslation() const
virtual G4bool IsParameterised() const =0
G4VModel * GetModel() const
G4Transform3D fObjectTransformation
G4ThreeVector GetTranslation() const
G4ThreeVector GetSize() const
void GetNumberOfSegments(G4int nSegment[3])
G4RotationMatrix GetRotationMatrix() const
HepPolyhedron & Transform(const G4Transform3D &t)
G4bool GetNextEdge(G4Point3D &p1, G4Point3D &p2, G4int &edgeFlag) const
const char * name(G4int ptype)