From 704911ae2c6c88f0e0d53e487256876f5ca20259 Mon Sep 17 00:00:00 2001 From: Andre Sailer Date: Wed, 29 May 2024 18:21:30 +0200 Subject: [PATCH 1/2] GeoHandler: store TGeoVolumes in deterministic order --- DDCore/include/DD4hep/GeoHandler.h | 3 ++- DDCore/src/GeoHandler.cpp | 4 +++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/DDCore/include/DD4hep/GeoHandler.h b/DDCore/include/DD4hep/GeoHandler.h index 6abb8fd91..b138d2547 100644 --- a/DDCore/include/DD4hep/GeoHandler.h +++ b/DDCore/include/DD4hep/GeoHandler.h @@ -59,7 +59,8 @@ namespace dd4hep { */ class GeometryInfo { public: - std::set solids; + std::vector solids; + std::set solid_set; std::set volumeSet; std::vector volumes; std::set vis; diff --git a/DDCore/src/GeoHandler.cpp b/DDCore/src/GeoHandler.cpp index 38a10f5f6..8cd4fee14 100644 --- a/DDCore/src/GeoHandler.cpp +++ b/DDCore/src/GeoHandler.cpp @@ -44,7 +44,9 @@ namespace { collectSolid(geo, name + "_left", name + "_left", boolean->GetLeftShape(), boolean->GetLeftMatrix()); collectSolid(geo, name + "_right", name + "_right", boolean->GetRightShape(), boolean->GetRightMatrix()); } - geo.solids.emplace(shape); + if(geo.solid_set.emplace(shape).second) { + geo.solids.push_back(shape); + } geo.trafos.emplace_back(node, matrix); } } From d5238cec0226e5d525c8ec0528a1c0a864ed309e Mon Sep 17 00:00:00 2001 From: Andre Sailer Date: Thu, 30 May 2024 18:24:05 +0200 Subject: [PATCH 2/2] GeoHandler: make collect give deterministic volume order --- DDCore/include/DD4hep/GeoHandler.h | 8 ++++---- DDCore/src/GeoHandler.cpp | 14 +++++++++----- DDG4/src/Geant4Converter.cpp | 2 +- 3 files changed, 14 insertions(+), 10 deletions(-) diff --git a/DDCore/include/DD4hep/GeoHandler.h b/DDCore/include/DD4hep/GeoHandler.h index b138d2547..31d507f17 100644 --- a/DDCore/include/DD4hep/GeoHandler.h +++ b/DDCore/include/DD4hep/GeoHandler.h @@ -88,7 +88,7 @@ namespace dd4hep { protected: bool m_propagateRegions { false }; - std::map >* m_data { nullptr }; + std::map >* m_data { nullptr }; std::map >* m_daughters { nullptr }; /// Internal helper to collect geometry information from traversal GeoHandler& i_collect(const TGeoNode* parent, @@ -108,7 +108,7 @@ namespace dd4hep { /// Default constructor GeoHandler(); /// Initializing constructor - GeoHandler(std::map >* ptr, + GeoHandler(std::map >* ptr, std::map >* daus = nullptr); /// Default destructor virtual ~GeoHandler(); @@ -119,7 +119,7 @@ namespace dd4hep { /// Collect geometry information from traversal with aggregated information GeoHandler& collect(DetElement top, GeometryInfo& info); /// Access to collected node list - std::map >* release(); + std::map >* release(); }; /// Geometry scanner (handle object) @@ -131,7 +131,7 @@ namespace dd4hep { class GeoScan { protected: /// Data holder - std::map >* m_data; + std::map >* m_data; public: /// Initializing constructor GeoScan(DetElement e); diff --git a/DDCore/src/GeoHandler.cpp b/DDCore/src/GeoHandler.cpp index 8cd4fee14..ca443d062 100644 --- a/DDCore/src/GeoHandler.cpp +++ b/DDCore/src/GeoHandler.cpp @@ -23,6 +23,7 @@ #include // C/C++ include files +#include #include using namespace dd4hep; @@ -53,11 +54,11 @@ namespace { /// Default constructor detail::GeoHandler::GeoHandler() { - m_data = new std::map >(); + m_data = new std::map >(); } /// Initializing constructor -detail::GeoHandler::GeoHandler(std::map >* ptr, +detail::GeoHandler::GeoHandler(std::map >* ptr, std::map >* daus) : m_data(ptr), m_daughters(daus) { @@ -70,8 +71,8 @@ detail::GeoHandler::~GeoHandler() { m_data = nullptr; } -std::map >* detail::GeoHandler::release() { - std::map >* d = m_data; +std::map >* detail::GeoHandler::release() { + std::map >* d = m_data; m_data = nullptr; return d; } @@ -149,7 +150,10 @@ detail::GeoHandler& detail::GeoHandler::i_collect(const TGeoNode* /* parent */, } } /// Collect the hierarchy of placements - (*m_data)[level].emplace(current); + auto& vec = (*m_data)[level]; + if(std::find(vec.begin(), vec.end(), current) == vec.end()) { + (*m_data)[level].push_back(current); + } int num = nodes ? nodes->GetEntriesFast() : 0; for (int i = 0; i < num; ++i) i_collect(current, (TGeoNode*)nodes->At(i), level + 1, region, limits); diff --git a/DDG4/src/Geant4Converter.cpp b/DDG4/src/Geant4Converter.cpp index f62e8c25f..4ca3bd57e 100644 --- a/DDG4/src/Geant4Converter.cpp +++ b/DDG4/src/Geant4Converter.cpp @@ -1689,7 +1689,7 @@ Geant4Converter& Geant4Converter::create(DetElement top) { handleRMap(this, *m_data, &Geant4Converter::handleAssembly); // Now place all this stuff appropriately //handleRMap(this, *m_data, &Geant4Converter::handlePlacement); - std::map >::const_reverse_iterator i = m_data->rbegin(); + std::map >::const_reverse_iterator i = m_data->rbegin(); for ( ; i != m_data->rend(); ++i ) { for ( const TGeoNode* node : i->second ) { #if 0