Commit c6f153dc authored by Tom Lane's avatar Tom Lane

Rethink how to test the hyperbolic functions.

The initial commit tried to test them on trivial cases such as 0,
reasoning that we shouldn't hit any portability issues that way.
The buildfarm immediately proved that hope ill-founded, and anyway
it's not a great testing scheme because it doesn't prove that we're
even calling the right library function for each SQL function.

Instead, let's test them at inputs such as 1 (or something within
the valid range, as needed), so that each function should produce
a different output.

As committed, this is just about certain to show portability
failures, because it's very unlikely that every platform computes
these functions the same as mine down to the last bit.  However,
I want to put it through a buildfarm cycle this way, so that
we can see how big the variations are.  The plan is to add
"set extra_float_digits = -1", or whatever we need in order to
hide the variations; but first we need data.

Discussion: https://postgr.es/m/E1h3nUY-0000sM-Vf@gemulon.postgresql.org
parent c6c9474a
...@@ -454,44 +454,44 @@ SELECT '' AS five, * FROM FLOAT8_TBL; ...@@ -454,44 +454,44 @@ SELECT '' AS five, * FROM FLOAT8_TBL;
| -1.2345678901234e-200 | -1.2345678901234e-200
(5 rows) (5 rows)
RESET extra_float_digits;
-- hyperbolic functions -- hyperbolic functions
SELECT sinh(float8 '0'); SELECT sinh(float8 '1');
sinh sinh
------ --------------------
0 1.1752011936438014
(1 row) (1 row)
SELECT cosh(float8 '0'); SELECT cosh(float8 '1');
cosh cosh
------ --------------------
1 1.5430806348152437
(1 row) (1 row)
SELECT tanh(float8 '0'); SELECT tanh(float8 '1');
tanh tanh
------ --------------------
0 0.7615941559557649
(1 row) (1 row)
SELECT asinh(float8 '0'); SELECT asinh(float8 '1');
asinh asinh
------- -------------------
0 0.881373587019543
(1 row) (1 row)
SELECT acosh(float8 '1'); SELECT acosh(float8 '2');
acosh acosh
------- --------------------
0 1.3169578969248166
(1 row) (1 row)
SELECT atanh(float8 '0'); SELECT atanh(float8 '0.5');
atanh atanh
------- --------------------
0 0.5493061443340548
(1 row) (1 row)
RESET extra_float_digits;
-- test for over- and underflow -- test for over- and underflow
INSERT INTO FLOAT8_TBL(f1) VALUES ('10e400'); INSERT INTO FLOAT8_TBL(f1) VALUES ('10e400');
ERROR: "10e400" is out of range for type double precision ERROR: "10e400" is out of range for type double precision
......
...@@ -154,16 +154,16 @@ SELECT '' AS bad, f.f1 / '0.0' from FLOAT8_TBL f; ...@@ -154,16 +154,16 @@ SELECT '' AS bad, f.f1 / '0.0' from FLOAT8_TBL f;
SELECT '' AS five, * FROM FLOAT8_TBL; SELECT '' AS five, * FROM FLOAT8_TBL;
-- hyperbolic functions
SELECT sinh(float8 '0');
SELECT cosh(float8 '0');
SELECT tanh(float8 '0');
SELECT asinh(float8 '0');
SELECT acosh(float8 '1');
SELECT atanh(float8 '0');
RESET extra_float_digits; RESET extra_float_digits;
-- hyperbolic functions
SELECT sinh(float8 '1');
SELECT cosh(float8 '1');
SELECT tanh(float8 '1');
SELECT asinh(float8 '1');
SELECT acosh(float8 '2');
SELECT atanh(float8 '0.5');
-- test for over- and underflow -- test for over- and underflow
INSERT INTO FLOAT8_TBL(f1) VALUES ('10e400'); INSERT INTO FLOAT8_TBL(f1) VALUES ('10e400');
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment