File indexing completed on 2025-11-05 08:53:43
0001
0002
0003
0004
0005
0006
0007
0008
0009 #pragma once
0010
0011 #include "Acts/Definitions/Algebra.hpp"
0012 #include "Acts/Geometry/GeometryContext.hpp"
0013 #include "Acts/Geometry/ITrackingVolumeArrayCreator.hpp"
0014 #include "Acts/Utilities/AxisDefinitions.hpp"
0015 #include "Acts/Utilities/Logger.hpp"
0016
0017 #include <memory>
0018 #include <utility>
0019
0020 namespace Acts {
0021
0022
0023
0024 using TrackingVolumeOrderPosition = std::pair<TrackingVolumePtr, Vector3>;
0025
0026
0027
0028
0029
0030
0031
0032 class TrackingVolumeArrayCreator : public ITrackingVolumeArrayCreator {
0033 public:
0034
0035 struct Config {};
0036
0037
0038
0039
0040 explicit TrackingVolumeArrayCreator(const Config& ,
0041 std::unique_ptr<const Logger> logger =
0042 getDefaultLogger("LayerArrayCreator",
0043 Logging::INFO))
0044 : m_logger(std::move(logger)) {}
0045
0046
0047
0048
0049
0050
0051
0052
0053 std::shared_ptr<const TrackingVolumeArray> trackingVolumeArray(
0054 const GeometryContext& gctx, const TrackingVolumeVector& tVolumes,
0055 AxisDirection aDir) const override;
0056
0057
0058
0059
0060 void setLogger(std::unique_ptr<const Logger> logger) {
0061 m_logger = std::move(logger);
0062 }
0063
0064 private:
0065
0066 const Logger& logger() const { return *m_logger; }
0067
0068
0069 std::unique_ptr<const Logger> m_logger;
0070 };
0071 }