Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/lib/libm/complex csqrt has a branch cut on the negative real...
details: https://anonhg.NetBSD.org/src/rev/7f49c0b9f3ae
branches: trunk
changeset: 349998:7f49c0b9f3ae
user: maya <maya%NetBSD.org@localhost>
date: Sat Dec 31 20:01:15 2016 +0000
description:
csqrt has a branch cut on the negative real axis, and this requires
delicacy in order to maintain continuity around it.
we have an initial case to deal with a fairly common case: getting
a real number. Avoid dealing with the branch cut in this case by
checking if the real part is negative.
later, -0.0 < 0 is not met, so instead, test for a negative number
using signbit, so negative zero is also treated as a negative number.
Fixes last part of PR lib/51427: libm issues triggered by py-numpy
ok riastradh
diffstat:
lib/libm/complex/csqrt.c | 7 ++++---
lib/libm/complex/csqrtf.c | 7 ++++---
2 files changed, 8 insertions(+), 6 deletions(-)
diffs (56 lines):
diff -r f1ef64512ba8 -r 7f49c0b9f3ae lib/libm/complex/csqrt.c
--- a/lib/libm/complex/csqrt.c Sat Dec 31 17:46:35 2016 +0000
+++ b/lib/libm/complex/csqrt.c Sat Dec 31 20:01:15 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: csqrt.c,v 1.2 2016/12/31 15:33:03 maya Exp $ */
+/* $NetBSD: csqrt.c,v 1.3 2016/12/31 20:01:15 maya Exp $ */
/*-
* Copyright (c) 2007 The NetBSD Foundation, Inc.
@@ -41,7 +41,8 @@
x = creal (z);
y = cimag (z);
- if (y == 0.0) {
+ /* Input is a real number that isn't on the branch cut */
+ if ((y == 0.0) && !signbit(y)) {
if (x == 0.0) {
w = 0.0 + y * I;
} else {
@@ -92,7 +93,7 @@
t = scale * fabs((0.5 * y) / r);
r *= scale;
}
- if (y < 0)
+ if (signbit(y))
w = t - r * I;
else
w = t + r * I;
diff -r f1ef64512ba8 -r 7f49c0b9f3ae lib/libm/complex/csqrtf.c
--- a/lib/libm/complex/csqrtf.c Sat Dec 31 17:46:35 2016 +0000
+++ b/lib/libm/complex/csqrtf.c Sat Dec 31 20:01:15 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: csqrtf.c,v 1.1 2007/08/20 16:01:37 drochner Exp $ */
+/* $NetBSD: csqrtf.c,v 1.2 2016/12/31 20:01:15 maya Exp $ */
/*-
* Copyright (c) 2007 The NetBSD Foundation, Inc.
@@ -41,7 +41,8 @@
x = crealf (z);
y = cimagf (z);
- if (y == 0.0f) {
+ /* Input is a real number that isn't on the branch cut */
+ if ((y == 0.0f) && !signbit(y)) {
if (x < 0.0f) {
w = 0.0f + sqrtf(-x) * I;
return w;
@@ -91,7 +92,7 @@
r *= scale;
}
- if (y < 0)
+ if (signbit(y))
w = t - r * I;
else
w = t + r * I;
Home |
Main Index |
Thread Index |
Old Index