Solver for triangle mesh contacts between two particles using boolean operations.
More...
#include <solver_boolean_pp.hpp>
|
| SolverBooleanPP () |
| Default constructor for SolverBooleanPP.
|
|
| SolverBooleanPP (Particle *const p1, Particle *const p2) |
| Constructor for SolverBooleanPP.
|
|
CollisionSolverPP * | Clone () const override |
| Creates a copy of this collision solver.
|
|
void | Init (Particle *const p1, Particle *const p2) override |
| Initializes the collision solver with two particles.
|
|
bool | Detect () override |
| Detects collisions between two particles using boolean operations on their triangle meshes.
|
|
void | ResolveInit (ContactPP *const cnt, double timestep) override |
| Initializes the contact point between two particles at time t = 0.
|
|
void | ResolveUpdate (ContactPP *const cnt, double timestep) override |
| Updates the contact point between two particles at time t > 0.
|
|
void | ResolveInit (CollisionGeometries *const cnt_geoms, double timestep, const VecXT< Vec3d > &vertices, const VecXT< Vec3i > &facets, const VecXT< int > &facets_of_1or2) |
| Initializes the contact geometries between two particles at time t = 0.
|
|
void | ResolveUpdate (CollisionGeometries *const cnt_geoms, double timestep, const VecXT< Vec3d > &vertices, const VecXT< Vec3i > &facets, const VecXT< int > &facets_of_1or2) |
| Updates the contact geometries between two particles at time t > 0.
|
|
void | ResolveInit_Equivalent (CollisionGeometries *const cnt_geoms, double timestep) |
| Initializes the contact geometries between two equivalent shapes at time t = 0.
|
|
void | ResolveUpdate_Equivalent (CollisionGeometries *const cnt_geoms, double timestep) |
| Updates the contact geometries between two equivalent shapes at time t > 0.
|
|
STLModel | GetContactTriMesh (int id) |
| Returns an STL model of the contact triangle mesh for a given component.
|
|
| CollisionSolverPP () |
|
| CollisionSolverPP (Particle *const p1, Particle *const p2) |
|
virtual bool | Detect (ContactPP *const cnt) |
|
virtual | ~CollisionSolverPP () |
|
◆ SolverBooleanPP() [1/2]
netdem::SolverBooleanPP::SolverBooleanPP |
( |
| ) |
|
◆ SolverBooleanPP() [2/2]
netdem::SolverBooleanPP::SolverBooleanPP |
( |
Particle *const | p1, |
|
|
Particle *const | p2 ) |
Constructor for SolverBooleanPP.
- Parameters
-
p1 | The first particle to check for collisions against the second particle. |
p2 | The second particle to check for collisions against the first particle. |
◆ ClearIntersectInfo()
void netdem::SolverBooleanPP::ClearIntersectInfo |
( |
| ) |
|
|
protected |
Clears the intersection information between the two triangle meshes.
◆ Clone()
Creates a copy of this collision solver.
- Returns
- A new instance of the collision solver.
Implements netdem::CollisionSolverPP.
◆ Detect()
bool netdem::SolverBooleanPP::Detect |
( |
| ) |
|
|
overridevirtual |
◆ GetContactTriMesh()
STLModel netdem::SolverBooleanPP::GetContactTriMesh |
( |
int | id | ) |
|
Returns an STL model of the contact triangle mesh for a given component.
- Parameters
-
id | The ID of the component. |
- Returns
- The STL model of the contact triangle mesh.
◆ Init()
◆ ResolveInit() [1/2]
Initializes the contact geometries between two particles at time t = 0.
- Parameters
-
cnt_geoms | The contact geometries. |
timestep | The simulation timestep. |
vertices | The vector of vertices defining the triangle mesh. |
facets | The vector of facets defining the triangle mesh. |
facets_of_1or2 | A vector indicating whether each facet is from particle 1 or particle 2. |
◆ ResolveInit() [2/2]
void netdem::SolverBooleanPP::ResolveInit |
( |
ContactPP *const | cnt, |
|
|
double | timestep ) |
|
overridevirtual |
◆ ResolveInit_Equivalent()
void netdem::SolverBooleanPP::ResolveInit_Equivalent |
( |
CollisionGeometries *const | cnt_geoms, |
|
|
double | timestep ) |
Initializes the contact geometries between two equivalent shapes at time t = 0.
- Parameters
-
cnt_geoms | The contact geometries. |
timestep | The simulation timestep. |
◆ ResolveUpdate() [1/2]
Updates the contact geometries between two particles at time t > 0.
- Parameters
-
cnt_geoms | The contact geometries. |
timestep | The simulation timestep. |
vertices | The vector of vertices defining the triangle mesh. |
facets | The vector of facets defining the triangle mesh. |
facets_of_1or2 | A vector indicating whether each facet is from particle 1 or particle 2. |
◆ ResolveUpdate() [2/2]
void netdem::SolverBooleanPP::ResolveUpdate |
( |
ContactPP *const | cnt, |
|
|
double | timestep ) |
|
overridevirtual |
Updates the contact point between two particles at time t > 0.
- Parameters
-
cnt | The contact point. |
timestep | The simulation timestep. |
Implements netdem::CollisionSolverPP.
◆ ResolveUpdate_Equivalent()
void netdem::SolverBooleanPP::ResolveUpdate_Equivalent |
( |
CollisionGeometries *const | cnt_geoms, |
|
|
double | timestep ) |
Updates the contact geometries between two equivalent shapes at time t > 0.
- Parameters
-
cnt_geoms | The contact geometries. |
timestep | The simulation timestep. |
◆ SeperateComponents()
void netdem::SolverBooleanPP::SeperateComponents |
( |
| ) |
|
|
protected |
Separates the intersection components in the triangle mesh into separate lists.
◆ bound_sphere_radius_1
double netdem::SolverBooleanPP::bound_sphere_radius_1 |
|
protected |
< The radius of the bounding sphere for the first STL model.
The radius of the bounding sphere for the second STL model.
◆ bound_sphere_radius_2
double netdem::SolverBooleanPP::bound_sphere_radius_2 |
|
protected |
The relative position vector between the centers of the two bounding spheres.
◆ comp_facets_list
List of components containing facets from either the first or second STL model.
◆ comp_facets_of_1or2_list
VecXT<VecXT<int> > netdem::SolverBooleanPP::comp_facets_of_1or2_list |
|
protected |
◆ dpos_12
Vec3d netdem::SolverBooleanPP::dpos_12 |
|
protected |
◆ facets_birth_ids
VecXT<int> netdem::SolverBooleanPP::facets_birth_ids |
|
protected |
List of components (connected sets of facets) for each STL model.
◆ facets_isct
List of birth IDs for each intersection facet.
◆ stl_model_1
STLModel* netdem::SolverBooleanPP::stl_model_1 {nullptr} |
|
protected |
◆ stl_model_2
STLModel* netdem::SolverBooleanPP::stl_model_2 {nullptr} |
|
protected |
List of intersection vertices.
◆ vertices_isct
VecXT<Vec3d> netdem::SolverBooleanPP::vertices_isct |
|
protected |
List of intersection facets.
The documentation for this class was generated from the following files: