ATLAS Offline Software
Loading...
Searching...
No Matches
TransformCache.icc
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
3*/
4#ifndef ActsGeoUtils_TransformCache_ICC
5#define ActsGeoUtils_TransformCache_ICC
6
7#include <CxxUtils/inline_hints.h>
8
9namespace ActsTrk {
10 ATH_FLATTEN
11 inline const Amg::Transform3D&
12 TransformCacheBase::getTransform(const ActsTrk::DetectorAlignStore* alignStore) const {
13 /// Valid alignment store is given -> Take the transformation from the cache there
14 if (alignStore) {
15 const Amg::Transform3D* cache = alignStore->trackingAlignment->getTransform(m_clientNo);
16 if (cache) {
17 return *cache;
18 }
19 const Amg::Transform3D& trf{alignStore->trackingAlignment->setTransform(m_clientNo, fetchTransform(alignStore))};
20 /// If an external alignment store is presented release the nominal transformation
21 releaseNominalCache();
22 return trf;
23 }
24 /// Fall back solution to go onto the nominal cache
25 if (!m_nomCache) {
26 m_nomCache.set(std::make_unique<Amg::Transform3D>(fetchTransform(alignStore)));
27 }
28 return (*m_nomCache);
29 }
30 inline IdentifierHash TransformCacheBase::hash() const { return m_hash; }
31#ifndef SIMULATIONBASE
32 ATH_FLATTEN
33 inline const Amg::Transform3D& TransformCacheBase::getTransform(const Acts::GeometryContext& anygctx) const {
34 const GeometryContext* gctx = anygctx.get<const GeometryContext*>();
35 // unpack the alignment store from the context
36 return getTransform(gctx->getStore(m_type).get());
37
38 }
39#endif
40
41
42template<typename CachingDetectorEle>
43 TransformCacheDetEle<CachingDetectorEle>::TransformCacheDetEle(const IdentifierHash& hash,
44 const CachingDetectorEle* parentEle):
45 TransformCache{hash, parentEle->detectorType()},
46 m_parent{parentEle} {}
47template<typename CachingDetectorEle>
48 const IDetectorElement* TransformCacheDetEle<CachingDetectorEle>::parent() const {
49 return m_parent;
50 }
51template <typename CachingDetectorEle>
52 Identifier TransformCacheDetEle<CachingDetectorEle>::identify() const {
53 return parent()->identify();
54 }
55}
56#endif