package test_internal_math_pow import "core:fmt" import "core:math" import "core:os" import "core:testing" @test pow_test :: proc(t: ^testing.T) { for exp in -2000..=2000 { { v1 := math.pow(2, f64(exp)) v2 := math.pow2_f64(exp) _v1 := transmute(u64)v1 _v2 := transmute(u64)v2 if exp == -1075 && ODIN_OS == .Windows { // LLVM on Windows returns 0h00000000_00000001 for pow(2, -1075), // unlike macOS and Linux where it returns 0h00000000_00000000 // pow2_f64 returns the same float on all platforms because it isn't this stupid _v1 = 0h00000000_00000000 } expect(t, _v1 == _v2, fmt.tprintf("Expected math.pow2_f64(%d) == math.pow(2, %d) (= %16x), got %16x", exp, exp, _v1, _v2)) } { v1 := math.pow(2, f32(exp)) v2 := math.pow2_f32(exp) _v1 := transmute(u32)v1 _v2 := transmute(u32)v2 expect(t, _v1 == _v2, fmt.tprintf("Expected math.pow2_f32(%d) == math.pow(2, %d) (= %08x), got %08x", exp, exp, _v1, _v2)) } { v1 := math.pow(2, f16(exp)) v2 := math.pow2_f16(exp) _v2 := transmute(u16)v2 _v1 := transmute(u16)v1 when ODIN_OS == .Darwin && ODIN_ARCH == .arm64 { if exp == -25 { testing.logf(t, "skipping known test failure on darwin+arm64, Expected math.pow2_f16(-25) == math.pow(2, -25) (= 0000), got 0001") _v2 = 0 } } expect(t, _v1 == _v2, fmt.tprintf("Expected math.pow2_f16(%d) == math.pow(2, %d) (= %04x), got %04x", exp, exp, _v1, _v2)) } } } // -------- -------- -------- -------- -------- -------- -------- -------- -------- -------- main :: proc() { t := testing.T{} pow_test(&t) fmt.printf("%v/%v tests successful.\n", TEST_count - TEST_fail, TEST_count) if TEST_fail > 0 { os.exit(1) } } TEST_count := 0 TEST_fail := 0 when ODIN_TEST { expect :: testing.expect log :: testing.log } else { expect :: proc(t: ^testing.T, condition: bool, message: string, loc := #caller_location) { TEST_count += 1 if !condition { TEST_fail += 1 fmt.printf("[%v] %v\n", loc, message) return } } log :: proc(t: ^testing.T, v: any, loc := #caller_location) { fmt.printf("[%v] ", loc) fmt.printf("log: %v\n", v) } }