blob: 41375057b62c466a7fa1418f10f9b2db85fea50a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
module math
pub fn hypot(x f64, y f64) f64 {
if is_inf(x, 0) || is_inf(y, 0) {
return inf(1)
}
if is_nan(x) || is_nan(y) {
return nan()
}
mut result := 0.0
if x != 0.0 || y != 0.0 {
abs_x := abs(x)
abs_y := abs(y)
min, max := minmax(abs_x, abs_y)
rat := min / max
root_term := sqrt(1.0 + rat * rat)
if max < max_f64 / root_term {
result = max * root_term
} else {
panic('overflow in hypot_e function')
}
}
return result
}
|