File indexing completed on 2025-10-26 08:51:57
0001 
0002 
0003 
0004 
0005 
0006 
0007 #pragma once
0008 
0009 #include "geocel/Types.hh"
0010 #include "orange/transform/Transformation.hh"
0011 
0012 #include "../SurfaceFwd.hh"
0013 
0014 namespace celeritas
0015 {
0016 namespace detail
0017 {
0018 
0019 
0020 
0021 
0022 
0023 
0024 
0025 class SurfaceTransformer
0026 {
0027   public:
0028     
0029     explicit SurfaceTransformer(Transformation const& trans) : tr_{trans} {}
0030 
0031     
0032 
0033     template<Axis T>
0034     Plane operator()(PlaneAligned<T> const&) const;
0035 
0036     template<Axis T>
0037     GeneralQuadric operator()(CylCentered<T> const&) const;
0038 
0039     Sphere operator()(SphereCentered const&) const;
0040 
0041     template<Axis T>
0042     GeneralQuadric operator()(CylAligned<T> const&) const;
0043 
0044     Plane operator()(Plane const&) const;
0045 
0046     Sphere operator()(Sphere const&) const;
0047 
0048     template<Axis T>
0049     GeneralQuadric operator()(ConeAligned<T> const&) const;
0050 
0051     GeneralQuadric operator()(SimpleQuadric const&) const;
0052 
0053     GeneralQuadric operator()(GeneralQuadric const&) const;
0054 
0055     Involute operator()(Involute const&) const;
0056 
0057   private:
0058     Transformation tr_;
0059 };
0060 
0061 
0062 }  
0063 }