1272 {
1273
1276
1278 if (!pScene) {
1280 G4warn <<
"ERROR: No current scene. Please create one." <<
G4endl;
1281 }
1282 return;
1283 }
1284
1287 std::istringstream is (newValue);
1288 is >>
name >> copyNo;
1289
1290 std::vector<G4PhysicalVolumesSearchScene::Findings> findingsVector;
1291
1292
1293 G4TransportationManager* transportationManager =
1295 std::vector<G4VPhysicalVolume*>::iterator iterWorld =
1297 size_t nWorlds = transportationManager->
GetNoWorlds();
1298 for (size_t i = 0; i < nWorlds; ++i, ++iterWorld) {
1299 G4ModelingParameters mp;
1300 G4PhysicalVolumeModel searchModel
1301 (*iterWorld,
1304 &mp,
1305 true);
1306 G4PhysicalVolumesSearchScene searchScene
1307 (&searchModel, name, copyNo);
1308 searchModel.DescribeYourselfTo (searchScene);
1309 for (const auto& findings: searchScene.GetFindings()) {
1310 findingsVector.push_back(findings);
1311 }
1312 }
1313
1315 for (const auto& findings: findingsVector) {
1316
1317
1318 const auto& extent = findings.fpFoundPV->GetLogicalVolume()->GetSolid()->GetExtent();
1319 const auto& transform = findings.fFoundObjectTransformation;
1320
1321 const G4double lengthMax = extent.GetExtentRadius()/2.;
1322 const G4double intLog10LengthMax = std::floor(std::log10(lengthMax));
1323 G4double length = std::pow(10,intLog10LengthMax);
1324 if (5.*length < lengthMax) length *= 5.;
1325 else if (2.*length < lengthMax) length *= 2.;
1326
1327 const auto& axesModel = new G4AxesModel(0.,0.,0.,length,transform);
1328 axesModel->SetGlobalTag("LocalAxesModel");
1329 std::ostringstream oss; oss
1330 << "Local Axes for " << findings.fpFoundPV->GetName()
1331 << ':' << findings.fFoundPVCopyNo << ':' << id++;
1332 axesModel->SetGlobalDescription(oss.str());
1333
1335 if (successful) {
1337 G4cout <<
"\"" << findings.fpFoundPV->GetName()
1338 << "\", copy no. " << findings.fFoundPVCopyNo
1339 << ",\n found in searched volume \""
1340 << findings.fpSearchPV->GetName()
1341 << "\" at depth " << findings.fFoundDepth
1342 << ",\n base path: \"" << findings.fFoundBasePVPath
1343 << "\".\n Local axes have been added to scene \""
1344 << pScene->
GetName() <<
"\".";
1346 G4cout <<
" With extent " << extent
1347 << "\n at " << transform.getRotation()
1348 << " " << transform.getTranslation();
1349 }
1351 }
1352 } else {
1354 }
1355 }
1356
1357 if (findingsVector.empty()) {
1359 G4warn <<
"ERROR: Volume \"" <<
name <<
"\"";
1360 if (copyNo >= 0) {
1361 G4warn <<
", copy no. " << copyNo <<
",";
1362 }
1364 }
1366 return;
1367 }
1368
1370}
G4GLOB_DLL std::ostream G4cout
G4bool AddRunDurationModel(G4VModel *, G4bool warn=false)
const G4String & GetName() const
static G4TransportationManager * GetTransportationManager()
std::vector< G4VPhysicalVolume * >::iterator GetWorldsIterator()
std::size_t GetNoWorlds() const
void G4VisCommandsSceneAddUnsuccessful(G4VisManager::Verbosity verbosity)
void CheckSceneAndNotifyHandlers(G4Scene *=nullptr)
static G4VisManager * fpVisManager
const char * name(G4int ptype)