nextminus.decTest 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. ------------------------------------------------------------------------
  2. -- nextminus.decTest -- decimal next that is less [754r nextdown] --
  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: 384
  25. minexponent: -383
  26. nextm001 nextminus 0.999999995 -> 0.999999994
  27. nextm002 nextminus 0.999999996 -> 0.999999995
  28. nextm003 nextminus 0.999999997 -> 0.999999996
  29. nextm004 nextminus 0.999999998 -> 0.999999997
  30. nextm005 nextminus 0.999999999 -> 0.999999998
  31. nextm006 nextminus 1.00000000 -> 0.999999999
  32. nextm007 nextminus 1.0 -> 0.999999999
  33. nextm008 nextminus 1 -> 0.999999999
  34. nextm009 nextminus 1.00000001 -> 1.00000000
  35. nextm010 nextminus 1.00000002 -> 1.00000001
  36. nextm011 nextminus 1.00000003 -> 1.00000002
  37. nextm012 nextminus 1.00000004 -> 1.00000003
  38. nextm013 nextminus 1.00000005 -> 1.00000004
  39. nextm014 nextminus 1.00000006 -> 1.00000005
  40. nextm015 nextminus 1.00000007 -> 1.00000006
  41. nextm016 nextminus 1.00000008 -> 1.00000007
  42. nextm017 nextminus 1.00000009 -> 1.00000008
  43. nextm018 nextminus 1.00000010 -> 1.00000009
  44. nextm019 nextminus 1.00000011 -> 1.00000010
  45. nextm020 nextminus 1.00000012 -> 1.00000011
  46. nextm021 nextminus -0.999999995 -> -0.999999996
  47. nextm022 nextminus -0.999999996 -> -0.999999997
  48. nextm023 nextminus -0.999999997 -> -0.999999998
  49. nextm024 nextminus -0.999999998 -> -0.999999999
  50. nextm025 nextminus -0.999999999 -> -1.00000000
  51. nextm026 nextminus -1.00000000 -> -1.00000001
  52. nextm027 nextminus -1.0 -> -1.00000001
  53. nextm028 nextminus -1 -> -1.00000001
  54. nextm029 nextminus -1.00000001 -> -1.00000002
  55. nextm030 nextminus -1.00000002 -> -1.00000003
  56. nextm031 nextminus -1.00000003 -> -1.00000004
  57. nextm032 nextminus -1.00000004 -> -1.00000005
  58. nextm033 nextminus -1.00000005 -> -1.00000006
  59. nextm034 nextminus -1.00000006 -> -1.00000007
  60. nextm035 nextminus -1.00000007 -> -1.00000008
  61. nextm036 nextminus -1.00000008 -> -1.00000009
  62. nextm037 nextminus -1.00000009 -> -1.00000010
  63. nextm038 nextminus -1.00000010 -> -1.00000011
  64. nextm039 nextminus -1.00000011 -> -1.00000012
  65. -- input operand is >precision
  66. nextm041 nextminus 1.00000010998 -> 1.00000010
  67. nextm042 nextminus 1.00000010999 -> 1.00000010
  68. nextm043 nextminus 1.00000011000 -> 1.00000010
  69. nextm044 nextminus 1.00000011001 -> 1.00000011
  70. nextm045 nextminus 1.00000011002 -> 1.00000011
  71. nextm046 nextminus 1.00000011002 -> 1.00000011
  72. nextm047 nextminus 1.00000011052 -> 1.00000011
  73. nextm048 nextminus 1.00000011552 -> 1.00000011
  74. nextm049 nextminus -1.00000010998 -> -1.00000011
  75. nextm050 nextminus -1.00000010999 -> -1.00000011
  76. nextm051 nextminus -1.00000011000 -> -1.00000012
  77. nextm052 nextminus -1.00000011001 -> -1.00000012
  78. nextm053 nextminus -1.00000011002 -> -1.00000012
  79. nextm054 nextminus -1.00000011002 -> -1.00000012
  80. nextm055 nextminus -1.00000011052 -> -1.00000012
  81. nextm056 nextminus -1.00000011552 -> -1.00000012
  82. -- ultra-tiny inputs
  83. nextm060 nextminus 1E-99999 -> 0E-391
  84. nextm061 nextminus 1E-999999999 -> 0E-391
  85. nextm062 nextminus 1E-391 -> 0E-391
  86. nextm063 nextminus -1E-99999 -> -1E-391
  87. nextm064 nextminus -1E-999999999 -> -1E-391
  88. nextm065 nextminus -1E-391 -> -2E-391
  89. -- Zeros
  90. nextm100 nextminus -0 -> -1E-391
  91. nextm101 nextminus 0 -> -1E-391
  92. nextm102 nextminus 0.00 -> -1E-391
  93. nextm103 nextminus -0.00 -> -1E-391
  94. nextm104 nextminus 0E-300 -> -1E-391
  95. nextm105 nextminus 0E+300 -> -1E-391
  96. nextm106 nextminus 0E+30000 -> -1E-391
  97. nextm107 nextminus -0E+30000 -> -1E-391
  98. precision: 9
  99. maxExponent: 999
  100. minexponent: -999
  101. -- specials
  102. nextm150 nextminus Inf -> 9.99999999E+999
  103. nextm151 nextminus -Inf -> -Infinity
  104. nextm152 nextminus NaN -> NaN
  105. nextm153 nextminus sNaN -> NaN Invalid_operation
  106. nextm154 nextminus NaN77 -> NaN77
  107. nextm155 nextminus sNaN88 -> NaN88 Invalid_operation
  108. nextm156 nextminus -NaN -> -NaN
  109. nextm157 nextminus -sNaN -> -NaN Invalid_operation
  110. nextm158 nextminus -NaN77 -> -NaN77
  111. nextm159 nextminus -sNaN88 -> -NaN88 Invalid_operation
  112. -- Nmax, Nmin, Ntiny, subnormals
  113. nextm170 nextminus 9.99999999E+999 -> 9.99999998E+999
  114. nextm171 nextminus 9.99999998E+999 -> 9.99999997E+999
  115. nextm172 nextminus 1E-999 -> 9.9999999E-1000
  116. nextm173 nextminus 1.00000000E-999 -> 9.9999999E-1000
  117. nextm174 nextminus 9E-1007 -> 8E-1007
  118. nextm175 nextminus 9.9E-1006 -> 9.8E-1006
  119. nextm176 nextminus 9.9999E-1003 -> 9.9998E-1003
  120. nextm177 nextminus 9.9999999E-1000 -> 9.9999998E-1000
  121. nextm178 nextminus 9.9999998E-1000 -> 9.9999997E-1000
  122. nextm179 nextminus 9.9999997E-1000 -> 9.9999996E-1000
  123. nextm180 nextminus 0E-1007 -> -1E-1007
  124. nextm181 nextminus 1E-1007 -> 0E-1007
  125. nextm182 nextminus 2E-1007 -> 1E-1007
  126. nextm183 nextminus -0E-1007 -> -1E-1007
  127. nextm184 nextminus -1E-1007 -> -2E-1007
  128. nextm185 nextminus -2E-1007 -> -3E-1007
  129. nextm186 nextminus -10E-1007 -> -1.1E-1006
  130. nextm187 nextminus -100E-1007 -> -1.01E-1005
  131. nextm188 nextminus -100000E-1007 -> -1.00001E-1002
  132. nextm189 nextminus -1.0000E-999 -> -1.00000001E-999
  133. nextm190 nextminus -1.00000000E-999 -> -1.00000001E-999
  134. nextm191 nextminus -1E-999 -> -1.00000001E-999
  135. nextm192 nextminus -9.99999998E+999 -> -9.99999999E+999
  136. nextm193 nextminus -9.99999999E+999 -> -Infinity
  137. -- Null tests
  138. nextm900 nextminus # -> NaN Invalid_operation