File indexing completed on 2025-12-11 09:40:21
0001
0002
0003
0004
0005
0006
0007
0008
0009 #pragma once
0010
0011 #include "Acts/Definitions/Units.hpp"
0012 #include "Acts/Geometry/Extent.hpp"
0013 #include "Acts/Utilities/AxisDefinitions.hpp"
0014 #include "Acts/Utilities/BinningData.hpp"
0015 #include "Acts/Utilities/ProtoAxis.hpp"
0016 #include "ActsPlugins/DD4hep/DD4hepConversionHelpers.hpp"
0017
0018 #include <optional>
0019 #include <sstream>
0020 #include <string>
0021 #include <tuple>
0022 #include <vector>
0023
0024 #include <DDRec/DetectorData.h>
0025
0026 namespace ActsPlugins {
0027
0028 static const std::vector<std::tuple<std::string, Acts::AxisDirection>>
0029 allowedBinnings = {{"x", Acts::AxisDirection::AxisX},
0030 {"y", Acts::AxisDirection::AxisY},
0031 {"z", Acts::AxisDirection::AxisZ},
0032 {"phi", Acts::AxisDirection::AxisPhi},
0033 {"r", Acts::AxisDirection::AxisR}};
0034
0035
0036
0037
0038
0039
0040 inline Acts::AxisDirection stringToAxisDirection(
0041 const std::string &binningString) {
0042 using enum Acts::AxisDirection;
0043 if (binningString == "x") {
0044 return AxisX;
0045 } else if (binningString == "y") {
0046 return AxisY;
0047 } else if (binningString == "z") {
0048 return AxisZ;
0049 } else if (binningString == "phi") {
0050 return AxisPhi;
0051 } else if (binningString == "r") {
0052 return AxisR;
0053 } else {
0054 throw std::invalid_argument("DD4hepBinningHelpers: Binning value " +
0055 binningString + " not allowed.");
0056 }
0057 }
0058
0059
0060
0061
0062
0063
0064
0065
0066 inline std::vector<Acts::AxisDirection> stringToAxisDirections(
0067 const std::string &binningString, const char &del = ',') {
0068 if (binningString.empty()) {
0069 return {};
0070 }
0071 std::vector<Acts::AxisDirection> bBinning;
0072 std::stringstream s(binningString);
0073 std::string b = "";
0074 while (getline(s, b, del)) {
0075 bBinning.push_back(stringToAxisDirection(b));
0076 }
0077 return bBinning;
0078 }
0079
0080 namespace DD4hepBinningHelpers {
0081
0082
0083
0084
0085
0086
0087
0088 std::vector<std::tuple<Acts::DirectedProtoAxis, std::size_t>> convertBinning(
0089 const dd4hep::DetElement &dd4hepElement, const std::string &bname);
0090
0091 }
0092 }