zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 411e9ca4ade243344f358b14151e87e2334e76a0 (tree)
parent f3ab092f67d5705ce3c70c0033e463b68523c8bd
Author: Miles Alan <m@milesalan.com>
Date:   Fri, 15 Oct 2021 13:55:40 -0400

Fix bug where std.math.asinh64 doesn't respect signedness for negative values (#9940)

* std: Correct math.asinh64 to return correct signedness for negative values

* std: Add tests for negative values for math.asinh32 and math.asinh64
Diffstat:
Mlib/std/math/asinh.zig | 4+++-
1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/lib/std/math/asinh.zig b/lib/std/math/asinh.zig @@ -60,7 +60,7 @@ fn asinh32(x: f32) f32 { fn asinh64(x: f64) f64 { const u = @bitCast(u64, x); const e = (u >> 52) & 0x7FF; - const s = u >> 63; + const s = e >> 63; var rx = @bitCast(f64, u & (maxInt(u64) >> 1)); // |x| @@ -97,6 +97,7 @@ test "math.asinh32" { const epsilon = 0.000001; try expect(math.approxEqAbs(f32, asinh32(0.0), 0.0, epsilon)); + try expect(math.approxEqAbs(f32, asinh32(-0.2), -0.198690, epsilon)); try expect(math.approxEqAbs(f32, asinh32(0.2), 0.198690, epsilon)); try expect(math.approxEqAbs(f32, asinh32(0.8923), 0.803133, epsilon)); try expect(math.approxEqAbs(f32, asinh32(1.5), 1.194763, epsilon)); @@ -109,6 +110,7 @@ test "math.asinh64" { const epsilon = 0.000001; try expect(math.approxEqAbs(f64, asinh64(0.0), 0.0, epsilon)); + try expect(math.approxEqAbs(f64, asinh64(-0.2), -0.198690, epsilon)); try expect(math.approxEqAbs(f64, asinh64(0.2), 0.198690, epsilon)); try expect(math.approxEqAbs(f64, asinh64(0.8923), 0.803133, epsilon)); try expect(math.approxEqAbs(f64, asinh64(1.5), 1.194763, epsilon));