blob: 8fa334c3509584bfc88d9b3060e9ebfdbf93a05f [file] [log] [blame]
Russ Cox88daac72008-11-19 16:14:31 -08001// Copyright 2009 The Go Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style
3// license that can be found in the LICENSE file.
4
5// $G $F.go && $L $F.$A && (./$A.out || echo BUG: math fails)
6
7package math
8
9import (
10 "math";
11 "testing";
12)
13
14var vf = []float64 {
15 4.9790119248836735e+00,
16 7.7388724745781045e+00,
17 -2.7688005719200159e-01,
18 -5.0106036182710749e+00,
19 9.6362937071984173e+00,
20 2.9263772392439646e+00,
21 5.2290834314593066e+00,
22 2.7279399104360102e+00,
23 1.8253080916808550e+00,
24 -8.6859247685756013e+00,
25}
26var asin = []float64 {
27 5.2117697218417440e-01,
28 8.8495619865825236e-01,
29 -2.7691544662819413e-02,
30 -5.2482360935268932e-01,
31 1.3002662421166553e+00,
32 2.9698415875871901e-01,
33 5.5025938468083364e-01,
34 2.7629597861677200e-01,
35 1.8355989225745148e-01,
36 -1.0523547536021498e+00,
37}
38var atan = []float64 {
39 1.3725902621296217e+00,
40 1.4422906096452980e+00,
41 -2.7011324359471755e-01,
42 -1.3738077684543379e+00,
43 1.4673921193587666e+00,
44 1.2415173565870167e+00,
45 1.3818396865615167e+00,
46 1.2194305844639670e+00,
47 1.0696031952318783e+00,
48 -1.4561721938838085e+00,
49}
50var exp = []float64 {
51 1.4533071302642137e+02,
52 2.2958822575694450e+03,
Russ Coxf379ea02008-11-20 10:54:02 -080053 7.5814542574851666e-01,
Russ Cox88daac72008-11-19 16:14:31 -080054 6.6668778421791010e-03,
55 1.5310493273896035e+04,
56 1.8659907517999329e+01,
57 1.8662167355098713e+02,
58 1.5301332413189379e+01,
59 6.2047063430646876e+00,
60 1.6894712385826522e-04,
61}
62var floor = []float64 {
63 4.0000000000000000e+00,
64 7.0000000000000000e+00,
65 -1.0000000000000000e+00,
66 -6.0000000000000000e+00,
67 9.0000000000000000e+00,
68 2.0000000000000000e+00,
69 5.0000000000000000e+00,
70 2.0000000000000000e+00,
71 1.0000000000000000e+00,
72 -9.0000000000000000e+00,
73}
74var log = []float64 {
75 1.6052314626930630e+00,
76 2.0462560018708768e+00,
77 -1.2841708730962657e+00,
78 1.6115563905281544e+00,
79 2.2655365644872018e+00,
80 1.0737652208918380e+00,
81 1.6542360106073545e+00,
82 1.0035467127723465e+00,
83 6.0174879014578053e-01,
84 2.1617038728473527e+00,
85}
86var pow = []float64 {
87 9.5282232631648415e+04,
88 5.4811599352999900e+07,
89 5.2859121715894400e-01,
90 9.7587991957286472e-06,
91 4.3280643293460450e+09,
92 8.4406761805034551e+02,
93 1.6946633276191194e+05,
94 5.3449040147551940e+02,
95 6.6881821384514159e+01,
96 2.0609869004248744e-09,
97}
98var sin = []float64 {
99 -9.6466616586009283e-01,
100 9.9338225271646543e-01,
101 -2.7335587039794395e-01,
102 9.5586257685042800e-01,
103 -2.0994210667799692e-01,
104 2.1355787807998605e-01,
105 -8.6945689711673619e-01,
106 4.0195666811555783e-01,
107 9.6778633541688000e-01,
108 -6.7344058690503452e-01,
109}
110var sinh = []float64 {
111 7.2661916084208533e+01,
112 1.1479409110035194e+03,
113 -2.8043136512812520e-01,
114 -7.4994290911815868e+01,
115 7.6552466042906761e+03,
116 9.3031583421672010e+00,
117 9.3308157558281088e+01,
118 7.6179893137269143e+00,
119 3.0217691805496156e+00,
120 -2.9595057572444951e+03,
121}
122var sqrt = []float64 {
123 2.2313699659365484e+00,
124 2.7818829009464263e+00,
125 5.2619393496314792e-01,
126 2.2384377628763938e+00,
127 3.1042380236055380e+00,
128 1.7106657298385224e+00,
129 2.2867189227054791e+00,
130 1.6516476350711160e+00,
131 1.3510396336454586e+00,
132 2.9471892997524950e+00,
133}
134var tan = []float64 {
135 -3.6613165650402277e+00,
136 8.6490023264859754e+00,
137 -2.8417941955033615e-01,
138 3.2532901859747287e+00,
139 2.1472756403802937e-01,
140 -2.1860091071106700e-01,
141 -1.7600028178723679e+00,
142 -4.3898089147528178e-01,
143 -3.8438855602011305e+00,
144 9.1098879337768517e-01,
145}
146var tanh = []float64 {
147 9.9990531206936328e-01,
148 9.9999962057085307e-01,
149 -2.7001505097318680e-01,
150 -9.9991110943061700e-01,
151 9.9999999146798441e-01,
152 9.9427249436125233e-01,
153 9.9994257600983156e-01,
154 9.9149409509772863e-01,
155 9.4936501296239700e-01,
156 -9.9999994291374019e-01,
157}
158
Russ Coxf379ea02008-11-20 10:54:02 -0800159func Tolerance(a,b,e float64) bool {
Russ Cox88daac72008-11-19 16:14:31 -0800160 d := a-b;
161 if d < 0 {
162 d = -d;
163 }
164
Russ Cox88daac72008-11-19 16:14:31 -0800165 if a != 0 {
166 e = e*a;
167 if e < 0 {
168 e = -e;
169 }
170 }
171 return d < e;
172}
Russ Coxf379ea02008-11-20 10:54:02 -0800173func Close(a,b float64) bool {
174 return Tolerance(a, b, 1e-14);
175}
176func VeryClose(a,b float64) bool {
177 return Tolerance(a, b, 4e-16);
178}
Russ Cox88daac72008-11-19 16:14:31 -0800179
180export func TestAsin(t *testing.T) {
181 for i := 0; i < len(vf); i++ {
Russ Coxf379ea02008-11-20 10:54:02 -0800182 if f := math.Asin(vf[i]/10); !VeryClose(asin[i], f) {
Russ Cox88daac72008-11-19 16:14:31 -0800183 t.Errorf("math.Asin(%g) = %g, want %g\n", vf[i]/10, f, asin[i]);
184 }
185 }
186}
187
188export func TestAtan(t *testing.T) {
189 for i := 0; i < len(vf); i++ {
Russ Coxf379ea02008-11-20 10:54:02 -0800190 if f := math.Atan(vf[i]); !VeryClose(atan[i], f) {
Russ Cox88daac72008-11-19 16:14:31 -0800191 t.Errorf("math.Atan(%g) = %g, want %g\n", vf[i], f, atan[i]);
192 }
193 }
194}
195
196export func TestExp(t *testing.T) {
197 for i := 0; i < len(vf); i++ {
Russ Coxf379ea02008-11-20 10:54:02 -0800198 if f := math.Exp(vf[i]); !VeryClose(exp[i], f) {
Russ Cox88daac72008-11-19 16:14:31 -0800199 t.Errorf("math.Exp(%g) = %g, want %g\n", vf[i], f, exp[i]);
200 }
201 }
202}
203
204export func TestFloor(t *testing.T) {
205 for i := 0; i < len(vf); i++ {
Russ Coxf379ea02008-11-20 10:54:02 -0800206 if f := math.Floor(vf[i]); floor[i] != f {
Russ Cox88daac72008-11-19 16:14:31 -0800207 t.Errorf("math.Floor(%g) = %g, want %g\n", vf[i], f, floor[i]);
208 }
209 }
210}
211
212export func TestLog(t *testing.T) {
213 for i := 0; i < len(vf); i++ {
214 a := math.Fabs(vf[i]);
Russ Coxf379ea02008-11-20 10:54:02 -0800215 if f := math.Log(a); log[i] != f {
216 t.Errorf("math.Log(%g) = %g, want %g\n", a, f, log[i]);
Russ Cox88daac72008-11-19 16:14:31 -0800217 }
218 }
Russ Coxf379ea02008-11-20 10:54:02 -0800219 const Ln10 = 2.30258509299404568401799145468436421;
220 if f := math.Log(10); f != Ln10 {
221 t.Errorf("math.Log(%g) = %g, want %g\n", 10, f, Ln10);
222 }
Russ Cox88daac72008-11-19 16:14:31 -0800223}
224
225export func TestPow(t *testing.T) {
226 for i := 0; i < len(vf); i++ {
227 if f := math.Pow(10, vf[i]); !Close(pow[i], f) {
228 t.Errorf("math.Pow(10, %.17g) = %.17g, want %.17g\n", vf[i], f, pow[i]);
229 }
230 }
231}
232
233export func TestSin(t *testing.T) {
234 for i := 0; i < len(vf); i++ {
235 if f := math.Sin(vf[i]); !Close(sin[i], f) {
236 t.Errorf("math.Sin(%g) = %g, want %g\n", vf[i], f, sin[i]);
237 }
238 }
239}
240
241export func TestSinh(t *testing.T) {
242 for i := 0; i < len(vf); i++ {
Russ Coxf379ea02008-11-20 10:54:02 -0800243 if f := math.Sinh(vf[i]); !VeryClose(sinh[i], f) {
Russ Cox88daac72008-11-19 16:14:31 -0800244 t.Errorf("math.Sinh(%g) = %g, want %g\n", vf[i], f, sinh[i]);
245 }
246 }
247}
248
249export func TestSqrt(t *testing.T) {
250 for i := 0; i < len(vf); i++ {
251 a := math.Fabs(vf[i]);
Russ Coxf379ea02008-11-20 10:54:02 -0800252 if f := math.Sqrt(a); !VeryClose(sqrt[i], f) {
Russ Cox88daac72008-11-19 16:14:31 -0800253 t.Errorf("math.Sqrt(%g) = %g, want %g\n", a, f, floor[i]);
254 }
255 }
256}
257
258export func TestTan(t *testing.T) {
259 for i := 0; i < len(vf); i++ {
260 if f := math.Tan(vf[i]); !Close(tan[i], f) {
261 t.Errorf("math.Tan(%g) = %g, want %g\n", vf[i], f, tan[i]);
262 }
263 }
264}
265
266export func TestTanh(t *testing.T) {
267 for i := 0; i < len(vf); i++ {
Russ Coxf379ea02008-11-20 10:54:02 -0800268 if f := math.Tanh(vf[i]); !VeryClose(tanh[i], f) {
Russ Cox88daac72008-11-19 16:14:31 -0800269 t.Errorf("math.Tanh(%g) = %g, want %g\n", vf[i], f, tanh[i]);
270 }
271 }
272}
273
274export func TestHypot(t *testing.T) {
275 for i := 0; i < len(vf); i++ {
276 a := math.Fabs(tanh[i]*math.Sqrt(2));
Russ Coxf379ea02008-11-20 10:54:02 -0800277 if f := math.Hypot(tanh[i], tanh[i]); !VeryClose(a, f) {
Russ Cox88daac72008-11-19 16:14:31 -0800278 t.Errorf("math.Hypot(%g, %g) = %g, want %g\n", tanh[i], tanh[i], f, a);
279 }
280 }
281}