use na::DefaultAllocator; use aliases::{TVec, TMat}; use traits::{Alloc, Number, Dimension}; /// Perform a component-wise equal-to comparison of two matrices. /// /// Return a boolean vector which components value is True if this expression is satisfied per column of the matrices. pub fn equal_columns(x: &TMat, y: &TMat) -> TVec where DefaultAllocator: Alloc { let mut res = TVec::<_, C>::repeat(false); for i in 0..C::dim() { res[i] = x.column(i) == y.column(i) } res } /// Returns the component-wise comparison of `|x - y| < epsilon`. /// /// True if this expression is satisfied. pub fn equal_columns_eps(x: &TMat, y: &TMat, epsilon: N) -> TVec where DefaultAllocator: Alloc { equal_columns_eps_vec(x, y, &TVec::<_, C>::repeat(epsilon)) } /// Returns the component-wise comparison on each matrix column `|x - y| < epsilon`. /// /// True if this expression is satisfied. pub fn equal_columns_eps_vec(x: &TMat, y: &TMat, epsilon: &TVec) -> TVec where DefaultAllocator: Alloc { let mut res = TVec::<_, C>::repeat(false); for i in 0..C::dim() { res[i] = (x.column(i) - y.column(i)).abs() < TVec::<_, R>::repeat(epsilon[i]) } res } /// Perform a component-wise not-equal-to comparison of two matrices. /// /// Return a boolean vector which components value is True if this expression is satisfied per column of the matrices. pub fn not_equal_columns(x: &TMat, y: &TMat) -> TVec where DefaultAllocator: Alloc { let mut res = TVec::<_, C>::repeat(false); for i in 0..C::dim() { res[i] = x.column(i) != y.column(i) } res } /// Returns the component-wise comparison of `|x - y| < epsilon`. /// /// True if this expression is not satisfied. pub fn not_equal_columns_eps(x: &TMat, y: &TMat, epsilon: N) -> TVec where DefaultAllocator: Alloc { not_equal_columns_eps_vec(x, y, &TVec::<_, C>::repeat(epsilon)) } /// Returns the component-wise comparison of `|x - y| >= epsilon`. /// /// True if this expression is not satisfied. pub fn not_equal_columns_eps_vec(x: &TMat, y: &TMat, epsilon: &TVec) -> TVec where DefaultAllocator: Alloc { let mut res = TVec::<_, C>::repeat(false); for i in 0..C::dim() { res[i] = (x.column(i) - y.column(i)).abs() >= TVec::<_, R>::repeat(epsilon[i]) } res }