Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/lib/libm/complex compare to zero, instead of using signbit, ...
details: https://anonhg.NetBSD.org/src/rev/94a9f64fe59c
branches: trunk
changeset: 350006:94a9f64fe59c
user: maya <maya%NetBSD.org@localhost>
date: Sun Jan 01 19:32:14 2017 +0000
description:
compare to zero, instead of using signbit, and be more specific in comment.
-0.0 > 0 is also false. no functional change.
while this is mostly a change to be consistent in style (the rest of the
comparisons aren't done with signbit), it is also a micro-optimization.
with our default compile flags, calls to copysign are libm calls (and a
whole function call!!). this generates more efficient code.
diffstat:
lib/libm/complex/csqrt.c | 13 ++++++++-----
lib/libm/complex/csqrtf.c | 13 ++++++++-----
2 files changed, 16 insertions(+), 10 deletions(-)
diffs (68 lines):
diff -r 8e648f7b2d83 -r 94a9f64fe59c lib/libm/complex/csqrt.c
--- a/lib/libm/complex/csqrt.c Sun Jan 01 12:39:33 2017 +0000
+++ b/lib/libm/complex/csqrt.c Sun Jan 01 19:32:14 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: csqrt.c,v 1.3 2016/12/31 20:01:15 maya Exp $ */
+/* $NetBSD: csqrt.c,v 1.4 2017/01/01 19:32:14 maya Exp $ */
/*-
* Copyright (c) 2007 The NetBSD Foundation, Inc.
@@ -41,7 +41,10 @@
x = creal (z);
y = cimag (z);
- /* Input is a real number that isn't on the branch cut */
+ /*
+ * input is a real number and imaginary part isn't -0.0.
+ * negative zero is on the branch cut.
+ */
if ((y == 0.0) && !signbit(y)) {
if (x == 0.0) {
w = 0.0 + y * I;
@@ -93,9 +96,9 @@
t = scale * fabs((0.5 * y) / r);
r *= scale;
}
- if (signbit(y))
+ if (y > 0)
+ w = t + r * I;
+ else
w = t - r * I;
- else
- w = t + r * I;
return w;
}
diff -r 8e648f7b2d83 -r 94a9f64fe59c lib/libm/complex/csqrtf.c
--- a/lib/libm/complex/csqrtf.c Sun Jan 01 12:39:33 2017 +0000
+++ b/lib/libm/complex/csqrtf.c Sun Jan 01 19:32:14 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: csqrtf.c,v 1.3 2016/12/31 22:54:56 maya Exp $ */
+/* $NetBSD: csqrtf.c,v 1.4 2017/01/01 19:32:14 maya Exp $ */
/*-
* Copyright (c) 2007 The NetBSD Foundation, Inc.
@@ -41,7 +41,10 @@
x = crealf (z);
y = cimagf (z);
- /* Input is a real number that isn't on the branch cut */
+ /*
+ * input is a real number and imaginary part isn't -0.0.
+ * negative zero is on the branch cut.
+ */
if ((y == 0.0f) && !signbit(y)) {
if (x < 0.0f) {
w = 0.0f + sqrtf(-x) * I;
@@ -93,9 +96,9 @@
r *= scale;
}
- if (signbit(y))
+ if (y > 0)
+ w = t + r * I;
+ else
w = t - r * I;
- else
- w = t + r * I;
return w;
}
Home |
Main Index |
Thread Index |
Old Index