2018-09-22 23:36:08 +08:00
|
|
|
// NOTE those are actually duplicates of vector_relational.rs
|
|
|
|
|
|
|
|
/*
|
2018-09-22 19:18:59 +08:00
|
|
|
use approx::AbsDiffEq;
|
|
|
|
use na::DefaultAllocator;
|
|
|
|
|
2019-03-23 21:29:07 +08:00
|
|
|
use crate::traits::{Alloc, Number, Dimension};
|
|
|
|
use crate::aliases::TVec;
|
2018-09-22 19:18:59 +08:00
|
|
|
|
2023-02-01 14:48:06 +08:00
|
|
|
/// Component-wise approximate equality between two vectors.
|
2021-04-11 17:00:38 +08:00
|
|
|
pub fn epsilon_equal<T: Number, const D: usize>(x: &TVec<T, D>, y: &TVec<T, D>, epsilon: T) -> TVec<bool, D>
|
|
|
|
where DefaultAllocator: Alloc<T, D> {
|
2018-09-22 19:18:59 +08:00
|
|
|
x.zip_map(y, |x, y| abs_diff_eq!(x, y, epsilon = epsilon))
|
|
|
|
}
|
|
|
|
|
2023-02-01 14:48:06 +08:00
|
|
|
/// Component-wise approximate equality between two scalars.
|
2021-04-11 17:00:38 +08:00
|
|
|
pub fn epsilon_equal2<T: AbsDiffEq<Epsilon = T>>(x: T, y: T, epsilon: T) -> bool {
|
2018-09-22 19:18:59 +08:00
|
|
|
abs_diff_eq!(x, y, epsilon = epsilon)
|
|
|
|
}
|
|
|
|
|
2023-02-01 14:48:06 +08:00
|
|
|
/// Component-wise approximate non-equality between two vectors.
|
2021-04-11 17:00:38 +08:00
|
|
|
pub fn epsilon_not_equal<T: Number, const D: usize>(x: &TVec<T, D>, y: &TVec<T, D>, epsilon: T) -> TVec<bool, D>
|
|
|
|
where DefaultAllocator: Alloc<T, D> {
|
2018-09-22 19:18:59 +08:00
|
|
|
x.zip_map(y, |x, y| abs_diff_ne!(x, y, epsilon = epsilon))
|
|
|
|
}
|
|
|
|
|
2023-02-01 14:48:06 +08:00
|
|
|
/// Component-wise approximate non-equality between two scalars.
|
2021-04-11 17:00:38 +08:00
|
|
|
pub fn epsilon_not_equal2<T: AbsDiffEq<Epsilon = T>>(x: T, y: T, epsilon: T) -> bool {
|
2018-09-22 19:18:59 +08:00
|
|
|
abs_diff_ne!(x, y, epsilon = epsilon)
|
|
|
|
}
|
2018-10-22 04:11:27 +08:00
|
|
|
*/
|