Commit 03dfd2ecc3

Lewis Gaul <lewis.gaul@gmail.com>
2024-05-26 00:05:20
Make sure to test the sign of the zero results
1 parent 7abb170
Changed files (7)
lib/compiler_rt/exp.zig
@@ -218,7 +218,7 @@ test "expf() special" {
     try expectEqual(expf(1.0), math.e);
     try expectEqual(expf(math.ln2), 2.0);
     try expectEqual(expf(math.inf(f32)), math.inf(f32));
-    try expectEqual(expf(-math.inf(f32)), 0.0);
+    try expect(math.isPositiveZero(expf(-math.inf(f32))));
     try expect(math.isNan(expf(math.nan(f32))));
     try expect(math.isNan(expf(math.snan(f32))));
 }
@@ -268,7 +268,7 @@ test "exp() special" {
     // try expectEqual(exp(1.0), math.e);
     try expectEqual(exp(math.ln2), 2.0);
     try expectEqual(exp(math.inf(f64)), math.inf(f64));
-    try expectEqual(exp(-math.inf(f64)), 0.0);
+    try expect(math.isPositiveZero(exp(-math.inf(f64))));
     try expect(math.isNan(exp(math.nan(f64))));
     try expect(math.isNan(exp(math.snan(f64))));
 }
lib/compiler_rt/exp2.zig
@@ -464,7 +464,7 @@ test "exp2f() special" {
     try expectEqual(exp2f(1.0), 2.0);
     try expectEqual(exp2f(-1.0), 0.5);
     try expectEqual(exp2f(math.inf(f32)), math.inf(f32));
-    try expectEqual(exp2f(-math.inf(f32)), 0.0);
+    try expect(math.isPositiveZero(exp2f(-math.inf(f32))));
     try expect(math.isNan(exp2f(math.nan(f32))));
     try expect(math.isNan(exp2f(math.snan(f32))));
 }
@@ -502,7 +502,7 @@ test "exp2() special" {
     try expectEqual(exp2(1.0), 2.0);
     try expectEqual(exp2(-1.0), 0.5);
     try expectEqual(exp2(math.inf(f64)), math.inf(f64));
-    try expectEqual(exp2(-math.inf(f64)), 0.0);
+    try expect(math.isPositiveZero(exp2(-math.inf(f64))));
     try expect(math.isNan(exp2(math.nan(f64))));
     try expect(math.isNan(exp2(math.snan(f64))));
 }
