float8.sql 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. --
  2. -- FLOAT8
  3. --
  4. CREATE TABLE FLOAT8_TBL(f1 float8);
  5. INSERT INTO FLOAT8_TBL(f1) VALUES (' 0.0 ');
  6. INSERT INTO FLOAT8_TBL(f1) VALUES ('1004.30 ');
  7. INSERT INTO FLOAT8_TBL(f1) VALUES (' -34.84');
  8. INSERT INTO FLOAT8_TBL(f1) VALUES ('1.2345678901234e+200');
  9. INSERT INTO FLOAT8_TBL(f1) VALUES ('1.2345678901234e-200');
  10. -- test for underflow and overflow handling
  11. SELECT '10e400'::float8;
  12. SELECT '-10e400'::float8;
  13. SELECT '10e-400'::float8;
  14. SELECT '-10e-400'::float8;
  15. -- test smallest normalized input
  16. SELECT float8send('2.2250738585072014E-308'::float8);
  17. -- bad input
  18. INSERT INTO FLOAT8_TBL(f1) VALUES ('');
  19. INSERT INTO FLOAT8_TBL(f1) VALUES (' ');
  20. INSERT INTO FLOAT8_TBL(f1) VALUES ('xyz');
  21. INSERT INTO FLOAT8_TBL(f1) VALUES ('5.0.0');
  22. INSERT INTO FLOAT8_TBL(f1) VALUES ('5 . 0');
  23. INSERT INTO FLOAT8_TBL(f1) VALUES ('5. 0');
  24. INSERT INTO FLOAT8_TBL(f1) VALUES (' - 3');
  25. INSERT INTO FLOAT8_TBL(f1) VALUES ('123 5');
  26. -- special inputs
  27. SELECT 'NaN'::float8;
  28. SELECT 'nan'::float8;
  29. SELECT ' NAN '::float8;
  30. SELECT 'infinity'::float8;
  31. SELECT ' -INFINiTY '::float8;
  32. -- bad special inputs
  33. SELECT 'N A N'::float8;
  34. SELECT 'NaN x'::float8;
  35. SELECT ' INFINITY x'::float8;
  36. SELECT 'Infinity'::float8 + 100.0;
  37. SELECT 'Infinity'::float8 / 'Infinity'::float8;
  38. SELECT '42'::float8 / 'Infinity'::float8;
  39. SELECT 'nan'::float8 / 'nan'::float8;
  40. SELECT 'nan'::float8 / '0'::float8;
  41. SELECT 'nan'::numeric::float8;
  42. SELECT * FROM FLOAT8_TBL;
  43. SELECT f.* FROM FLOAT8_TBL f WHERE f.f1 <> '1004.3';
  44. SELECT f.* FROM FLOAT8_TBL f WHERE f.f1 = '1004.3';
  45. SELECT f.* FROM FLOAT8_TBL f WHERE '1004.3' > f.f1;
  46. SELECT f.* FROM FLOAT8_TBL f WHERE f.f1 < '1004.3';
  47. SELECT f.* FROM FLOAT8_TBL f WHERE '1004.3' >= f.f1;
  48. SELECT f.* FROM FLOAT8_TBL f WHERE f.f1 <= '1004.3';
  49. SELECT f.f1, f.f1 * '-10' AS x
  50. FROM FLOAT8_TBL f
  51. WHERE f.f1 > '0.0';
  52. SELECT f.f1, f.f1 + '-10' AS x
  53. FROM FLOAT8_TBL f
  54. WHERE f.f1 > '0.0';
  55. SELECT f.f1, f.f1 - '-10' AS x
  56. FROM FLOAT8_TBL f
  57. WHERE f.f1 > '0.0';
  58. -- absolute value
  59. SELECT f.f1, @f.f1 AS abs_f1
  60. FROM FLOAT8_TBL f;
  61. -- truncate
  62. SELECT f.f1, trunc(f.f1) AS trunc_f1
  63. FROM FLOAT8_TBL f;
  64. -- round
  65. SELECT f.f1, round(f.f1) AS round_f1
  66. FROM FLOAT8_TBL f;
  67. -- avoid bit-exact output here because operations may not be bit-exact.
  68. SET extra_float_digits = 0;
  69. -- square root
  70. SELECT sqrt(float8 '64') AS eight;
  71. SELECT |/ float8 '64' AS eight;
  72. SELECT f.f1, |/f.f1 AS sqrt_f1
  73. FROM FLOAT8_TBL f
  74. WHERE f.f1 > '0.0';
  75. -- power
  76. SELECT power(float8 '144', float8 '0.5');
  77. SELECT power(float8 'NaN', float8 '0.5');
  78. SELECT power(float8 '144', float8 'NaN');
  79. SELECT power(float8 'NaN', float8 'NaN');
  80. SELECT power(float8 '-1', float8 'NaN');
  81. SELECT power(float8 '1', float8 'NaN');
  82. SELECT power(float8 'NaN', float8 '0');
  83. SELECT power(float8 'inf', float8 '0');
  84. SELECT power(float8 '-inf', float8 '0');
  85. SELECT power(float8 '0', float8 'inf');
  86. SELECT power(float8 '0', float8 '-inf');
  87. SELECT power(float8 '1', float8 'inf');
  88. SELECT power(float8 '1', float8 '-inf');
  89. SELECT power(float8 '-1', float8 'inf');
  90. SELECT power(float8 '-1', float8 '-inf');
  91. SELECT power(float8 '0.1', float8 'inf');
  92. SELECT power(float8 '-0.1', float8 'inf');
  93. SELECT power(float8 '1.1', float8 'inf');
  94. SELECT power(float8 '-1.1', float8 'inf');
  95. SELECT power(float8 '0.1', float8 '-inf');
  96. SELECT power(float8 '-0.1', float8 '-inf');
  97. SELECT power(float8 '1.1', float8 '-inf');
  98. SELECT power(float8 '-1.1', float8 '-inf');
  99. SELECT power(float8 'inf', float8 '-2');
  100. SELECT power(float8 'inf', float8 '2');
  101. SELECT power(float8 'inf', float8 'inf');
  102. SELECT power(float8 'inf', float8 '-inf');
  103. -- Intel's icc misoptimizes the code that controls the sign of this result,
  104. -- even with -mp1. Pending a fix for that, only test for "is it zero".
  105. SELECT power(float8 '-inf', float8 '-2') = '0';
  106. SELECT power(float8 '-inf', float8 '-3');
  107. SELECT power(float8 '-inf', float8 '2');
  108. SELECT power(float8 '-inf', float8 '3');
  109. SELECT power(float8 '-inf', float8 '3.5');
  110. SELECT power(float8 '-inf', float8 'inf');
  111. SELECT power(float8 '-inf', float8 '-inf');
  112. -- take exp of ln(f.f1)
  113. SELECT f.f1, exp(ln(f.f1)) AS exp_ln_f1
  114. FROM FLOAT8_TBL f
  115. WHERE f.f1 > '0.0';
  116. -- cube root
  117. SELECT ||/ float8 '27' AS three;
  118. SELECT f.f1, ||/f.f1 AS cbrt_f1 FROM FLOAT8_TBL f;
  119. SELECT * FROM FLOAT8_TBL;
  120. SELECT f.f1 * '1e200' from FLOAT8_TBL f;
  121. SELECT f.f1 ^ '1e200' from FLOAT8_TBL f;
  122. SELECT 0 ^ 0 + 0 ^ 1 + 0 ^ 0.0 + 0 ^ 0.5;
  123. SELECT ln(f.f1) from FLOAT8_TBL f where f.f1 = '0.0' ;
  124. SELECT ln(f.f1) from FLOAT8_TBL f where f.f1 < '0.0' ;
  125. SELECT f.f1 / '0.0' from FLOAT8_TBL f;
  126. -- hyperbolic functions
  127. -- we run these with extra_float_digits = 0 too, since different platforms
  128. -- tend to produce results that vary in the last place.
  129. SELECT sinh(float8 '1');
  130. SELECT cosh(float8 '1');
  131. SELECT tanh(float8 '1');
  132. SELECT asinh(float8 '1');
  133. SELECT acosh(float8 '2');
  134. SELECT atanh(float8 '0.5');
  135. -- test Inf/NaN cases for hyperbolic functions
  136. SELECT sinh(float8 'infinity');
  137. SELECT sinh(float8 '-infinity');
  138. SELECT sinh(float8 'nan');
  139. SELECT cosh(float8 'infinity');
  140. SELECT cosh(float8 '-infinity');
  141. SELECT cosh(float8 'nan');
  142. SELECT tanh(float8 'infinity');
  143. SELECT tanh(float8 '-infinity');
  144. SELECT tanh(float8 'nan');
  145. SELECT asinh(float8 'infinity');
  146. SELECT asinh(float8 '-infinity');
  147. SELECT asinh(float8 'nan');
  148. -- acosh(Inf) should be Inf, but some mingw versions produce NaN, so skip test
  149. -- SELECT acosh(float8 'infinity');
  150. SELECT acosh(float8 '-infinity');
  151. SELECT acosh(float8 'nan');
  152. SELECT atanh(float8 'infinity');
  153. SELECT atanh(float8 '-infinity');
  154. SELECT atanh(float8 'nan');
  155. RESET extra_float_digits;
  156. -- test for over- and underflow
  157. INSERT INTO FLOAT8_TBL(f1) VALUES ('10e400');
  158. INSERT INTO FLOAT8_TBL(f1) VALUES ('-10e400');
  159. INSERT INTO FLOAT8_TBL(f1) VALUES ('10e-400');
  160. INSERT INTO FLOAT8_TBL(f1) VALUES ('-10e-400');
  161. INSERT INTO FLOAT8_TBL(f1) VALUES ('0.0');
  162. INSERT INTO FLOAT8_TBL(f1) VALUES ('-34.84');
  163. INSERT INTO FLOAT8_TBL(f1) VALUES ('-1004.30');
  164. INSERT INTO FLOAT8_TBL(f1) VALUES ('-1.2345678901234e+200');
  165. INSERT INTO FLOAT8_TBL(f1) VALUES ('-1.2345678901234e-200');
  166. -- test edge-case coercions to integer
  167. SELECT '32767.4'::float8::int2;
  168. SELECT '32767.6'::float8::int2;
  169. SELECT '-32768.4'::float8::int2;
  170. SELECT '-32768.6'::float8::int2;
  171. SELECT '2147483647.4'::float8::int4;
  172. SELECT '2147483647.6'::float8::int4;
  173. SELECT '-2147483648.4'::float8::int4;
  174. SELECT '-2147483648.6'::float8::int4;
  175. SELECT '9223372036854773760'::float8::int8;
  176. SELECT '9223372036854775807'::float8::int8;
  177. SELECT '-9223372036854775808.5'::float8::int8;
  178. SELECT '-9223372036854780000'::float8::int8;
  179. -- test exact cases for trigonometric functions in degrees
  180. SELECT x,
  181. sind(x),
  182. sind(x) IN (-1,-0.5,0,0.5,1) AS sind_exact
  183. FROM (VALUES (0), (30), (90), (150), (180),
  184. (210), (270), (330), (360)) AS t(x);
  185. SELECT x,
  186. cosd(x),
  187. cosd(x) IN (-1,-0.5,0,0.5,1) AS cosd_exact
  188. FROM (VALUES (0), (60), (90), (120), (180),
  189. (240), (270), (300), (360)) AS t(x);
  190. SELECT x,
  191. tand(x),
  192. tand(x) IN ('-Infinity'::float8,-1,0,
  193. 1,'Infinity'::float8) AS tand_exact,
  194. cotd(x),
  195. cotd(x) IN ('-Infinity'::float8,-1,0,
  196. 1,'Infinity'::float8) AS cotd_exact
  197. FROM (VALUES (0), (45), (90), (135), (180),
  198. (225), (270), (315), (360)) AS t(x);
  199. SELECT x,
  200. atand(x),
  201. atand(x) IN (-90,-45,0,45,90) AS atand_exact
  202. FROM (VALUES ('-Infinity'::float8), (-1), (0), (1),
  203. ('Infinity'::float8)) AS t(x);
  204. SELECT x, y,
  205. atan2d(y, x),
  206. atan2d(y, x) IN (-90,0,90,180) AS atan2d_exact
  207. FROM (SELECT 10*cosd(a), 10*sind(a)
  208. FROM generate_series(0, 360, 90) AS t(a)) AS t(x,y);