chombo-discharge
Loading...
Searching...
No Matches
CD_SignedDistanceBVH.H
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2021-2026 SINTEF Energy Research
3 *
4 * SPDX-License-Identifier: GPL-3.0-or-later
5 */
6
13#ifndef CD_SIGNEDDISTANCEBVH_H
14#define CD_SIGNEDDISTANCEBVH_H
15
16// Std includes
17#include <memory>
18#include <chrono>
19
20// EBGeometry includes
21#include <EBGeometry.hpp>
22
23// Chombo includes
24#include <BaseIF.H>
25
26// Our includes
27#include <CD_NamespaceHeader.H>
28
34template <class T, class BV, int K>
35class SignedDistanceBVH : public BaseIF
36{
37public:
41 using Vec3 = EBGeometry::Vec3T<T>;
42
46 using Face = EBGeometry::DCEL::FaceT<T>;
47
51 using Node = EBGeometry::BVH::LinearBVH<T, Face, BV, K>;
52
57
65
71
75 virtual ~SignedDistanceBVH();
76
82 Real
83 value(const RealVect& a_point) const override;
84
89 BaseIF*
90 newImplicitFunction() const override;
91
92protected:
97
102
107
111 mutable long m_numCalled;
112
116 mutable std::chrono::duration<double> m_timespan;
117};
118
119#include <CD_NamespaceFooter.H>
120
122
123#endif
Implementation of CD_SignedDistanceBVH.H.
Signed distance function for a DCEL mesh.
Definition CD_SignedDistanceBVH.H:36
bool m_flipInside
Hook for turning inside to outside.
Definition CD_SignedDistanceBVH.H:106
Real m_zCoord
For 2D only. This is the z-coordinate through which we slice the object.
Definition CD_SignedDistanceBVH.H:96
BaseIF * newImplicitFunction() const override
Factory method. Sends pointers around.
Definition CD_SignedDistanceBVHImplem.H:88
SignedDistanceBVH()=delete
Disallowed weak construction.
std::shared_ptr< Node > m_root
Pointer to root node in bounding volume hierarchy.
Definition CD_SignedDistanceBVH.H:101
EBGeometry::BVH::LinearBVH< T, Face, BV, K > Node
Alias for BVH node with precision T, enclosing DCEL face with a bounding volume type V.
Definition CD_SignedDistanceBVH.H:51
std::chrono::duration< double > m_timespan
Total time spent computing the signed distance. Use for performance tracking.
Definition CD_SignedDistanceBVH.H:116
EBGeometry::Vec3T< T > Vec3
Alias for always-3D vector with template.
Definition CD_SignedDistanceBVH.H:41
EBGeometry::DCEL::FaceT< T > Face
DCEL polygon face, which is the primitive type enclosed in the bounding volume hierarchy.
Definition CD_SignedDistanceBVH.H:46
virtual ~SignedDistanceBVH()
Destructor (does nothing)
Definition CD_SignedDistanceBVHImplem.H:50
long m_numCalled
Number of times the implicit function was called. Use for performance tracking.
Definition CD_SignedDistanceBVH.H:111
Real value(const RealVect &a_point) const override
Value function.
Definition CD_SignedDistanceBVHImplem.H:61
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:38
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:26