pub struct Tetrahedron<S> { /* private fields */ }Expand description
A 3-simplex or tetrahedron in 3D space
Creation methods will fail with a debug assertion if the points are coplanar.
Implementations§
Source§impl<S: OrderedField> Tetrahedron<S>
impl<S: OrderedField> Tetrahedron<S>
Sourcepub fn new(
a: Point3<S>,
b: Point3<S>,
c: Point3<S>,
d: Point3<S>,
) -> Option<Self>where
S: AbsDiffEq<Epsilon = S>,
pub fn new(
a: Point3<S>,
b: Point3<S>,
c: Point3<S>,
d: Point3<S>,
) -> Option<Self>where
S: AbsDiffEq<Epsilon = S>,
Returns None if the points are coplanar:
assert!(Tetrahedron::new (
[-1.0, -1.0, -1.0].into(),
[ 1.0, 1.0, 1.0].into(),
[-1.0, 1.0, 0.0].into(),
[ 1.0, -1.0, 0.0].into()
).is_none());Sourcepub fn noisy(a: Point3<S>, b: Point3<S>, c: Point3<S>, d: Point3<S>) -> Selfwhere
S: AbsDiffEq<Epsilon = S>,
pub fn noisy(a: Point3<S>, b: Point3<S>, c: Point3<S>, d: Point3<S>) -> Selfwhere
S: AbsDiffEq<Epsilon = S>,
Panics if the points are coplanar:
let s = Tetrahedron::noisy (
[-1.0, -1.0, -1.0].into(),
[ 1.0, 1.0, 1.0].into(),
[-1.0, 1.0, 0.0].into(),
[ 1.0, -1.0, 0.0].into());Sourcepub fn unchecked(a: Point3<S>, b: Point3<S>, c: Point3<S>, d: Point3<S>) -> Selfwhere
S: AbsDiffEq<Epsilon = S>,
pub fn unchecked(a: Point3<S>, b: Point3<S>, c: Point3<S>, d: Point3<S>) -> Selfwhere
S: AbsDiffEq<Epsilon = S>,
Debug panic if the points are coplanar:
let s = Tetrahedron::unchecked (
[-1.0, -1.0, -1.0].into(),
[ 1.0, 1.0, 1.0].into(),
[-1.0, 1.0, 0.0].into(),
[ 1.0, -1.0, 0.0].into());pub fn from_array([a, b, c, d]: [Point3<S>; 4]) -> Option<Self>where
S: AbsDiffEq<Epsilon = S>,
pub const fn point_a(self) -> Point3<S>
pub const fn point_b(self) -> Point3<S>
pub const fn point_c(self) -> Point3<S>
pub const fn point_d(self) -> Point3<S>
pub const fn points(self) -> [Point3<S>; 4]
pub const fn edge_ab(self) -> Segment3<S>
pub const fn edge_ac(self) -> Segment3<S>
pub const fn edge_ad(self) -> Segment3<S>
pub const fn edge_bc(self) -> Segment3<S>
pub const fn edge_bd(self) -> Segment3<S>
pub const fn edge_cd(self) -> Segment3<S>
pub const fn edges(self) -> [Segment3<S>; 6]
Sourcepub fn face_abc(self) -> Triangle<S>
pub fn face_abc(self) -> Triangle<S>
Note that the points in the returned triangle will be ordered so that the
triangle.normal() will face away from the tetrahedron.
Sourcepub fn face_abd(self) -> Triangle<S>
pub fn face_abd(self) -> Triangle<S>
Note that the points in the returned triangle will be ordered so that the
triangle.normal() will face away from the tetrahedron.
Sourcepub fn face_acd(self) -> Triangle<S>
pub fn face_acd(self) -> Triangle<S>
Note that the points in the returned triangle will be ordered so that the
triangle.normal() will face away from the tetrahedron.
Sourcepub fn face_bcd(self) -> Triangle<S>
pub fn face_bcd(self) -> Triangle<S>
Note that the points in the returned triangle will be ordered so that the
triangle.normal() will face away from the tetrahedron.
pub fn faces(self) -> [Triangle<S>; 4]
pub fn normal_abc(self) -> NonZero3<S>
pub fn normal_abd(self) -> NonZero3<S>
pub fn normal_acd(self) -> NonZero3<S>
pub fn normal_bcd(self) -> NonZero3<S>
pub fn volume(self) -> Positive<S>
pub fn translate(&mut self, displacement: Vector3<S>)
Sourcepub fn contains(self, point: Point3<S>) -> bool
pub fn contains(self, point: Point3<S>) -> bool
Checks if a point is contained in the tetrahedron:
let s = Tetrahedron::noisy (
[ 0.0, 0.0, 1.0].into(),
[ 0.0, 1.0, -1.0].into(),
[-1.0, -1.0, -1.0].into(),
[ 1.0, -1.0, -1.0].into()
);
assert!(s.contains (Point3::origin()));
assert!(!s.contains ([0.0, 0.0, 2.0].into()));Trait Implementations§
Source§impl<S: Clone> Clone for Tetrahedron<S>
impl<S: Clone> Clone for Tetrahedron<S>
Source§fn clone(&self) -> Tetrahedron<S>
fn clone(&self) -> Tetrahedron<S>
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<S: Debug> Debug for Tetrahedron<S>
impl<S: Debug> Debug for Tetrahedron<S>
Source§impl<S: Field + Sqrt> Default for Tetrahedron<S>
impl<S: Field + Sqrt> Default for Tetrahedron<S>
Source§fn default() -> Self
fn default() -> Self
A default simplex is arbitrarily chosen to be the simplex with vertices at unit
distance from the origin with A at [0.0, 0.0, 1.0] and B at
[0.0, sqrt(8.0/9.0), -1.0/3.0], and points C and D at
[ sqrt(2.0/3.0), -sqrt(2.0/9.0), -1.0/3.0] and
[-sqrt(2.0/3.0), -sqrt(2.0/9.0), -1.0/3.0].
let s = Tetrahedron::default();
let t = Tetrahedron::noisy (
[ 0.0, 0.0, 1.0].into(),
[ 0.0, f64::sqrt(8.0/9.0), -1.0/3.0].into(),
[ f64::sqrt(2.0/3.0), -f64::sqrt(2.0/9.0), -1.0/3.0].into(),
[-f64::sqrt(2.0/3.0), -f64::sqrt(2.0/9.0), -1.0/3.0].into());
approx::assert_relative_eq!(
Matrix4::from_col_arrays ([
s.point_a().0.with_w (0.0).into_array(),
s.point_b().0.with_w (0.0).into_array(),
s.point_c().0.with_w (0.0).into_array(),
s.point_d().0.with_w (0.0).into_array()
]),
Matrix4::from_col_arrays ([
t.point_a().0.with_w (0.0).into_array(),
t.point_b().0.with_w (0.0).into_array(),
t.point_c().0.with_w (0.0).into_array(),
t.point_d().0.with_w (0.0).into_array()
]));Source§impl<S> From<Tetrahedron<S>> for Hull3<S>where
S: Real + RelativeEq<Epsilon = S>,
impl<S> From<Tetrahedron<S>> for Hull3<S>where
S: Real + RelativeEq<Epsilon = S>,
Source§fn from(tetrahedron: Tetrahedron<S>) -> Self
fn from(tetrahedron: Tetrahedron<S>) -> Self
Source§impl<S: PartialEq> PartialEq for Tetrahedron<S>
impl<S: PartialEq> PartialEq for Tetrahedron<S>
Source§fn eq(&self, other: &Tetrahedron<S>) -> bool
fn eq(&self, other: &Tetrahedron<S>) -> bool
self and other values to be equal, and is used by ==.Source§impl<S> TryFrom<[Point3<S>; 4]> for Tetrahedron<S>where
S: OrderedField + RelativeEq<Epsilon = S>,
impl<S> TryFrom<[Point3<S>; 4]> for Tetrahedron<S>where
S: OrderedField + RelativeEq<Epsilon = S>,
impl<S: Copy> Copy for Tetrahedron<S>
impl<S: Eq> Eq for Tetrahedron<S>
impl<S> StructuralPartialEq for Tetrahedron<S>
Auto Trait Implementations§
impl<S> Freeze for Tetrahedron<S>where
S: Freeze,
impl<S> RefUnwindSafe for Tetrahedron<S>where
S: RefUnwindSafe,
impl<S> Send for Tetrahedron<S>where
S: Send,
impl<S> Sync for Tetrahedron<S>where
S: Sync,
impl<S> Unpin for Tetrahedron<S>where
S: Unpin,
impl<S> UnsafeUnpin for Tetrahedron<S>where
S: UnsafeUnpin,
impl<S> UnwindSafe for Tetrahedron<S>where
S: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CheckedAs for T
impl<T> CheckedAs for T
Source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
Source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
Source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more