blob: 58bd4dac01bc23ebf9846ad4d7d107fe870d621b [file] [log] [blame]
Robert Griesemerd2490e72008-03-19 15:45:07 -07001// $G $F.go && $L $F.$A && ./$A.out
2
3// Copyright 2009 The Go Authors. All rights reserved.
4// Use of this source code is governed by a BSD-style
5// license that can be found in the LICENSE file.
6
7package main
8
Ken Thompsonad073b12008-06-08 16:16:17 -07009func
Robert Griesemer542099d2009-12-09 19:27:08 -080010pow10(pow int) float64 {
Ken Thompsonb1a34632008-06-10 13:23:19 -070011 if pow < 0 { return 1/pow10(-pow); }
12 if pow > 0 { return pow10(pow-1)*10; }
13 return 1;
14}
15
16func
Robert Griesemer542099d2009-12-09 19:27:08 -080017close(da float64, ia, ib int64, pow int) bool {
Russ Cox9cdb8bd2008-10-29 13:58:12 -070018 db := float64(ia) / float64(ib);
Ken Thompson343f5aa2008-06-12 21:48:56 -070019 db *= pow10(pow);
Ken Thompsonb1a34632008-06-10 13:23:19 -070020
Russ Coxef46a9d2009-11-15 17:24:14 -080021 if da == 0 || db == 0 {
22 if da == 0 && db == 0 {
Ken Thompsonad073b12008-06-08 16:16:17 -070023 return true;
24 }
25 return false;
26 }
Ken Thompsonb1a34632008-06-10 13:23:19 -070027
Ken Thompson343f5aa2008-06-12 21:48:56 -070028 de := (da-db) /da;
Ken Thompsonb1a34632008-06-10 13:23:19 -070029 if de < 0 {
30 de = -de;
Ken Thompsonad073b12008-06-08 16:16:17 -070031 }
Ken Thompsonb1a34632008-06-10 13:23:19 -070032
Ken Thompson343f5aa2008-06-12 21:48:56 -070033 if de < 1.0e-14 {
Ken Thompsonad073b12008-06-08 16:16:17 -070034 return true;
35 }
36 return false;
37}
38
Ken Thompsonb1a34632008-06-10 13:23:19 -070039func
Robert Griesemer542099d2009-12-09 19:27:08 -080040main() {
Robert Griesemerd2490e72008-03-19 15:45:07 -070041
Rob Pikebc2f5f12008-08-11 22:07:49 -070042 if !close(0., 0, 1, 0) { print("0. is ", 0., "\n"); }
43 if !close(+10., 10, 1, 0) { print("+10. is ", +10., "\n"); }
44 if !close(-210., -210, 1, 0) { print("-210. is ", -210., "\n"); }
Robert Griesemerd2490e72008-03-19 15:45:07 -070045
Rob Pikebc2f5f12008-08-11 22:07:49 -070046 if !close(.0, 0, 1, 0) { print(".0 is ", .0, "\n"); }
47 if !close(+.01, 1, 100, 0) { print("+.01 is ", +.01, "\n"); }
48 if !close(-.012, -12, 1000, 0) { print("-.012 is ", -.012, "\n"); }
Robert Griesemerd2490e72008-03-19 15:45:07 -070049
Rob Pikebc2f5f12008-08-11 22:07:49 -070050 if !close(0.0, 0, 1, 0) { print("0.0 is ", 0.0, "\n"); }
51 if !close(+10.01, 1001, 100, 0) { print("+10.01 is ", +10.01, "\n"); }
52 if !close(-210.012, -210012, 1000, 0) { print("-210.012 is ", -210.012, "\n"); }
Robert Griesemerd2490e72008-03-19 15:45:07 -070053
Rob Pikebc2f5f12008-08-11 22:07:49 -070054 if !close(0E+1, 0, 1, 0) { print("0E+1 is ", 0E+1, "\n"); }
55 if !close(+10e2, 10, 1, 2) { print("+10e2 is ", +10e2, "\n"); }
56 if !close(-210e3, -210, 1, 3) { print("-210e3 is ", -210e3, "\n"); }
Robert Griesemerd2490e72008-03-19 15:45:07 -070057
Rob Pikebc2f5f12008-08-11 22:07:49 -070058 if !close(0E-1, 0, 1, 0) { print("0E-1 is ", 0E-1, "\n"); }
Russ Coxef46a9d2009-11-15 17:24:14 -080059 if !close(+0e23, 0, 1, 1) { print("+0e23 is ", +0e23, "\n"); }
60 if !close(-0e345, 0, 1, 1) { print("-0e345 is ", -0e345, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070061
Rob Pikebc2f5f12008-08-11 22:07:49 -070062 if !close(0E1, 0, 1, 1) { print("0E1 is ", 0E1, "\n"); }
63 if !close(+10e23, 10, 1, 23) { print("+10e23 is ", +10e23, "\n"); }
64 if !close(-210e34, -210, 1, 34) { print("-210e34 is ", -210e34, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070065
Rob Pikebc2f5f12008-08-11 22:07:49 -070066 if !close(0.E1, 0, 1, 1) { print("0.E1 is ", 0.E1, "\n"); }
67 if !close(+10.e+2, 10, 1, 2) { print("+10.e+2 is ", +10.e+2, "\n"); }
68 if !close(-210.e-3, -210, 1, -3) { print("-210.e-3 is ", -210.e-3, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070069
Rob Pikebc2f5f12008-08-11 22:07:49 -070070 if !close(.0E1, 0, 1, 1) { print(".0E1 is ", .0E1, "\n"); }
71 if !close(+.01e2, 1, 100, 2) { print("+.01e2 is ", +.01e2, "\n"); }
72 if !close(-.012e3, -12, 1000, 3) { print("-.012e3 is ", -.012e3, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070073
Rob Pikebc2f5f12008-08-11 22:07:49 -070074 if !close(0.0E1, 0, 1, 0) { print("0.0E1 is ", 0.0E1, "\n"); }
75 if !close(+10.01e2, 1001, 100, 2) { print("+10.01e2 is ", +10.01e2, "\n"); }
76 if !close(-210.012e3, -210012, 1000, 3) { print("-210.012e3 is ", -210.012e3, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070077
Rob Pikebc2f5f12008-08-11 22:07:49 -070078 if !close(0.E+12, 0, 1, 0) { print("0.E+12 is ", 0.E+12, "\n"); }
79 if !close(+10.e23, 10, 1, 23) { print("+10.e23 is ", +10.e23, "\n"); }
80 if !close(-210.e33, -210, 1, 33) { print("-210.e33 is ", -210.e33, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070081
Rob Pikebc2f5f12008-08-11 22:07:49 -070082 if !close(.0E-12, 0, 1, 0) { print(".0E-12 is ", .0E-12, "\n"); }
83 if !close(+.01e23, 1, 100, 23) { print("+.01e23 is ", +.01e23, "\n"); }
84 if !close(-.012e34, -12, 1000, 34) { print("-.012e34 is ", -.012e34, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070085
Rob Pikebc2f5f12008-08-11 22:07:49 -070086 if !close(0.0E12, 0, 1, 12) { print("0.0E12 is ", 0.0E12, "\n"); }
87 if !close(+10.01e23, 1001, 100, 23) { print("+10.01e23 is ", +10.01e23, "\n"); }
88 if !close(-210.012e33, -210012, 1000, 33) { print("-210.012e33 is ", -210.012e33, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070089
Rob Pikebc2f5f12008-08-11 22:07:49 -070090 if !close(0.E123, 0, 1, 123) { print("0.E123 is ", 0.E123, "\n"); }
91 if !close(+10.e+23, 10, 1, 23) { print("+10.e+234 is ", +10.e+234, "\n"); }
92 if !close(-210.e-35, -210, 1, -35) { print("-210.e-35 is ", -210.e-35, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070093
Rob Pikebc2f5f12008-08-11 22:07:49 -070094 if !close(.0E123, 0, 1, 123) { print(".0E123 is ", .0E123, "\n"); }
95 if !close(+.01e29, 1, 100, 29) { print("+.01e29 is ", +.01e29, "\n"); }
96 if !close(-.012e29, -12, 1000, 29) { print("-.012e29 is ", -.012e29, "\n"); }
Ken Thompsonad073b12008-06-08 16:16:17 -070097
Rob Pikebc2f5f12008-08-11 22:07:49 -070098 if !close(0.0E123, 0, 1, 123) { print("0.0E123 is ", 0.0E123, "\n"); }
99 if !close(+10.01e31, 1001, 100, 31) { print("+10.01e31 is ", +10.01e31, "\n"); }
100 if !close(-210.012e19, -210012, 1000, 19) { print("-210.012e19 is ", -210.012e19, "\n"); }
Robert Griesemerd2490e72008-03-19 15:45:07 -0700101}