2020-12-18 22:46:21 +08:00
|
|
|
#![allow(dead_code)]
|
2020-11-29 08:41:16 +08:00
|
|
|
use super::Complex;
|
|
|
|
|
2021-01-18 05:19:14 +08:00
|
|
|
/// Maximum acceptable error between a computed and actual value given fixed and relative
|
|
|
|
/// tolerances.
|
|
|
|
///
|
|
|
|
/// # Args
|
|
|
|
/// * `a` - First input.
|
|
|
|
/// * `b` - Second input. The relative tolerance is computed with respect to the maximum of the
|
|
|
|
/// absolute values of the first and second inputs.
|
|
|
|
/// * `rtol` - Relative tolerance.
|
|
|
|
/// * `atol` - Fixed tolerance.
|
|
|
|
///
|
|
|
|
/// # Returns
|
|
|
|
/// Maximum acceptable error.
|
|
|
|
pub fn max_error(a: f64, b: f64, rtol: f64, atol: f64) -> f64 {
|
|
|
|
rtol * a.abs().max(b.abs()) + atol
|
|
|
|
}
|
|
|
|
|
2020-12-17 08:02:17 +08:00
|
|
|
pub fn isclose(a: f64, b: f64, rtol: f64, atol: f64) -> bool {
|
|
|
|
(a - b).abs() <= a.abs().max(b.abs()) * rtol + atol
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn isclosef(a: f32, b: f32, rtol: f32, atol: f32) -> bool {
|
2020-12-05 01:09:23 +08:00
|
|
|
(a - b).abs() <= a.abs().max(b.abs()) * rtol + atol
|
2020-11-29 08:41:16 +08:00
|
|
|
}
|
|
|
|
|
2020-12-05 01:09:23 +08:00
|
|
|
pub fn complex_isclose(
|
2020-11-29 08:41:16 +08:00
|
|
|
a: Complex<f32>,
|
|
|
|
b: Complex<f32>,
|
2020-12-05 01:09:23 +08:00
|
|
|
rtol: f32,
|
|
|
|
atol: f32,
|
2020-11-29 08:41:16 +08:00
|
|
|
) -> bool {
|
2021-02-18 20:17:24 +08:00
|
|
|
isclosef(a.re, b.re, rtol, atol) && isclosef(a.im, b.im, rtol, atol)
|
2020-11-29 08:41:16 +08:00
|
|
|
}
|
|
|
|
|
2020-12-05 01:09:23 +08:00
|
|
|
pub fn complex_allclose(
|
2020-11-29 08:41:16 +08:00
|
|
|
a: &[Complex<f32>],
|
|
|
|
b: &[Complex<f32>],
|
2020-12-05 01:09:23 +08:00
|
|
|
rtol: f32,
|
|
|
|
atol: f32,
|
2020-11-29 08:41:16 +08:00
|
|
|
) -> bool {
|
2020-12-18 22:46:21 +08:00
|
|
|
a.iter()
|
|
|
|
.zip(b)
|
|
|
|
.all(|(&i, &j)| complex_isclose(i, j, rtol, atol))
|
2020-11-29 08:41:16 +08:00
|
|
|
}
|