File indexing completed on 2025-10-24 08:20:24
0001
0002
0003
0004
0005
0006
0007
0008
0009 #include <boost/test/unit_test.hpp>
0010
0011 #include "Acts/Definitions/Units.hpp"
0012 #include "Acts/Geometry/CylinderVolumeBuilder.hpp"
0013 #include "Acts/Geometry/CylinderVolumeHelper.hpp"
0014 #include "Acts/Geometry/GeometryContext.hpp"
0015 #include "Acts/Geometry/LayerArrayCreator.hpp"
0016 #include "Acts/Geometry/LayerCreator.hpp"
0017 #include "Acts/Geometry/PassiveLayerBuilder.hpp"
0018 #include "Acts/Geometry/SurfaceArrayCreator.hpp"
0019 #include "Acts/Geometry/TrackingGeometry.hpp"
0020 #include "Acts/Geometry/TrackingGeometryBuilder.hpp"
0021 #include "Acts/Geometry/TrackingVolumeArrayCreator.hpp"
0022 #include "Acts/Utilities/Logger.hpp"
0023
0024 #include <functional>
0025 #include <memory>
0026 #include <string>
0027 #include <utility>
0028 #include <vector>
0029
0030 using namespace Acts;
0031 using namespace Acts::UnitLiterals;
0032
0033 namespace ActsTests {
0034
0035
0036 GeometryContext tgContext = GeometryContext();
0037
0038 BOOST_AUTO_TEST_SUITE(GeometrySuite)
0039
0040
0041
0042
0043 BOOST_AUTO_TEST_CASE(SimpleGeometryTest) {
0044 Logging::Level surfaceLLevel = Logging::INFO;
0045 Logging::Level layerLLevel = Logging::INFO;
0046 Logging::Level volumeLLevel = Logging::INFO;
0047
0048
0049 SurfaceArrayCreator::Config sacConfig;
0050 auto surfaceArrayCreator = std::make_shared<const SurfaceArrayCreator>(
0051 sacConfig, getDefaultLogger("SurfaceArrayCreator", surfaceLLevel));
0052
0053 LayerCreator::Config lcConfig;
0054 lcConfig.surfaceArrayCreator = surfaceArrayCreator;
0055 auto layerCreator = std::make_shared<const LayerCreator>(
0056 lcConfig, getDefaultLogger("LayerCreator", layerLLevel));
0057
0058 LayerArrayCreator::Config lacConfig;
0059 auto layerArrayCreator = std::make_shared<const LayerArrayCreator>(
0060 lacConfig, getDefaultLogger("LayerArrayCreator", layerLLevel));
0061
0062
0063 TrackingVolumeArrayCreator::Config tvacConfig;
0064 auto tVolumeArrayCreator = std::make_shared<const TrackingVolumeArrayCreator>(
0065 tvacConfig, getDefaultLogger("TrackingVolumeArrayCreator", volumeLLevel));
0066
0067 CylinderVolumeHelper::Config cvhConfig;
0068 cvhConfig.layerArrayCreator = layerArrayCreator;
0069 cvhConfig.trackingVolumeArrayCreator = tVolumeArrayCreator;
0070 auto cylinderVolumeHelper = std::make_shared<const CylinderVolumeHelper>(
0071 cvhConfig, getDefaultLogger("CylinderVolumeHelper", volumeLLevel));
0072
0073
0074 PassiveLayerBuilder::Config bplConfig;
0075 bplConfig.layerIdentification = "BeamPipe";
0076 bplConfig.centralLayerRadii = std::vector<double>(1, 3_mm);
0077 bplConfig.centralLayerHalflengthZ = std::vector<double>(1, 40_mm);
0078 bplConfig.centralLayerThickness = std::vector<double>(1, 0.8_mm);
0079 auto beamPipeBuilder = std::make_shared<const PassiveLayerBuilder>(
0080 bplConfig, getDefaultLogger("BeamPipeLayerBuilder", layerLLevel));
0081
0082 CylinderVolumeBuilder::Config bpvConfig;
0083 bpvConfig.trackingVolumeHelper = cylinderVolumeHelper;
0084 bpvConfig.volumeName = "BeamPipe";
0085 bpvConfig.layerBuilder = beamPipeBuilder;
0086 bpvConfig.layerEnvelopeR = {1_mm, 1_mm};
0087 bpvConfig.buildToRadiusZero = true;
0088 auto beamPipeVolumeBuilder = std::make_shared<const CylinderVolumeBuilder>(
0089 bpvConfig, getDefaultLogger("BeamPipeVolumeBuilder", volumeLLevel));
0090
0091 PassiveLayerBuilder::Config layerBuilderConfig;
0092 layerBuilderConfig.layerIdentification = "CentralBarrel";
0093 layerBuilderConfig.centralLayerRadii = {10_mm, 20_mm, 30_mm};
0094 layerBuilderConfig.centralLayerHalflengthZ = {40_mm, 40_mm, 40_mm};
0095 layerBuilderConfig.centralLayerThickness = {1_mm, 1_mm, 1_mm};
0096 auto layerBuilder = std::make_shared<const PassiveLayerBuilder>(
0097 layerBuilderConfig,
0098 getDefaultLogger("CentralBarrelBuilder", layerLLevel));
0099
0100 CylinderVolumeBuilder::Config cvbConfig;
0101 cvbConfig.trackingVolumeHelper = cylinderVolumeHelper;
0102 cvbConfig.volumeName = "CentralBarrel";
0103 cvbConfig.layerBuilder = layerBuilder;
0104 cvbConfig.layerEnvelopeR = {1_mm, 1_mm};
0105 cvbConfig.buildToRadiusZero = false;
0106 auto centralVolumeBuilder = std::make_shared<const CylinderVolumeBuilder>(
0107 cvbConfig, getDefaultLogger("CentralVolumeBuilder", volumeLLevel));
0108
0109
0110 TrackingGeometryBuilder::Config tgbConfig;
0111 tgbConfig.trackingVolumeBuilders.push_back(
0112 [=](const auto& context, const auto& inner, const auto&) {
0113 return beamPipeVolumeBuilder->trackingVolume(context, inner);
0114 });
0115 tgbConfig.trackingVolumeBuilders.push_back(
0116 [=](const auto& context, const auto& inner, const auto&) {
0117 return centralVolumeBuilder->trackingVolume(context, inner);
0118 });
0119 tgbConfig.trackingVolumeHelper = cylinderVolumeHelper;
0120
0121 TrackingGeometryBuilder tgBuilder(tgbConfig);
0122 auto tGeometry = tgBuilder.trackingGeometry(tgContext);
0123
0124 BOOST_CHECK(tGeometry != nullptr);
0125 }
0126
0127 BOOST_AUTO_TEST_SUITE_END()
0128
0129 }