|
NetDEM v1.0
|
A class for representing an ellipsoid shape. More...
#include <shape_ellipsoid.hpp>
Public Member Functions | |
| Ellipsoid () | |
| Default constructor. | |
| Ellipsoid (double a, double b, double c) | |
| Constructor taking the lengths of the three semi-axes. | |
| Shape * | Clone () const override |
| Clone the Ellipsoid object. | |
| nlohmann::json | PackJson () override |
| Pack the Ellipsoid object into a JSON structure. | |
| void | InitFromJson (nlohmann::json const &js) override |
| Initialize the Ellipsoid object from a JSON structure. | |
| void | Init () |
| Initialize the Ellipsoid object. | |
| void | SetSize (double d) override |
| Set the size of the Ellipsoid object. | |
| void | UpdateSurfaceNodes () override |
| Update the surface nodes of the Ellipsoid object. | |
| void | UpdateShapeProperties () override |
| Update the shape properties of the Ellipsoid object. | |
| STLModel | GetSTLModel (int num_nodes=200) override |
| Generate an STL model of the Ellipsoid object. | |
| Vec3d | SupportPoint (Vec3d const &dir) override |
| Compute the support point in a given direction for the Ellipsoid object. | |
| VecXT< Vec3d > | SupportPoints (Vec3d const &dir) override |
| Compute the support points in a given direction for the Ellipsoid object. | |
| double | SignedDistance (Vec3d const &pos) const override |
| Compute the signed distance from a given position to the surface of the Ellipsoid object. | |
| Vec3d | SurfacePoint (Vec3d const &pos) override |
| Compute the surface point closest to a given position on the Ellipsoid object. | |
| double | CalculateRho (Vec3d const &dir) const |
| Compute the distance from the center of the Ellipsoid object to a plane perpendicular to its axis in a given direction. | |
| void | Print () override |
| Print information about the Ellipsoid object. | |
Public Member Functions inherited from netdem::Shape | |
| virtual void | InitFromJsonFile (std::string const &js_file) |
| Initializes the shape instance from a JSON file. | |
| virtual double | GetSize () const |
| Return shape size, which is defined as the diameter of equal-volume sphere. | |
| virtual double | GetVolume () const |
| Return the volume of the shape. | |
| virtual Mat3d const & | GetInertia () const |
| Return the inertia of the shape. | |
| Vec3d | GetInertiaPrincipal () const |
| Return the principal inertia of the shape. | |
| virtual double | GetBoundSphereRadius () const |
| Return the inertia of the shape. | |
| virtual std::tuple< Vec3d, Vec3d > | GetBoundAABB () const |
| Gets the boundary AABB of the shape instance. | |
| virtual std::tuple< Vec3d, Vec3d > | GetBoundAABB (Vec3d const &pos, Vec4d const &quat) const |
| Gets the boundary AABB of the shape instance. | |
| virtual double | GetSkin () const |
| Return skin size of the shape. | |
| virtual double | GetSkinFactor () const |
| Return skin factor of the shape. | |
| virtual double | GetSurfaceNodeNum () const |
| Return number of surface nodes of the shape. | |
| virtual VecXT< Vec3d > const & | GetSurfaceNodes () const |
| Return surface nodes of the shape. | |
| virtual VecXT< double > const & | GetSurfaceNodeAreas () const |
| Return surface area associated with each surface node. | |
| virtual double | GetSurfaceNodeSpacing () const |
| Return spacing of surface nodes. | |
| const STLModel & | GetRenderMesh () const |
| Return the surface mesh for rendering. | |
| bool | CheckConvexity () |
| Return the convexity of the shape. | |
| virtual void | Translate (Vec3d const &pos) |
| Translates the shape instance to a new position. | |
| virtual void | UpdateRenderMesh (int num_nodes=200) |
| Initializes the surface mesh for rendering. | |
| virtual void | SetSkin (double sk) |
| Set skin size of the shape. | |
| virtual void | SetSkinFactor (double sk_factor) |
| Set skin size factor (skin = size by skin size factor) of the shape. | |
| virtual void | EnableSurfaceNodes () |
| Enable the use of surface nodes. | |
| virtual void | DisableSurfaceNodes () |
| Disable the use of surface nodes. | |
| virtual bool | IsSurfaceNodesEnabled () |
| Check if the use of surface nodes is enabled. | |
| virtual void | SetSurfaceNodeNum (int num) |
| Set number of surface nodes of the shape. | |
| virtual void | SetSurfaceNodes (VecXT< Vec3d > const &nodes) |
| Set the surface nodes of the shape. | |
| virtual void | SetSurfaceNodes (STLModel const &surf_stl) |
| Set the surface nodes of the shape. | |
| virtual void | SaveAsVTK (std::string const &filename) |
| Saves the shape instance as a VTK file. | |
| virtual void | SaveAsSTL (std::string const &filename) |
| Saves the shape instance as an STL file. | |
| virtual bool | CheckEnclose (Vec3d const &pos) const |
| Determines whether a given point is enclosed within the shape instance. | |
| virtual bool | CheckPrincipal () const |
| Determines whether the shape is in principal configuration. | |
| virtual | ~Shape () |
| Destructor for the Shape class. | |
Public Attributes | |
| double | axis_a {0.5} |
| The length of the semi-axis in the x direction. | |
| double | axis_b {0.5} |
| The length of the semi-axis in the y direction. | |
| double | axis_c {0.5} |
| The length of the semi-axis in the z direction. | |
Public Attributes inherited from netdem::Shape | |
| int | id {0} |
| ID of the shape instance. | |
| std::string | label {"default"} |
| Label of the shape instance. | |
| Type | shape_type {Type::none} |
| Type of the shape instance. | |
| std::string | shape_name {"shape"} |
| Name of the shape instance. | |
| bool | use_customized_solver {false} |
| Determines whether to use a customized contact solver or not. | |
| STLModel | render_mesh |
| Surface mesh for rendering. | |
Additional Inherited Members | |
Public Types inherited from netdem::Shape | |
| enum | Type { none , point_sphere , sphere , spherical_harmonics , trimesh , trimesh_convex , ellipsoid , polybezier , triangle , plane , cylinder , poly_super_ellipsoid , poly_super_quadrics , level_set , netsdf , coded_netsdf , num_shapes } |
| Enumeration for different types of shapes. More... | |
Static Public Member Functions inherited from netdem::Shape | |
| static MatNd< 8, 3 > | VerticesOfAABB (Vec3d const &bmin, Vec3d const &bmax) |
| Gets the vertices of the boundary AABB of the shape instance. | |
Protected Attributes inherited from netdem::Shape | |
| double | size {1.0} |
| Size and volume of the shape instance. | |
| double | volume {0.5236} |
| Volume of the shape instance. | |
| Mat3d | inertia {{{0.05236, 0, 0}, {0, 0.05236, 0}, {0, 0, 0.05236}}} |
| Inertia tensor of the shape instance. | |
| double | bound_sphere_radius {0.5} |
| Radius of the bounding sphere used for broad-phase contact detection. | |
| double | skin {0.025} |
| Skin thickness used for broad-phase contact detection. | |
| double | skin_factor {0.05} |
| Factor used to adjust the skin thickness. | |
| Vec3d | bound_aabb_min {-0.5, -0.5, -0.5} |
| Minimum bounds of the AABB used for broad-phase contact detection. | |
| Vec3d | bound_aabb_max {0.5, 0.5, 0.5} |
| Maximum bounds of the AABB used for broad-phase contact detection. | |
| bool | is_convex {true} |
| Determines whether the shape instance is convex or not. | |
| bool | use_surface_nodes {false} |
| Determines whether to use nodes for the contact solver. | |
| int | surface_node_num {1000} |
| Number of nodes used for the contact solver. | |
| double | surface_node_spacing {std::sqrt(Math::PI / 1000.0)} |
| Spacing between nodes used for the contact solver. | |
| VecXT< Vec3d > | surface_nodes |
| Surface nodes of the shape instance used for the contact solver. | |
| VecXT< double > | surface_node_areas |
| Area associated with each surface node. | |
A class for representing an ellipsoid shape.
This class provides methods for computing signed distances, surface points, support points, and STL models for an ellipsoid shape.
| Ellipsoid::Ellipsoid | ( | ) |
Default constructor.
| Ellipsoid::Ellipsoid | ( | double | a, |
| double | b, | ||
| double | c ) |
Constructor taking the lengths of the three semi-axes.
This constructor creates an ellipsoid with the specified lengths of its three semi-axes.
| a | The length of the semi-axis in the x direction. |
| b | The length of the semi-axis in the y direction. |
| c | The length of the semi-axis in the z direction. |
| double Ellipsoid::CalculateRho | ( | Vec3d const & | dir | ) | const |
Compute the distance from the center of the Ellipsoid object to a plane perpendicular to its axis in a given direction.
This private method computes the distance from the center of the Ellipsoid object to a plane perpendicular to its axis in a given direction, which is used when computing support points.
| dir | The direction of the plane. |
|
overridevirtual |
Clone the Ellipsoid object.
This method creates a copy of the Ellipsoid object.
Reimplemented from netdem::Shape.
|
overridevirtual |
Generate an STL model of the Ellipsoid object.
This method generates an STL model of the Ellipsoid object using the specified number of nodes for each surface triangle.
| num_nodes | The number of nodes to use for each surface triangle (default: 200). |
Reimplemented from netdem::Shape.
| void Ellipsoid::Init | ( | ) |
|
overridevirtual |
Initialize the Ellipsoid object from a JSON structure.
This method initializes the Ellipsoid object from a JSON structure previously generated by PackJson().
| js | The JSON structure to load. |
Reimplemented from netdem::Shape.
|
overridevirtual |
Pack the Ellipsoid object into a JSON structure.
This method packs the Ellipsoid object into a JSON structure for serialization and storage.
Reimplemented from netdem::Shape.
|
overridevirtual |
Print information about the Ellipsoid object.
This method prints basic information about the Ellipsoid object, including its position, rotation, size, semi-axes lengths, volume, and surface area.
Reimplemented from netdem::Shape.
|
overridevirtual |
Set the size of the Ellipsoid object.
This method sets the size of the Ellipsoid object by scaling it uniformly in all dimensions.
| d | The new size of the Ellipsoid object. |
Reimplemented from netdem::Shape.
|
overridevirtual |
Compute the signed distance from a given position to the surface of the Ellipsoid object.
This method computes the signed distance from a given position to the surface of the Ellipsoid object by evaluating the implicit equation for an ellipsoid.
| pos | The position for which to compute the signed distance. |
Reimplemented from netdem::Shape.
Compute the support point in a given direction for the Ellipsoid object.
This method computes the support point in a given direction for the Ellipsoid object by finding the point on its surface farthest in that direction.
| dir | The direction for which to compute the support point. |
Reimplemented from netdem::Shape.
Compute the support points in a given direction for the Ellipsoid object.
This method computes the support points in a given direction for the Ellipsoid object by finding the two points on its top and bottom surfaces farthest in that direction.
| dir | The direction for which to compute the support points. |
Reimplemented from netdem::Shape.
Compute the surface point closest to a given position on the Ellipsoid object.
This method computes the surface point closest to a given position on the Ellipsoid object by finding the intersection of a line passing through the specified position and perpendicular to the ellipsoid surface with the ellipsoid surface.
| pos | The position for which to compute the closest surface point. |
Reimplemented from netdem::Shape.
|
overridevirtual |
Update the shape properties of the Ellipsoid object.
This method updates the shape properties of the Ellipsoid object, such as its volume and surface area.
Reimplemented from netdem::Shape.
|
overridevirtual |
Update the surface nodes of the Ellipsoid object.
This method updates the surface nodes of the Ellipsoid object based on its current position and rotation.
Reimplemented from netdem::Shape.
| double netdem::Ellipsoid::axis_a {0.5} |
The length of the semi-axis in the x direction.
| double netdem::Ellipsoid::axis_b {0.5} |
The length of the semi-axis in the y direction.
| double netdem::Ellipsoid::axis_c {0.5} |
The length of the semi-axis in the z direction.