File indexing completed on 2025-07-01 08:07:51
0001
0002
0003
0004
0005
0006
0007
0008
0009 #pragma once
0010
0011 #include "Acts/Definitions/Algebra.hpp"
0012 #include "Acts/Definitions/Common.hpp"
0013 #include "Acts/Plugins/Geant4/Geant4PhysicalVolumeSelectors.hpp"
0014 #include "Acts/Surfaces/Surface.hpp"
0015
0016 #include <cstddef>
0017 #include <memory>
0018 #include <tuple>
0019 #include <vector>
0020
0021 namespace HepGeom {
0022 class Transform3D;
0023 }
0024
0025 class G4VPhysicalVolume;
0026 using G4Transform3D = HepGeom::Transform3D;
0027
0028 namespace Acts {
0029
0030 class Geant4DetectorElement;
0031 class IGeant4PhysicalVolumeSelector;
0032 class Surface;
0033
0034
0035
0036
0037 class Geant4DetectorSurfaceFactory {
0038 public:
0039
0040
0041 struct Config {};
0042
0043
0044 using Geant4SensitiveSurface =
0045 std::tuple<std::shared_ptr<Geant4DetectorElement>,
0046 std::shared_ptr<Surface>>;
0047
0048
0049 using Geant4PassiveSurface = std::shared_ptr<Surface>;
0050
0051
0052 struct Cache {
0053
0054 std::vector<Geant4SensitiveSurface> sensitiveSurfaces;
0055
0056 std::vector<Geant4PassiveSurface> passiveSurfaces;
0057
0058 std::size_t matchedG4Volumes = 0;
0059
0060 std::size_t convertedSurfaces = 0;
0061
0062 std::size_t convertedMaterials = 0;
0063 };
0064
0065
0066 struct Options {
0067
0068 ActsScalar scaleConversion = 1.;
0069
0070 bool convertMaterial = true;
0071
0072 ActsScalar convertedMaterialThickness = -1;
0073
0074 std::shared_ptr<IGeant4PhysicalVolumeSelector> sensitiveSurfaceSelector =
0075 nullptr;
0076
0077 std::shared_ptr<IGeant4PhysicalVolumeSelector> passiveSurfaceSelector =
0078 nullptr;
0079 };
0080
0081
0082 Geant4DetectorSurfaceFactory() = default;
0083
0084
0085
0086
0087
0088
0089
0090
0091 void construct(Cache& cache, const G4Transform3D& g4ToGlobal,
0092 const G4VPhysicalVolume& g4PhysVol, const Options& option);
0093 };
0094 }