-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathinterval.pi
More file actions
38 lines (33 loc) · 788 Bytes
/
interval.pi
File metadata and controls
38 lines (33 loc) · 788 Bytes
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
use raytracepl::utils::*;
pub struct Interval {
pub min:f64;
pub max:f64;
}
pub fn new(min:f64, max:f64) Interval {
return Interval {
min: min,
max: max
};
}
impl Interval {
pub fn is_empty() bool {
return self.min > self.max;
}
pub fn contains(x:f64) bool {
return x >= self.min && x <= self.max;
}
pub fn surrounds(x:f64) bool {
return x > self.min && x < self.max;
}
pub fn clamp(x:f64) f64 {
if x < self.min {
return self.min;
}
if x > self.max {
return self.max;
}
return x;
}
}
var EMPTY = Interval { min: utils::INFINITY, max: -utils::INFINITY };
var UNIVERSE = Interval { min: -utils::INFINITY, max: utils::INFINITY };