parry3d/bounding_volume/
bounding_sphere_utils.rsuse crate::math::{Point, Real};
use crate::utils;
use na::{self, ComplexField};
#[inline]
pub fn point_cloud_bounding_sphere_with_center(
pts: &[Point<Real>],
center: Point<Real>,
) -> (Point<Real>, Real) {
let mut sqradius = 0.0;
for pt in pts.iter() {
let distance_squared = na::distance_squared(pt, ¢er);
if distance_squared > sqradius {
sqradius = distance_squared
}
}
(center, ComplexField::sqrt(sqradius))
}
#[inline]
pub fn point_cloud_bounding_sphere(pts: &[Point<Real>]) -> (Point<Real>, Real) {
point_cloud_bounding_sphere_with_center(pts, utils::center(pts))
}