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