73 void Init(std::string
const &classifier_file,
74 std::string
const ®ressor_file);
221 Shape *shape_1{
nullptr};
224 Shape *shape_2{
nullptr};
227 double bound_sphere_radius_1;
230 double bound_sphere_radius_2;
A class representing the geometries associated with a collision.
Definition collision_geometries.hpp:15
An abstract class representing a collision solver for a particle and a wall.
Definition collision_solver_pw.hpp:20
A class representing a general neural network.
Definition general_net.hpp:19
Definition particle.hpp:26
A class that represents a feedforward neural network for regression.
Definition regression_net.hpp:21
This class represents different types of shapes and performs various calculations on them.
Definition shape.hpp:15
A class that represents a collision solver between two particles using artificial neural networks.
Definition solver_ann_pw.hpp:26
netdem::GeneralNet classifier
The neural network model used for classification.
Definition solver_ann_pw.hpp:29
CollisionSolverPW * Clone() const override
Creates a copy of the SolverANNPW object.
Definition solver_ann_pw.cpp:13
void ResolveUpdate(ContactPW *const cnt, double timestep) override
Resolves the collision during update time.
Definition solver_ann_pw.cpp:93
void ResolveInit_LinearSpring(CollisionGeometries *const cnt_geoms, double timestep)
Resolves the collision using a linear spring model at initialization time.
Definition solver_ann_pw.cpp:109
std::tuple< double, Vec3d > GetPotential(Vec3d const &pos, Vec4d const &quat)
Calculates the potential energy and contact position for the collision.
Definition solver_ann_pw.cpp:269
std::tuple< Vec3d, Vec3d, Vec3d > EvaluateContactForces()
Evaluates the contact forces for the collision.
Definition solver_ann_pw.cpp:291
void Init(std::string const &classifier_file, std::string const ®ressor_file)
Initializes the collision solver with neural network models from disk.
void ResolveInit_VolumeBased(CollisionGeometries *const cnt_geoms, double timestep)
Resolves the collision using a volume-based method at initialization time.
Definition solver_ann_pw.cpp:165
netdem::RegressionNet regressor
The neural network model used for regression.
Definition solver_ann_pw.hpp:32
bool Detect() override
Detects collisions between the two particles.
Definition solver_ann_pw.cpp:39
void ResolveUpdate_PotentialBased(CollisionGeometries *const cnt_geoms, double timestep)
Resolves the collision using a potential-based method during update time.
Definition solver_ann_pw.cpp:246
void ResolveUpdate_VolumeBased(CollisionGeometries *const cnt_geoms, double timestep)
Resolves the collision using a volume-based method during update time.
Definition solver_ann_pw.cpp:194
void ResolveInit_PotentialBased(CollisionGeometries *const cnt_geoms, double timestep)
Resolves the collision using a potential-based method at initialization time.
Definition solver_ann_pw.cpp:225
void ResolveInit(ContactPW *const cnt, double timestep) override
Resolves the collision at initialization time.
Definition solver_ann_pw.cpp:73
void ResolveUpdate_LinearSpring(CollisionGeometries *const cnt_geoms, double timestep)
Resolves the collision using a linear spring model during update time.
Definition solver_ann_pw.cpp:136
SolverANNPW()
Default constructor for the SolverANNPW class.
Definition solver_ann_pw.cpp:9
A class representing a wall object in a physics simulation.
Definition wall.hpp:32
Definition bond_entry.hpp:7
pos
Definition json_serilization.hpp:19
std::array< double, 3 > Vec3d
Definition utils_macros.hpp:18
std::array< double, 4 > Vec4d
Definition utils_macros.hpp:19