File indexing completed on 2025-10-31 08:17:29
0001 
0002 
0003 
0004 
0005 
0006 
0007 
0008 
0009 #include "ActsPlugins/DD4hep/DD4hepFieldAdapter.hpp"
0010 
0011 #include "Acts/Definitions/Algebra.hpp"
0012 #include "Acts/Definitions/Units.hpp"
0013 #include "Acts/MagneticField/MagneticFieldContext.hpp"
0014 #include "Acts/MagneticField/MagneticFieldProvider.hpp"
0015 
0016 #include <DD4hep/Fields.h>
0017 #include <DD4hep/Handle.h>
0018 #include <DD4hep/Objects.h>
0019 
0020 using namespace Acts;
0021 
0022 namespace ActsPlugins {
0023 
0024 DD4hepFieldAdapter::DD4hepFieldAdapter(dd4hep::OverlayedField field)
0025     : m_field{std::make_unique<dd4hep::OverlayedField>(field)} {
0026   m_fieldConversionFactor = dd4hep::_toDouble("1/tesla") * UnitConstants::T;
0027   m_lengthConversionFactor = dd4hep::_toDouble("1*mm") / UnitConstants::mm;
0028 }
0029 
0030 MagneticFieldProvider::Cache DD4hepFieldAdapter::makeCache(
0031     const MagneticFieldContext& ) const {
0032   return MagneticFieldProvider::Cache{};
0033 }
0034 
0035 Result<Vector3> DD4hepFieldAdapter::getField(
0036     const Vector3& position, MagneticFieldProvider::Cache& ) const {
0037   dd4hep::Position dd4hepPosition{position.x(), position.y(), position.z()};
0038 
0039   
0040   dd4hepPosition *= m_lengthConversionFactor;
0041 
0042   const auto direction = m_field->combinedMagnetic(dd4hepPosition);
0043 
0044   Vector3 result{direction.x(), direction.y(), direction.z()};
0045 
0046   
0047   result *= m_fieldConversionFactor;
0048 
0049   return Result<Vector3>::success(result);
0050 }
0051 
0052 }