...
Source file src/pkg/math/mod.go
1
2
3
4
5 package math
6
7
10
11
12
13
14
15
16
17
18
19
20
21 func Mod(x, y float64) float64
22
23 func mod(x, y float64) float64 {
24 if y == 0 || IsInf(x, 0) || IsNaN(x) || IsNaN(y) {
25 return NaN()
26 }
27 y = Abs(y)
28
29 yfr, yexp := Frexp(y)
30 r := x
31 if x < 0 {
32 r = -x
33 }
34
35 for r >= y {
36 rfr, rexp := Frexp(r)
37 if rfr < yfr {
38 rexp = rexp - 1
39 }
40 r = r - Ldexp(y, rexp-yexp)
41 }
42 if x < 0 {
43 r = -r
44 }
45 return r
46 }
47
View as plain text