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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
use core::cmp::Ordering;
use num::Float;
pub fn fcmp<T>(lhs: &T, rhs: &T) -> Ordering
where
T: Float,
{
match lhs.partial_cmp(rhs) {
Some(ordering) => ordering,
None => {
if lhs.is_nan() {
if rhs.is_nan() {
Ordering::Equal
} else {
Ordering::Greater
}
} else {
Ordering::Less
}
}
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_equal() {
let a: f64 = 3.4;
let b: f64 = 3.4;
assert_eq!(fcmp(&a, &b), Ordering::Equal);
}
#[test]
fn test_less() {
let a: f64 = 2.4;
let b: f64 = 3.4;
assert_eq!(fcmp(&a, &b), Ordering::Less);
}
#[test]
fn test_greater() {
let a: f64 = 4.4;
let b: f64 = 3.4;
assert_eq!(fcmp(&a, &b), Ordering::Greater);
}
#[test]
fn test_nan_nan() {
let a: f64 = f64::NAN;
let b: f64 = f64::NAN;
assert_eq!(fcmp(&a, &b), Ordering::Equal);
}
#[test]
fn test_nan_value() {
let a: f64 = f64::NAN;
let b: f64 = 3.4;
assert_eq!(fcmp(&a, &b), Ordering::Greater);
}
#[test]
fn test_value_nan() {
let a: f64 = 3.4;
let b: f64 = f64::NAN;
assert_eq!(fcmp(&a, &b), Ordering::Less);
}
}