NetDEM v1.0
Loading...
Searching...
No Matches
shape_ellipsoid.hpp
Go to the documentation of this file.
1#pragma once
2
3#include "shape.hpp"
4#include <iostream>
5
6namespace netdem {
7
15class Ellipsoid : public Shape {
16public:
20 double axis_a{0.5};
21
25 double axis_b{0.5};
26
30 double axis_c{0.5};
31
35 Ellipsoid();
36
47 Ellipsoid(double a, double b, double c);
48
56 Shape *Clone() const override;
57
66 nlohmann::json PackJson() override;
67
76 void InitFromJson(nlohmann::json const &js) override;
77
84 void Init();
85
94 void SetSize(double d) override;
95
102 void UpdateSurfaceNodes() override;
103
110 void UpdateShapeProperties() override;
111
122 STLModel GetSTLModel(int num_nodes = 200) override;
123
136 Vec3d SupportPoint(Vec3d const &dir) override;
137
150 VecXT<Vec3d> SupportPoints(Vec3d const &dir) override;
151
164 double SignedDistance(Vec3d const &pos) const override;
165
179 Vec3d SurfacePoint(Vec3d const &pos) override;
180
192 double CalculateRho(Vec3d const &dir) const;
193
200 void Print() override;
201};
202
203} // namespace netdem
A class for representing an ellipsoid shape.
Definition shape_ellipsoid.hpp:15
double axis_b
The length of the semi-axis in the y direction.
Definition shape_ellipsoid.hpp:25
double axis_c
The length of the semi-axis in the z direction.
Definition shape_ellipsoid.hpp:30
void UpdateShapeProperties() override
Update the shape properties of the Ellipsoid object.
Definition shape_ellipsoid.cpp:89
nlohmann::json PackJson() override
Pack the Ellipsoid object into a JSON structure.
Definition shape_ellipsoid.cpp:31
void UpdateSurfaceNodes() override
Update the surface nodes of the Ellipsoid object.
Definition shape_ellipsoid.cpp:67
double axis_a
The length of the semi-axis in the x direction.
Definition shape_ellipsoid.hpp:20
STLModel GetSTLModel(int num_nodes=200) override
Generate an STL model of the Ellipsoid object.
Definition shape_ellipsoid.cpp:118
VecXT< Vec3d > SupportPoints(Vec3d const &dir) override
Compute the support points in a given direction for the Ellipsoid object.
Definition shape_ellipsoid.cpp:180
void InitFromJson(nlohmann::json const &js) override
Initialize the Ellipsoid object from a JSON structure.
Definition shape_ellipsoid.cpp:41
double CalculateRho(Vec3d const &dir) const
Compute the distance from the center of the Ellipsoid object to a plane perpendicular to its axis in ...
Definition shape_ellipsoid.cpp:206
void Print() override
Print information about the Ellipsoid object.
Definition shape_ellipsoid.cpp:221
Ellipsoid()
Default constructor.
Definition shape_ellipsoid.cpp:14
void SetSize(double d) override
Set the size of the Ellipsoid object.
Definition shape_ellipsoid.cpp:51
Vec3d SurfacePoint(Vec3d const &pos) override
Compute the surface point closest to a given position on the Ellipsoid object.
Definition shape_ellipsoid.cpp:196
void Init()
Initialize the Ellipsoid object.
Definition shape_ellipsoid.cpp:60
Shape * Clone() const override
Clone the Ellipsoid object.
Definition shape_ellipsoid.cpp:29
double SignedDistance(Vec3d const &pos) const override
Compute the signed distance from a given position to the surface of the Ellipsoid object.
Definition shape_ellipsoid.cpp:186
Vec3d SupportPoint(Vec3d const &dir) override
Compute the support point in a given direction for the Ellipsoid object.
Definition shape_ellipsoid.cpp:168
Class for working with STL models.
Definition stl_model.hpp:17
This class represents different types of shapes and performs various calculations on them.
Definition shape.hpp:15
Definition bond_entry.hpp:7
std::vector< T > VecXT
Definition utils_macros.hpp:31
pos
Definition json_serilization.hpp:19
std::array< double, 3 > Vec3d
Definition utils_macros.hpp:18