Block-Structured AMR Software Framework
Loading...
Searching...
No Matches
AMReX_distFcnElement.H
Go to the documentation of this file.
1#ifndef AMREX_DISTFCNELEMENT_H_
2#define AMREX_DISTFCNELEMENT_H_
3#include <AMReX_Config.H>
4
5#include <AMReX_RealVect.H>
6#include <AMReX.H>
7#include <AMReX_Vector.H>
8
15namespace amrex {
16
18class distFcnElement2d { // NOLINT(cppcoreguidelines-special-member-functions)
19 public:
21 distFcnElement2d() = default;
22 virtual ~distFcnElement2d() = default;
23
24 [[nodiscard]] virtual distFcnElement2d* newDistFcnElement2d() const = 0;
25
26 [[nodiscard]] virtual amrex::Real cpdist(amrex::RealVect pt, amrex::RealVect& cp) const = 0;
27 [[nodiscard]] virtual amrex::Real cpside(amrex::RealVect pt, amrex::RealVect& cp) const = 0;
28 static int solve_thomas (const std::vector<amrex::Real> &a,
29 std::vector<amrex::Real> &b,
30 const std::vector<amrex::Real> &c,
31 std::vector<amrex::Real> &d,
32 std::vector<amrex::Real> &X);
33};
34
35
37class LineDistFcnElement2d: public distFcnElement2d { // NOLINT(cppcoreguidelines-special-member-functions)
38 public:
40 ~LineDistFcnElement2d() override = default;
41
42 [[nodiscard]] distFcnElement2d* newDistFcnElement2d() const override;
43
44 void set_control_points(std::vector<amrex::RealVect> pts);
45
46 [[nodiscard]] amrex::Real cpdist(amrex::RealVect pt, amrex::RealVect& cp) const override;
47 [[nodiscard]] amrex::Real cpside(amrex::RealVect pt, amrex::RealVect& cp) const override;
48
50
51 protected:
56 amrex::Real& dist);
57
58 private:
59 std::vector<amrex::Real> control_points_x;
60 std::vector<amrex::Real> control_points_y;
61
62
63};
64
65
67class SplineDistFcnElement2d: public distFcnElement2d { // NOLINT(cppcoreguidelines-special-member-functions)
68 public:
70 ~SplineDistFcnElement2d() override = default;
71
72 [[nodiscard]] distFcnElement2d* newDistFcnElement2d() const override;
73
74
75 void set_control_points(std::vector<amrex::RealVect> pts);
77
78 void print_control_points() const;
79 void print_spline() const;
80
81 void calc_D(bool clamped_bc = false);
82
83 [[nodiscard]] amrex::Real cpdist(amrex::RealVect pt, amrex::RealVect& cp) const override;
84 [[nodiscard]] amrex::Real cpside(amrex::RealVect pt, amrex::RealVect& cp) const override;
85
86 protected:
89 static void dxbydt(amrex::Real t, amrex::Real y0, amrex::Real y1,
91 amrex::Real& d2yf);
92
95 amrex::Real Dx0, amrex::Real Dx1,
97 amrex::Real Dy0, amrex::Real Dy1,
100
103 amrex::Real Dx0, amrex::Real Dx1,
105 amrex::Real Dy0, amrex::Real Dy1,
106 amrex::Real& t,
107 amrex::RealVect& spt);
108
109 private:
110 std::vector<amrex::Real> control_points_x;
111 std::vector<amrex::Real> control_points_y;
112
113 amrex::RealVect bc_pt_start;
114 amrex::RealVect bc_pt_end;
115
116 std::vector<amrex::Real> Dx;
117 std::vector<amrex::Real> Dy;
118};
119
120}
121
122#endif
Distance function defined by a polyline.
Definition AMReX_distFcnElement.H:37
amrex::Real cpside(amrex::RealVect pt, amrex::RealVect &cp) const override
Definition AMReX_distFcnElement.cpp:354
distFcnElement2d * newDistFcnElement2d() const override
Definition AMReX_distFcnElement.cpp:447
static void single_seg_cpdist(amrex::RealVect pt, amrex::Real x0, amrex::Real x1, amrex::Real y0, amrex::Real y1, amrex::RealVect &cp, amrex::Real &dist)
Definition AMReX_distFcnElement.cpp:413
void set_control_points(std::vector< amrex::RealVect > pts)
Definition AMReX_distFcnElement.cpp:406
~LineDistFcnElement2d() override=default
void print_control_points()
Definition AMReX_distFcnElement.cpp:439
amrex::Real cpdist(amrex::RealVect pt, amrex::RealVect &cp) const override
Definition AMReX_distFcnElement.cpp:334
Distance function defined by a cubic spline.
Definition AMReX_distFcnElement.H:67
distFcnElement2d * newDistFcnElement2d() const override
Definition AMReX_distFcnElement.cpp:43
static amrex::Real dist(amrex::RealVect pt, amrex::Real x0, amrex::Real x1, amrex::Real Dx0, amrex::Real Dx1, amrex::Real y0, amrex::Real y1, amrex::Real Dy0, amrex::Real Dy1, amrex::Real &t, amrex::RealVect &spt)
Definition AMReX_distFcnElement.cpp:64
static void single_spline_cpdist(amrex::RealVect pt, amrex::Real x0, amrex::Real x1, amrex::Real Dx0, amrex::Real Dx1, amrex::Real y0, amrex::Real y1, amrex::Real Dy0, amrex::Real Dy1, amrex::Real &t, amrex::RealVect &cp, amrex::Real &dist)
Definition AMReX_distFcnElement.cpp:171
amrex::Real cpside(amrex::RealVect pt, amrex::RealVect &cp) const override
Definition AMReX_distFcnElement.cpp:107
void print_control_points() const
Definition AMReX_distFcnElement.cpp:300
void set_control_points(std::vector< amrex::RealVect > pts)
Definition AMReX_distFcnElement.cpp:285
amrex::Real cpdist(amrex::RealVect pt, amrex::RealVect &cp) const override
Definition AMReX_distFcnElement.cpp:85
void print_spline() const
Definition AMReX_distFcnElement.cpp:312
~SplineDistFcnElement2d() override=default
static void dxbydt(amrex::Real t, amrex::Real y0, amrex::Real y1, amrex::Real D0, amrex::Real D1, amrex::Real &dyf, amrex::Real &d2yf)
Definition AMReX_distFcnElement.cpp:212
void calc_D(bool clamped_bc=false)
Definition AMReX_distFcnElement.cpp:226
static amrex::Real eval(amrex::Real t, amrex::Real y0, amrex::Real y1, amrex::Real D0, amrex::Real D1)
Definition AMReX_distFcnElement.cpp:54
void set_bc_points(amrex::RealVect start, amrex::RealVect end)
Definition AMReX_distFcnElement.cpp:293
Abstract base for 2-D distance-function elements.
Definition AMReX_distFcnElement.H:18
virtual ~distFcnElement2d()=default
virtual amrex::Real cpdist(amrex::RealVect pt, amrex::RealVect &cp) const =0
virtual distFcnElement2d * newDistFcnElement2d() const =0
static int solve_thomas(const std::vector< amrex::Real > &a, std::vector< amrex::Real > &b, const std::vector< amrex::Real > &c, std::vector< amrex::Real > &d, std::vector< amrex::Real > &X)
Definition AMReX_distFcnElement.cpp:9
distFcnElement2d()=default
Constructor.
virtual amrex::Real cpside(amrex::RealVect pt, amrex::RealVect &cp) const =0
amrex_real Real
Floating Point Type for Fields.
Definition AMReX_REAL.H:79
Definition AMReX_Amr.cpp:49
__host__ __device__ Dim3 end(BoxND< dim > const &box) noexcept
Definition AMReX_Box.H:2015