fixes float comparison tests
pull/1393/head
vitalyster 2019-07-31 10:20:40 +03:00 committed by Alexander Medvednikov
parent e0b45e33ea
commit 375bc1352c
3 changed files with 22 additions and 11 deletions

View File

@ -4,6 +4,12 @@
module builtin module builtin
#include <float.h>
import const (
DBL_EPSILON
)
pub fn (d double) str() string { pub fn (d double) str() string {
buf := malloc(sizeof(double) * 5 + 1)// TODO buf := malloc(sizeof(double) * 5 + 1)// TODO
C.sprintf(buf, '%f', d) C.sprintf(buf, '%f', d)
@ -28,6 +34,11 @@ pub fn ptr_str(ptr voidptr) string {
return tos(buf, strlen(buf)) return tos(buf, strlen(buf))
} }
// compare floats using C epsilon
pub fn (a f64) eq(b f64) bool {
return C.fabs(a - b) <= DBL_EPSILON
}
// fn (nn i32) str() string { // fn (nn i32) str() string {
// return i // return i
// } // }

View File

@ -115,8 +115,8 @@ fn test_complex_abs() {
mut c1 := cmplx.complex(3,4) mut c1 := cmplx.complex(3,4)
assert c1.abs() == 5 assert c1.abs() == 5
c1 = cmplx.complex(1,2) c1 = cmplx.complex(1,2)
assert c1.abs() == math.sqrt(5) assert c1.abs().eq(math.sqrt(5))
assert c1.abs() == c1.conjugate().abs() assert c1.abs().eq(c1.conjugate().abs())
c1 = cmplx.complex(7,0) c1 = cmplx.complex(7,0)
assert c1.abs() == 7 assert c1.abs() == 7
} }
@ -125,17 +125,17 @@ fn test_complex_angle(){
// Test is based on and verified from practice examples of Khan Academy // Test is based on and verified from practice examples of Khan Academy
// https://www.khanacademy.org/math/precalculus/imaginary-and-complex-numbers // https://www.khanacademy.org/math/precalculus/imaginary-and-complex-numbers
mut c := cmplx.complex(1, 0) mut c := cmplx.complex(1, 0)
assert c.angle() * 180 / math.Pi == 0 assert (c.angle() * 180 / math.Pi).eq(0)
c = cmplx.complex(1, 1) c = cmplx.complex(1, 1)
assert c.angle() * 180 / math.Pi == 45 assert (c.angle() * 180 / math.Pi).eq(45)
c = cmplx.complex(0, 1) c = cmplx.complex(0, 1)
assert c.angle() * 180 / math.Pi == 90 assert (c.angle() * 180 / math.Pi).eq(90)
c = cmplx.complex(-1, 1) c = cmplx.complex(-1, 1)
assert c.angle() * 180 / math.Pi == 135 assert (c.angle() * 180 / math.Pi).eq(135)
c = cmplx.complex(-1, -1) c = cmplx.complex(-1, -1)
assert c.angle() * 180 / math.Pi == -135 assert (c.angle() * 180 / math.Pi).eq(-135)
mut cc := c.conjugate() mut cc := c.conjugate()
assert cc.angle() + c.angle() == 0 assert (cc.angle() + c.angle()).eq(0)
} }

View File

@ -35,10 +35,10 @@ fn test_factorial() {
fn test_erf() { fn test_erf() {
assert math.erf(0) == 0 assert math.erf(0) == 0
assert math.erf(1.5) + math.erf(-1.5) == 0 assert (math.erf(1.5) + math.erf(-1.5)).eq(0)
assert math.erfc(0) == 1 assert math.erfc(0) == 1
assert math.erf(2.5) + math.erfc(2.5) == 1 assert (math.erf(2.5) + math.erfc(2.5)).eq(1)
assert math.erfc(3.6) + math.erfc(-3.6) == 2 assert (math.erfc(3.6) + math.erfc(-3.6)).eq(2)
} }
fn test_gamma() { fn test_gamma() {