File indexing completed on 2025-04-04 07:57:29
0001
0002
0003
0004
0005
0006
0007
0008
0009 #pragma once
0010
0011 #include "Acts/Definitions/Algebra.hpp"
0012 #include "Acts/Geometry/CuboidVolumeBounds.hpp"
0013 #include "Acts/Geometry/PortalShell.hpp"
0014 #include "Acts/Geometry/TrackingVolume.hpp"
0015 #include "Acts/Utilities/AxisDefinitions.hpp"
0016 #include "Acts/Utilities/Logger.hpp"
0017
0018 #include <array>
0019 #include <memory>
0020 #include <vector>
0021
0022 namespace Acts {
0023
0024
0025
0026
0027 class CuboidPortalShell : public PortalShellBase {
0028 public:
0029 using Face = CuboidVolumeBounds::Face;
0030
0031
0032
0033
0034 virtual Portal* portal(Face face) = 0;
0035
0036
0037
0038
0039
0040 virtual std::shared_ptr<Portal> portalPtr(Face face) = 0;
0041
0042
0043
0044
0045 virtual void setPortal(std::shared_ptr<Portal> portal, Face face) = 0;
0046
0047
0048 void fill(TrackingVolume& volume) override;
0049
0050 virtual const Transform3& transform() const = 0;
0051 };
0052
0053
0054
0055
0056
0057 std::ostream& operator<<(std::ostream& os, CuboidPortalShell::Face face);
0058
0059
0060
0061 class SingleCuboidPortalShell : public CuboidPortalShell {
0062 public:
0063
0064
0065 explicit SingleCuboidPortalShell(TrackingVolume& volume);
0066
0067
0068 std::size_t size() const final;
0069
0070
0071 Portal* portal(Face face) final;
0072
0073
0074 std::shared_ptr<Portal> portalPtr(Face face) final;
0075
0076
0077 void setPortal(std::shared_ptr<Portal> portal, Face face) final;
0078
0079
0080 void applyToVolume() override;
0081
0082
0083 bool isValid() const override;
0084
0085
0086 std::string label() const override;
0087
0088 const Transform3& transform() const override {
0089 return m_volume->transform();
0090 };
0091
0092 private:
0093 std::array<std::shared_ptr<Portal>, 6> m_portals{};
0094
0095 TrackingVolume* m_volume;
0096 };
0097
0098
0099
0100 class CuboidStackPortalShell final : public CuboidPortalShell {
0101 public:
0102
0103
0104
0105
0106
0107
0108 CuboidStackPortalShell(const GeometryContext& gctx,
0109 std::vector<CuboidPortalShell*> shells,
0110 AxisDirection direction,
0111 const Logger& logger = getDummyLogger());
0112
0113
0114 std::size_t size() const override;
0115
0116
0117 Portal* portal(Face face) override;
0118
0119
0120 std::shared_ptr<Portal> portalPtr(Face face) override;
0121
0122
0123 void setPortal(std::shared_ptr<Portal> portal, Face face) override;
0124
0125 void applyToVolume() override {
0126
0127 }
0128
0129
0130 bool isValid() const override;
0131
0132
0133 std::string label() const override;
0134
0135
0136 const Transform3& transform() const override;
0137
0138 private:
0139
0140 AxisDirection m_direction;
0141
0142
0143 CuboidVolumeBounds::Face m_frontFace = Face::NegativeXFace;
0144
0145 CuboidVolumeBounds::Face m_backFace = Face::PositiveXFace;
0146
0147 std::array<CuboidVolumeBounds::Face, 4> m_sideFaces{
0148 Face::NegativeZFace, Face::PositiveZFace, Face::NegativeYFace,
0149 Face::PositiveYFace};
0150
0151 std::vector<CuboidPortalShell*> m_shells;
0152 };
0153
0154 }