41std::tuple<Utils::Vector3d, Utils::Vector3d, Utils::Vector3d>
73std::optional<std::tuple<Utils::Vector3d, Utils::Vector3d, Utils::Vector3d>>
80 auto const l =
vec2.norm();
83 auto const lp =
vec1.norm();
98 const double Dyx = 0.0;
Vector implementation and trait types for boost qvm interoperability.
Utils::Vector< T, 3 > get_mi_vector(const Utils::Vector< T, 3 > &a, const Utils::Vector< T, 3 > &b) const
Get the minimum-image vector between two coordinates.
cudaStream_t stream[1]
CUDA streams for parallel computing on CPU and GPU.
Utils::Vector3d get_ibm_particle_position(CellStructure const &cell_structure, int pid)
Returns the position of a given particle.
Vector< T, 3 > vector_product(Vector< T, 3 > const &a, Vector< T, 3 > const &b)
DEVICE_QUALIFIER constexpr T sqr(T x)
Calculates the SQuaRe of x.
std::tuple< Utils::Vector3d, Utils::Vector3d, Utils::Vector3d > RotateForces(Utils::Vector2d const &f1_rot, Utils::Vector2d const &f2_rot, Utils::Vector3d const &v12, Utils::Vector3d const &v13)
Rotate calculated trielastic forces in the 2d plane back to the 3d plane.
Describes a cell structure / cell system.
void initialize(BoxGeometry const &box_geo, CellStructure const &cell_structure)
Set the IBM Triel parameters.
std::optional< std::tuple< Utils::Vector3d, Utils::Vector3d, Utils::Vector3d > > calc_forces(Utils::Vector3d const &vec1, Utils::Vector3d const &vec2) const
Calculate the forces.
std::tuple< int, int, int > p_ids
Particle ids.