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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
use crate::clone;
use arctk_attr::load;
use std::{
f64::{INFINITY, NEG_INFINITY},
fmt::{Display, Formatter, Result},
};
#[load]
#[derive(Clone, PartialEq)]
pub struct Range {
min: f64,
max: f64,
}
impl Range {
clone!(min, f64);
clone!(max, f64);
#[inline]
#[must_use]
pub fn new(min: f64, max: f64) -> Self {
debug_assert!(min < max);
Self { min, max }
}
#[inline]
#[must_use]
pub const fn new_infinite() -> Self {
Self {
min: NEG_INFINITY,
max: INFINITY,
}
}
#[inline]
#[must_use]
pub fn width(&self) -> f64 {
self.max - self.min
}
#[inline]
#[must_use]
pub fn contains(&self, x: f64) -> bool {
if x < self.min || x > self.max {
return false;
}
true
}
#[inline]
#[must_use]
pub fn intersect(&self, other: &Self) -> bool {
if self.max < other.min || other.max < self.min {
return false;
}
true
}
#[inline]
#[must_use]
pub fn overlap(&self, other: &Self) -> Option<Self> {
if !self.intersect(other) {
return None;
}
let min = self.min.max(other.min);
let max = self.max.min(other.max);
Some(Self::new(min, max))
}
}
impl Display for Range {
#[inline]
fn fmt(&self, fmt: &mut Formatter) -> Result {
write!(fmt, "{} -> {}", self.min, self.max)
}
}