1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
use crate::complex::{Complex, Moebius, Quaternion}; use approx::{abs_diff_eq, AbsDiffEq}; impl<T> AbsDiffEq for Complex<T> where T: AbsDiffEq<Epsilon = T> + Copy, { type Epsilon = T; fn default_epsilon() -> Self::Epsilon { T::default_epsilon() } fn abs_diff_eq(&self, other: &Self, epsilon: Self::Epsilon) -> bool { abs_diff_eq!(self.into_vector(), other.into_vector(), epsilon = epsilon) } } impl<T> AbsDiffEq for Quaternion<T> where T: AbsDiffEq<Epsilon = T> + Copy, { type Epsilon = T; fn default_epsilon() -> Self::Epsilon { T::default_epsilon() } fn abs_diff_eq(&self, other: &Self, epsilon: Self::Epsilon) -> bool { abs_diff_eq!(self.into_vector(), other.into_vector(), epsilon = epsilon) } } impl<T> AbsDiffEq for Moebius<T> where T: AbsDiffEq<Epsilon = T> + Copy, { type Epsilon = T; fn default_epsilon() -> Self::Epsilon { T::default_epsilon() } fn abs_diff_eq(&self, other: &Self, epsilon: Self::Epsilon) -> bool { abs_diff_eq!(self.into_matrix(), other.into_matrix(), epsilon = epsilon) } }