19#include "BDSColours.hh"
20#include "BDSColourFromMaterial.hh"
21#include "BDSGeometryExternal.hh"
22#include "BDSGeometryFactoryBase.hh"
23#include "BDSGlobalConstants.hh"
24#include "BDSSDType.hh"
25#include "BDSUtilities.hh"
28#include "G4AssemblyVolume.hh"
30#include "G4LogicalVolume.hh"
31#include "G4RotationMatrix.hh"
33#include "G4VisAttributes.hh"
34#include "G4VPhysicalVolume.hh"
41BDSGeometryFactoryBase::BDSGeometryFactoryBase()
46BDSGeometryFactoryBase::~BDSGeometryFactoryBase()
50 std::map<G4String, G4Colour*>* mapping,
52 const G4String& prefixToStripFromName)
54 std::set<G4VisAttributes*> visAttributes;
57 if (!mapping && !autoColour)
58 {
return visAttributes;}
62 if (mapping->size() == 1)
65 vis->SetVisibility(
true);
66 visAttributes.insert(vis);
68 {lv->SetVisAttributes(*vis);}
74 std::map<G4String, G4VisAttributes*> attMap;
75 for (
const auto& it : *mapping)
77 G4VisAttributes* vis =
new G4VisAttributes(*(it.second));
78 vis->SetVisibility(
true);
79 visAttributes.insert(vis);
80 attMap[it.first] = vis;
85 const G4String& name = lv->GetName();
86 for (
const auto& it : attMap)
90 lv->SetVisAttributes(it.second);
101 const G4VisAttributes* existingVis = lv->GetVisAttributes();
105 G4VisAttributes* vis =
new G4VisAttributes(*c);
106 vis->SetVisibility(
true);
107 visAttributes.insert(vis);
108 lv->SetVisAttributes(vis);
113 return visAttributes;
117 G4UserLimits* userLimits)
119 for (
auto& lv : lvsIn)
120 {lv->SetUserLimits(userLimits);}
124 const std::set<G4LogicalVolume*>& allLogicalVolumesIn,
126 const std::set<G4LogicalVolume*>& vacuumLogicalVolumes,
129 std::map<G4LogicalVolume*, BDSSDType> sensitivityMapping;
130 std::set<G4LogicalVolume*> notVacuumVolumes;
131 std::set_difference(allLogicalVolumesIn.begin(),
132 allLogicalVolumesIn.end(),
133 vacuumLogicalVolumes.begin(),
134 vacuumLogicalVolumes.end(),
135 std::inserter(notVacuumVolumes, notVacuumVolumes.begin()));
136 for (
auto lv : notVacuumVolumes)
137 {sensitivityMapping[lv] = generalSensitivity;}
138 for (
auto lv : vacuumLogicalVolumes)
139 {sensitivityMapping[lv] = vacuumSensitivity;}
149 const G4String& )
const
153 std::vector<G4String>* volumeNames,
154 G4bool preprocessFile,
155 const G4String& componentName)
const
158 {
return std::set<G4LogicalVolume*>();}
160 std::vector<G4String> expectedVolumeNames;
164 expectedVolumeNames.resize(volumeNames->size());
165 std::transform(volumeNames->begin(),
167 expectedVolumeNames.begin(),
168 [&](
const G4String& n){return PreprocessedName(n, componentName);});
171 {expectedVolumeNames = *volumeNames;}
173 std::set<G4LogicalVolume*> volsMatched;
174 for (
const auto& en : expectedVolumeNames)
176 for (
auto lv : allLVs)
178 if (lv->GetName() == en)
179 {volsMatched.insert(lv);}
207 G4double y0, G4double ry,
208 G4double z0, G4double rz)
219 G4double y0, G4double yLow, G4double yHigh,
220 G4double z0, G4double zLow, G4double zHigh)
static BDSColourFromMaterial * Instance()
Singleton pattern.
G4Colour * GetColour(const G4Material *material, const G4String &prefixToStripFromName="")
Get colour from name.
static BDSColours * Instance()
singleton pattern
Holder for +- extents in 3 dimensions.
G4double XPos() const
Accessor.
G4double ZPos() const
Accessor.
G4double XNeg() const
Accessor.
G4double YNeg() const
Accessor.
G4double YPos() const
Accessor.
G4double ZNeg() const
Accessor.
virtual void FactoryBaseCleanUp()
Empty containers for next use - factories are never deleted so can't rely on scope.
void RegisterSensitiveVolume(G4LogicalVolume *sensitiveVolume, BDSSDType sensitivityType)
A loaded piece of externally provided geometry.
G4double ymax
Extent in one dimension.
virtual void ApplySensitivity(BDSGeometryExternal *result, const std::set< G4LogicalVolume * > &allLogicalVolumesIn, BDSSDType generalSensitivity, const std::set< G4LogicalVolume * > &vacuumLogicalVolumes, BDSSDType vacuumSensitivity)
Attach the relevant general and vacuum sensitivity to each volume.
void ExpandExtent(const BDSExtent &extent)
Expand the acuumulated extents using a (possibly asymmetric) extent instance.
virtual G4String PreprocessedName(const G4String &objectName, const G4String &acceleratorComponentName) const
std::set< G4LogicalVolume * > GetVolumes(const std::set< G4LogicalVolume * > &allLVs, std::vector< G4String > *volumeNames, G4bool preprocessGDML, const G4String &componentName) const
Get the volumes that match the name. Volume names are matched exactly and are case sensitive.
virtual void CleanUp()
Virtual clean up that derived classes can override that calls CleanUpBase().
G4double xmin
Extent in one dimension.
G4double ymin
Extent in one dimension.
G4double zmin
Extent in one dimension.
G4double zmax
Extent in one dimension.
G4double xmax
Extent in one dimension.
virtual void ApplyUserLimits(const std::set< G4LogicalVolume * > &lvsIn, G4UserLimits *userLimits)
Attach a set of user limits to every logical volume supplied.
virtual std::set< G4VisAttributes * > ApplyColourMapping(std::set< G4LogicalVolume * > &lvs, std::map< G4String, G4Colour * > *mapping, G4bool autoColour, const G4String &preprocessPrefix="")
Improve type-safety of native enum data type in C++.
G4bool StrContains(const G4String &str, const G4String &test)
Utility function to simplify lots of syntax changes for pedantic g4 changes.