1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
use crate::algebra::abstr::AbsDiffEq;
use crate::algebra::abstr::Field;
use crate::algebra::abstr::Scalar;
use crate::algebra::linear::matrix::UpperHessenberg;

impl<T> AbsDiffEq for UpperHessenberg<T>
where
    T: Field + Scalar + AbsDiffEq<Epsilon = T>,
{
    type Epsilon = T;

    fn default_epsilon() -> T {
        T::default_epsilon()
    }

    fn abs_diff_eq(&self, other: &UpperHessenberg<T>, epsilon: T) -> bool {
        self.matrix.abs_diff_eq(&other.matrix, epsilon)
    }
}