lib/compiler_rt/log.zig
@@ -163,7 +163,7 @@ pub fn logl(x: c_longdouble) callconv(.c) c_longdouble {
 test "logf() special" {
     try expectEqual(logf(0.0), -math.inf(f32));
     try expectEqual(logf(-0.0), -math.inf(f32));
-    try expectEqual(logf(1.0), 0.0);
+    try expect(math.isPositiveZero(logf(1.0)));
     try expectEqual(logf(math.e), 1.0);
     try expectEqual(logf(math.inf(f32)), math.inf(f32));
     try expect(math.isNan(logf(-1.0)));
@@ -198,7 +198,7 @@ test "logf() boundary" {
 test "log() special" {
     try expectEqual(log(0.0), -math.inf(f64));
     try expectEqual(log(-0.0), -math.inf(f64));
-    try expectEqual(log(1.0), 0.0);
+    try expect(math.isPositiveZero(log(1.0)));
     try expectEqual(log(math.e), 1.0);
     try expectEqual(log(math.inf(f64)), math.inf(f64));
     try expect(math.isNan(log(-1.0)));
lib/compiler_rt/log10.zig
@@ -191,7 +191,7 @@ pub fn log10l(x: c_longdouble) callconv(.c) c_longdouble {
 test "log10f() special" {
     try expectEqual(log10f(0.0), -math.inf(f32));
     try expectEqual(log10f(-0.0), -math.inf(f32));
-    try expectEqual(log10f(1.0), 0.0);
+    try expect(math.isPositiveZero(log10f(1.0)));
     try expectEqual(log10f(10.0), 1.0);
     try expectEqual(log10f(0.1), -1.0);
     try expectEqual(log10f(math.inf(f32)), math.inf(f32));
@@ -227,7 +227,7 @@ test "log10f() boundary" {
 test "log10() special" {
     try expectEqual(log10(0.0), -math.inf(f64));
     try expectEqual(log10(-0.0), -math.inf(f64));
-    try expectEqual(log10(1.0), 0.0);
+    try expect(math.isPositiveZero(log10(1.0)));
     try expectEqual(log10(10.0), 1.0);
     try expectEqual(log10(0.1), -1.0);
     try expectEqual(log10(math.inf(f64)), math.inf(f64));
lib/compiler_rt/log2.zig
@@ -183,7 +183,7 @@ pub fn log2l(x: c_longdouble) callconv(.c) c_longdouble {
 test "log2f() special" {
     try expectEqual(log2f(0.0), -math.inf(f32));
     try expectEqual(log2f(-0.0), -math.inf(f32));
-    try expectEqual(log2f(1.0), 0.0);
+    try expect(math.isPositiveZero(log2f(1.0)));
     try expectEqual(log2f(2.0), 1.0);
     try expectEqual(log2f(math.inf(f32)), math.inf(f32));
     try expect(math.isNan(log2f(-1.0)));
@@ -219,7 +219,7 @@ test "log2f() boundary" {
 test "log2() special" {
     try expectEqual(log2(0.0), -math.inf(f64));
     try expectEqual(log2(-0.0), -math.inf(f64));
-    try expectEqual(log2(1.0), 0.0);
+    try expect(math.isPositiveZero(log2(1.0)));
     try expectEqual(log2(2.0), 1.0);
     try expectEqual(log2(math.inf(f64)), math.inf(f64));
     try expect(math.isNan(log2(-1.0)));
lib/std/math/expm1.zig
@@ -288,8 +288,8 @@ fn expm1_64(x_: f64) f64 {
 }
 
 test "expm1_32() special" {
-    try expectEqual(expm1_32(0.0), 0.0);
-    try expectEqual(expm1_32(-0.0), 0.0);
+    try expect(math.isPositiveZero(expm1_32(0.0)));
+    try expect(math.isNegativeZero(expm1_32(-0.0)));
     try expectEqual(expm1_32(math.ln2), 1.0);
     try expectEqual(expm1_32(math.inf(f32)), math.inf(f32));
     try expectEqual(expm1_32(-math.inf(f32)), -1.0);
@@ -326,8 +326,8 @@ test "expm1_32() boundary" {
 }
 
 test "expm1_64() special" {
-    try expectEqual(expm1_64(0.0), 0.0);
-    try expectEqual(expm1_64(-0.0), 0.0);
+    try expect(math.isPositiveZero(expm1_64(0.0)));
+    try expect(math.isNegativeZero(expm1_64(-0.0)));
     try expectEqual(expm1_64(math.ln2), 1.0);
     try expectEqual(expm1_64(math.inf(f64)), math.inf(f64));
     try expectEqual(expm1_64(-math.inf(f64)), -1.0);
lib/std/math/log1p.zig
@@ -184,8 +184,8 @@ fn log1p_64(x: f64) f64 {
 }
 
 test "log1p_32() special" {
-    try expectEqual(log1p_32(0.0), 0.0);
-    try expectEqual(log1p_32(-0.0), 0.0);
+    try expect(math.isPositiveZero(log1p_32(0.0)));
+    try expect(math.isNegativeZero(log1p_32(-0.0)));
     try expectEqual(log1p_32(-1.0), -math.inf(f32));
     try expectEqual(log1p_32(1.0), math.ln2);
     try expectEqual(log1p_32(math.inf(f32)), math.inf(f32));
@@ -219,8 +219,8 @@ test "log1p_32() boundary" {
 }
 
 test "log1p_64() special" {
-    try expectEqual(log1p_64(0.0), 0.0);
-    try expectEqual(log1p_64(-0.0), 0.0);
+    try expect(math.isPositiveZero(log1p_64(0.0)));
+    try expect(math.isNegativeZero(log1p_64(-0.0)));
     try expectEqual(log1p_64(-1.0), -math.inf(f64));
     try expectEqual(log1p_64(1.0), math.ln2);
     try expectEqual(log1p_64(math.inf(f64)), math.inf(f64));