ddNextMinus.decTest 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. ------------------------------------------------------------------------
  2. -- ddNextMinus.decTest -- decDouble 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. -- All operands and results are decDoubles.
  22. precision: 16
  23. maxExponent: 384
  24. minExponent: -383
  25. extended: 1
  26. clamp: 1
  27. rounding: half_even
  28. ddnextm001 nextminus 0.9999999999999995 -> 0.9999999999999994
  29. ddnextm002 nextminus 0.9999999999999996 -> 0.9999999999999995
  30. ddnextm003 nextminus 0.9999999999999997 -> 0.9999999999999996
  31. ddnextm004 nextminus 0.9999999999999998 -> 0.9999999999999997
  32. ddnextm005 nextminus 0.9999999999999999 -> 0.9999999999999998
  33. ddnextm006 nextminus 1.000000000000000 -> 0.9999999999999999
  34. ddnextm007 nextminus 1.0 -> 0.9999999999999999
  35. ddnextm008 nextminus 1 -> 0.9999999999999999
  36. ddnextm009 nextminus 1.000000000000001 -> 1.000000000000000
  37. ddnextm010 nextminus 1.000000000000002 -> 1.000000000000001
  38. ddnextm011 nextminus 1.000000000000003 -> 1.000000000000002
  39. ddnextm012 nextminus 1.000000000000004 -> 1.000000000000003
  40. ddnextm013 nextminus 1.000000000000005 -> 1.000000000000004
  41. ddnextm014 nextminus 1.000000000000006 -> 1.000000000000005
  42. ddnextm015 nextminus 1.000000000000007 -> 1.000000000000006
  43. ddnextm016 nextminus 1.000000000000008 -> 1.000000000000007
  44. ddnextm017 nextminus 1.000000000000009 -> 1.000000000000008
  45. ddnextm018 nextminus 1.000000000000010 -> 1.000000000000009
  46. ddnextm019 nextminus 1.000000000000011 -> 1.000000000000010
  47. ddnextm020 nextminus 1.000000000000012 -> 1.000000000000011
  48. ddnextm021 nextminus -0.9999999999999995 -> -0.9999999999999996
  49. ddnextm022 nextminus -0.9999999999999996 -> -0.9999999999999997
  50. ddnextm023 nextminus -0.9999999999999997 -> -0.9999999999999998
  51. ddnextm024 nextminus -0.9999999999999998 -> -0.9999999999999999
  52. ddnextm025 nextminus -0.9999999999999999 -> -1.000000000000000
  53. ddnextm026 nextminus -1.000000000000000 -> -1.000000000000001
  54. ddnextm027 nextminus -1.0 -> -1.000000000000001
  55. ddnextm028 nextminus -1 -> -1.000000000000001
  56. ddnextm029 nextminus -1.000000000000001 -> -1.000000000000002
  57. ddnextm030 nextminus -1.000000000000002 -> -1.000000000000003
  58. ddnextm031 nextminus -1.000000000000003 -> -1.000000000000004
  59. ddnextm032 nextminus -1.000000000000004 -> -1.000000000000005
  60. ddnextm033 nextminus -1.000000000000005 -> -1.000000000000006
  61. ddnextm034 nextminus -1.000000000000006 -> -1.000000000000007
  62. ddnextm035 nextminus -1.000000000000007 -> -1.000000000000008
  63. ddnextm036 nextminus -1.000000000000008 -> -1.000000000000009
  64. ddnextm037 nextminus -1.000000000000009 -> -1.000000000000010
  65. ddnextm038 nextminus -1.000000000000010 -> -1.000000000000011
  66. ddnextm039 nextminus -1.000000000000011 -> -1.000000000000012
  67. -- ultra-tiny inputs
  68. ddnextm062 nextminus 1E-398 -> 0E-398
  69. ddnextm065 nextminus -1E-398 -> -2E-398
  70. -- Zeros
  71. ddnextm100 nextminus -0 -> -1E-398
  72. ddnextm101 nextminus 0 -> -1E-398
  73. ddnextm102 nextminus 0.00 -> -1E-398
  74. ddnextm103 nextminus -0.00 -> -1E-398
  75. ddnextm104 nextminus 0E-300 -> -1E-398
  76. ddnextm105 nextminus 0E+300 -> -1E-398
  77. ddnextm106 nextminus 0E+30000 -> -1E-398
  78. ddnextm107 nextminus -0E+30000 -> -1E-398
  79. -- specials
  80. ddnextm150 nextminus Inf -> 9.999999999999999E+384
  81. ddnextm151 nextminus -Inf -> -Infinity
  82. ddnextm152 nextminus NaN -> NaN
  83. ddnextm153 nextminus sNaN -> NaN Invalid_operation
  84. ddnextm154 nextminus NaN77 -> NaN77
  85. ddnextm155 nextminus sNaN88 -> NaN88 Invalid_operation
  86. ddnextm156 nextminus -NaN -> -NaN
  87. ddnextm157 nextminus -sNaN -> -NaN Invalid_operation
  88. ddnextm158 nextminus -NaN77 -> -NaN77
  89. ddnextm159 nextminus -sNaN88 -> -NaN88 Invalid_operation
  90. -- Nmax, Nmin, Ntiny, subnormals
  91. ddnextm170 nextminus 9.999999999999999E+384 -> 9.999999999999998E+384
  92. ddnextm171 nextminus 9.999999999999998E+384 -> 9.999999999999997E+384
  93. ddnextm172 nextminus 1E-383 -> 9.99999999999999E-384
  94. ddnextm173 nextminus 1.000000000000000E-383 -> 9.99999999999999E-384
  95. ddnextm174 nextminus 9E-398 -> 8E-398
  96. ddnextm175 nextminus 9.9E-397 -> 9.8E-397
  97. ddnextm176 nextminus 9.99999999999E-387 -> 9.99999999998E-387
  98. ddnextm177 nextminus 9.99999999999999E-384 -> 9.99999999999998E-384
  99. ddnextm178 nextminus 9.99999999999998E-384 -> 9.99999999999997E-384
  100. ddnextm179 nextminus 9.99999999999997E-384 -> 9.99999999999996E-384
  101. ddnextm180 nextminus 0E-398 -> -1E-398
  102. ddnextm181 nextminus 1E-398 -> 0E-398
  103. ddnextm182 nextminus 2E-398 -> 1E-398
  104. ddnextm183 nextminus -0E-398 -> -1E-398
  105. ddnextm184 nextminus -1E-398 -> -2E-398
  106. ddnextm185 nextminus -2E-398 -> -3E-398
  107. ddnextm186 nextminus -10E-398 -> -1.1E-397
  108. ddnextm187 nextminus -100E-398 -> -1.01E-396
  109. ddnextm188 nextminus -100000E-398 -> -1.00001E-393
  110. ddnextm189 nextminus -1.00000000000E-383 -> -1.000000000000001E-383
  111. ddnextm190 nextminus -1.000000000000000E-383 -> -1.000000000000001E-383
  112. ddnextm191 nextminus -1E-383 -> -1.000000000000001E-383
  113. ddnextm192 nextminus -9.999999999999998E+384 -> -9.999999999999999E+384
  114. ddnextm193 nextminus -9.999999999999999E+384 -> -Infinity
  115. -- Null tests
  116. ddnextm900 nextminus # -> NaN Invalid_operation