inexact.decTest 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. ------------------------------------------------------------------------
  2. -- inexact.decTest -- decimal inexact and rounded edge cases --
  3. -- Copyright (c) IBM Corporation, 1981, 2008. All rights reserved. --
  4. ------------------------------------------------------------------------
  5. -- Please see the document "General Decimal Arithmetic Testcases" --
  6. -- at http://www2.hursley.ibm.com/decimal for the description of --
  7. -- these testcases. --
  8. -- --
  9. -- These testcases are experimental ('beta' versions), and they --
  10. -- may contain errors. They are offered on an as-is basis. In --
  11. -- particular, achieving the same results as the tests here is not --
  12. -- a guarantee that an implementation complies with any Standard --
  13. -- or specification. The tests are not exhaustive. --
  14. -- --
  15. -- Please send comments, suggestions, and corrections to the author: --
  16. -- Mike Cowlishaw, IBM Fellow --
  17. -- IBM UK, PO Box 31, Birmingham Road, Warwick CV34 5JL, UK --
  18. -- mfc@uk.ibm.com --
  19. ------------------------------------------------------------------------
  20. version: 2.59
  21. extended: 1
  22. precision: 9
  23. rounding: half_up
  24. maxExponent: 999
  25. minexponent: -999
  26. inx001 add 1 1 -> 2
  27. inx002 add 123456789 0 -> 123456789
  28. inx003 add 123456789 0.0 -> 123456789 Rounded
  29. inx004 add 123456789 0.00 -> 123456789 Rounded
  30. inx005 add 123456789 1 -> 123456790
  31. inx006 add 123456789 0.1 -> 123456789 Inexact Rounded
  32. inx007 add 123456789 0.01 -> 123456789 Inexact Rounded
  33. inx008 add 123456789 0.001 -> 123456789 Inexact Rounded
  34. inx009 add 123456789 0.000001 -> 123456789 Inexact Rounded
  35. inx010 add 123456789 0.000000001 -> 123456789 Inexact Rounded
  36. inx011 add 123456789 0.000000000001 -> 123456789 Inexact Rounded
  37. inx012 add 123456789 0.9 -> 123456790 Inexact Rounded
  38. inx013 add 123456789 0.09 -> 123456789 Inexact Rounded
  39. inx014 add 123456789 0.009 -> 123456789 Inexact Rounded
  40. inx015 add 123456789 0.000009 -> 123456789 Inexact Rounded
  41. inx016 add 123456789 0.000000009 -> 123456789 Inexact Rounded
  42. inx017 add 123456789 0.000000000009 -> 123456789 Inexact Rounded
  43. inx021 add 1 -1 -> 0
  44. inx022 add 123456789 -0 -> 123456789
  45. inx023 add 123456789 -0.0 -> 123456789 Rounded
  46. inx024 add 123456789 -0.00 -> 123456789 Rounded
  47. inx025 add 123456789 -1 -> 123456788
  48. inx026 add 123456789 -0.1 -> 123456789 Inexact Rounded
  49. inx027 add 123456789 -0.01 -> 123456789 Inexact Rounded
  50. inx028 add 123456789 -0.001 -> 123456789 Inexact Rounded
  51. inx029 add 123456789 -0.000001 -> 123456789 Inexact Rounded
  52. inx030 add 123456789 -0.000000001 -> 123456789 Inexact Rounded
  53. inx031 add 123456789 -0.000000000001 -> 123456789 Inexact Rounded
  54. inx032 add 123456789 -0.9 -> 123456788 Inexact Rounded
  55. inx033 add 123456789 -0.09 -> 123456789 Inexact Rounded
  56. inx034 add 123456789 -0.009 -> 123456789 Inexact Rounded
  57. inx035 add 123456789 -0.000009 -> 123456789 Inexact Rounded
  58. inx036 add 123456789 -0.000000009 -> 123456789 Inexact Rounded
  59. inx037 add 123456789 -0.000000000009 -> 123456789 Inexact Rounded
  60. inx042 add 0 123456789 -> 123456789
  61. inx043 add 0.0 123456789 -> 123456789 Rounded
  62. inx044 add 0.00 123456789 -> 123456789 Rounded
  63. inx045 add 1 123456789 -> 123456790
  64. inx046 add 0.1 123456789 -> 123456789 Inexact Rounded
  65. inx047 add 0.01 123456789 -> 123456789 Inexact Rounded
  66. inx048 add 0.001 123456789 -> 123456789 Inexact Rounded
  67. inx049 add 0.000001 123456789 -> 123456789 Inexact Rounded
  68. inx050 add 0.000000001 123456789 -> 123456789 Inexact Rounded
  69. inx051 add 0.000000000001 123456789 -> 123456789 Inexact Rounded
  70. inx052 add 0.9 123456789 -> 123456790 Inexact Rounded
  71. inx053 add 0.09 123456789 -> 123456789 Inexact Rounded
  72. inx054 add 0.009 123456789 -> 123456789 Inexact Rounded
  73. inx055 add 0.000009 123456789 -> 123456789 Inexact Rounded
  74. inx056 add 0.000000009 123456789 -> 123456789 Inexact Rounded
  75. inx057 add 0.000000000009 123456789 -> 123456789 Inexact Rounded
  76. inx062 add -0 123456789 -> 123456789
  77. inx063 add -0.0 123456789 -> 123456789 Rounded
  78. inx064 add -0.00 123456789 -> 123456789 Rounded
  79. inx065 add -1 123456789 -> 123456788
  80. inx066 add -0.1 123456789 -> 123456789 Inexact Rounded
  81. inx067 add -0.01 123456789 -> 123456789 Inexact Rounded
  82. inx068 add -0.001 123456789 -> 123456789 Inexact Rounded
  83. inx069 add -0.000001 123456789 -> 123456789 Inexact Rounded
  84. inx070 add -0.000000001 123456789 -> 123456789 Inexact Rounded
  85. inx071 add -0.000000000001 123456789 -> 123456789 Inexact Rounded
  86. inx072 add -0.9 123456789 -> 123456788 Inexact Rounded
  87. inx073 add -0.09 123456789 -> 123456789 Inexact Rounded
  88. inx074 add -0.009 123456789 -> 123456789 Inexact Rounded
  89. inx075 add -0.000009 123456789 -> 123456789 Inexact Rounded
  90. inx076 add -0.000000009 123456789 -> 123456789 Inexact Rounded
  91. inx077 add -0.000000000009 123456789 -> 123456789 Inexact Rounded
  92. -- some boundaries
  93. inx081 add 999999999 0 -> 999999999
  94. inx082 add 0.999999999 0.000000000 -> 0.999999999
  95. inx083 add 999999999 1 -> 1.00000000E+9 Rounded
  96. inx084 add 0.999999999 0.000000001 -> 1.00000000 Rounded
  97. inx085 add 999999999 2 -> 1.00000000E+9 Inexact Rounded
  98. inx086 add 0.999999999 0.000000002 -> 1.00000000 Inexact Rounded
  99. inx087 add 999999999 3 -> 1.00000000E+9 Inexact Rounded
  100. inx089 add 0.999999999 0.000000003 -> 1.00000000 Inexact Rounded
  101. -- minus, plus, and subtract all assumed to work like add.
  102. -- multiply
  103. precision: 8
  104. inx101 multiply 1000 1000 -> 1000000
  105. inx102 multiply 9000 9000 -> 81000000
  106. inx103 multiply 9999 9999 -> 99980001
  107. inx104 multiply 1000 10000 -> 10000000
  108. inx105 multiply 10000 10000 -> 1.0000000E+8 Rounded
  109. inx106 multiply 10001 10000 -> 1.0001000E+8 Rounded
  110. inx107 multiply 10001 10001 -> 1.0002000E+8 Inexact Rounded
  111. inx108 multiply 10101 10001 -> 1.0102010E+8 Inexact Rounded
  112. inx109 multiply 10001 10101 -> 1.0102010E+8 Inexact Rounded
  113. -- divide
  114. precision: 4
  115. inx201 divide 1000 1000 -> 1
  116. inx202 divide 1000 1 -> 1000
  117. inx203 divide 1000 2 -> 500
  118. inx204 divide 1000 3 -> 333.3 Inexact Rounded
  119. inx205 divide 1000 4 -> 250
  120. inx206 divide 1000 5 -> 200
  121. inx207 divide 1000 6 -> 166.7 Inexact Rounded
  122. inx208 divide 1000 7 -> 142.9 Inexact Rounded
  123. inx209 divide 1000 8 -> 125
  124. inx210 divide 1000 9 -> 111.1 Inexact Rounded
  125. inx211 divide 1000 10 -> 100
  126. inx220 divide 1 1 -> 1
  127. inx221 divide 1 2 -> 0.5
  128. inx222 divide 1 4 -> 0.25
  129. inx223 divide 1 8 -> 0.125
  130. inx224 divide 1 16 -> 0.0625
  131. inx225 divide 1 32 -> 0.03125
  132. inx226 divide 1 64 -> 0.01563 Inexact Rounded
  133. inx227 divide 1 128 -> 0.007813 Inexact Rounded
  134. precision: 5
  135. inx230 divide 1 1 -> 1
  136. inx231 divide 1 2 -> 0.5
  137. inx232 divide 1 4 -> 0.25
  138. inx233 divide 1 8 -> 0.125
  139. inx234 divide 1 16 -> 0.0625
  140. inx235 divide 1 32 -> 0.03125
  141. inx236 divide 1 64 -> 0.015625
  142. inx237 divide 1 128 -> 0.0078125
  143. precision: 3
  144. inx240 divide 1 1 -> 1
  145. inx241 divide 1 2 -> 0.5
  146. inx242 divide 1 4 -> 0.25
  147. inx243 divide 1 8 -> 0.125
  148. inx244 divide 1 16 -> 0.0625
  149. inx245 divide 1 32 -> 0.0313 Inexact Rounded
  150. inx246 divide 1 64 -> 0.0156 Inexact Rounded
  151. inx247 divide 1 128 -> 0.00781 Inexact Rounded
  152. precision: 2
  153. inx250 divide 1 1 -> 1
  154. inx251 divide 1 2 -> 0.5
  155. inx252 divide 1 4 -> 0.25
  156. inx253 divide 1 8 -> 0.13 Inexact Rounded
  157. inx254 divide 1 16 -> 0.063 Inexact Rounded
  158. inx255 divide 1 32 -> 0.031 Inexact Rounded
  159. inx256 divide 1 64 -> 0.016 Inexact Rounded
  160. inx257 divide 1 128 -> 0.0078 Inexact Rounded
  161. precision: 1
  162. inx260 divide 1 1 -> 1
  163. inx261 divide 1 2 -> 0.5
  164. inx262 divide 1 4 -> 0.3 Inexact Rounded
  165. inx263 divide 1 8 -> 0.1 Inexact Rounded
  166. inx264 divide 1 16 -> 0.06 Inexact Rounded
  167. inx265 divide 1 32 -> 0.03 Inexact Rounded
  168. inx266 divide 1 64 -> 0.02 Inexact Rounded
  169. inx267 divide 1 128 -> 0.008 Inexact Rounded
  170. -- power
  171. precision: 4
  172. inx301 power 0.5 2 -> 0.25
  173. inx302 power 0.5 4 -> 0.0625
  174. inx303 power 0.5 8 -> 0.003906 Inexact Rounded
  175. inx304 power 0.5 16 -> 0.00001526 Inexact Rounded
  176. inx305 power 0.5 32 -> 2.328E-10 Inexact Rounded
  177. -- compare, divideInteger, and remainder are always exact
  178. -- rescale
  179. precision: 4
  180. inx401 rescale 0 0 -> 0
  181. inx402 rescale 1 0 -> 1
  182. inx403 rescale 0.1 +2 -> 0E+2 Inexact Rounded
  183. inx404 rescale 0.1 +1 -> 0E+1 Inexact Rounded
  184. inx405 rescale 0.1 0 -> 0 Inexact Rounded
  185. inx406 rescale 0.1 -1 -> 0.1
  186. inx407 rescale 0.1 -2 -> 0.10
  187. -- long operands cause rounding too
  188. precision: 9
  189. inx801 plus 123456789 -> 123456789
  190. inx802 plus 1234567890 -> 1.23456789E+9 Rounded
  191. inx803 plus 1234567891 -> 1.23456789E+9 Inexact Rounded
  192. inx804 plus 1234567892 -> 1.23456789E+9 Inexact Rounded
  193. inx805 plus 1234567899 -> 1.23456790E+9 Inexact Rounded
  194. inx806 plus 1234567900 -> 1.23456790E+9 Rounded