ddCanonical.decTest 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  1. ------------------------------------------------------------------------
  2. -- ddCanonical.decTest -- test decDouble canonical results --
  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. -- This file tests that copy operations leave uncanonical operands
  22. -- unchanged, and vice versa
  23. -- All operands and results are decDoubles.
  24. precision: 16
  25. maxExponent: 384
  26. minExponent: -383
  27. extended: 1
  28. clamp: 1
  29. rounding: half_even
  30. -- Uncanonical declets are: abc, where:
  31. -- a=1,2,3
  32. -- b=6,7,e,f
  33. -- c=e,f
  34. -- assert some standard (canonical) values; this tests that FromString
  35. -- produces canonical results (many more in decimalNN)
  36. ddcan001 apply 9.999999999999999E+384 -> #77fcff3fcff3fcff
  37. ddcan002 apply 0 -> #2238000000000000
  38. ddcan003 apply 1 -> #2238000000000001
  39. ddcan004 apply -1 -> #a238000000000001
  40. ddcan005 apply Infinity -> #7800000000000000
  41. ddcan006 apply -Infinity -> #f800000000000000
  42. ddcan007 apply -NaN -> #fc00000000000000
  43. ddcan008 apply -sNaN -> #fe00000000000000
  44. ddcan009 apply NaN999999999999999 -> #7c00ff3fcff3fcff
  45. ddcan010 apply sNaN999999999999999 -> #7e00ff3fcff3fcff
  46. decan011 apply 9999999999999999 -> #6e38ff3fcff3fcff
  47. ddcan012 apply 7.50 -> #22300000000003d0
  48. ddcan013 apply 9.99 -> #22300000000000ff
  49. -- Base tests for canonical encodings (individual operator
  50. -- propagation is tested later)
  51. -- Finites: declets in coefficient
  52. ddcan021 canonical #77fcff3fcff3fcff -> #77fcff3fcff3fcff
  53. ddcan022 canonical #77fcff3fcff3fcff -> #77fcff3fcff3fcff
  54. ddcan023 canonical #77ffff3fcff3fcff -> #77fcff3fcff3fcff
  55. ddcan024 canonical #77ffff3fcff3fcff -> #77fcff3fcff3fcff
  56. ddcan025 canonical #77fcffffcff3fcff -> #77fcff3fcff3fcff
  57. ddcan026 canonical #77fcffffcff3fcff -> #77fcff3fcff3fcff
  58. ddcan027 canonical #77fcff3ffff3fcff -> #77fcff3fcff3fcff
  59. ddcan028 canonical #77fcff3ffff3fcff -> #77fcff3fcff3fcff
  60. ddcan030 canonical #77fcff3fcffffcff -> #77fcff3fcff3fcff
  61. ddcan031 canonical #77fcff3fcffffcff -> #77fcff3fcff3fcff
  62. ddcan032 canonical #77fcff3fcff3ffff -> #77fcff3fcff3fcff
  63. ddcan033 canonical #77fcff3fcff3ffff -> #77fcff3fcff3fcff
  64. ddcan035 canonical #77fcff3fdff3fcff -> #77fcff3fcff3fcff
  65. ddcan036 canonical #77fcff3feff3fcff -> #77fcff3fcff3fcff
  66. -- NaN: declets in payload
  67. ddcan100 canonical NaN999999999999999 -> #7c00ff3fcff3fcff
  68. ddcan101 canonical #7c00ff3fcff3fcff -> #7c00ff3fcff3fcff
  69. ddcan102 canonical #7c03ff3fcff3fcff -> #7c00ff3fcff3fcff
  70. ddcan103 canonical #7c00ffffcff3fcff -> #7c00ff3fcff3fcff
  71. ddcan104 canonical #7c00ff3ffff3fcff -> #7c00ff3fcff3fcff
  72. ddcan105 canonical #7c00ff3fcffffcff -> #7c00ff3fcff3fcff
  73. ddcan106 canonical #7c00ff3fcff3ffff -> #7c00ff3fcff3fcff
  74. ddcan107 canonical #7c00ff3fcff3ffff -> #7c00ff3fcff3fcff
  75. -- NaN: exponent continuation bits [excluding sNaN selector]
  76. ddcan110 canonical #7c00ff3fcff3fcff -> #7c00ff3fcff3fcff
  77. ddcan112 canonical #7d00ff3fcff3fcff -> #7c00ff3fcff3fcff
  78. ddcan113 canonical #7c80ff3fcff3fcff -> #7c00ff3fcff3fcff
  79. ddcan114 canonical #7c40ff3fcff3fcff -> #7c00ff3fcff3fcff
  80. ddcan115 canonical #7c20ff3fcff3fcff -> #7c00ff3fcff3fcff
  81. ddcan116 canonical #7c10ff3fcff3fcff -> #7c00ff3fcff3fcff
  82. ddcan117 canonical #7c08ff3fcff3fcff -> #7c00ff3fcff3fcff
  83. ddcan118 canonical #7c04ff3fcff3fcff -> #7c00ff3fcff3fcff
  84. -- sNaN: declets in payload
  85. ddcan120 canonical sNaN999999999999999 -> #7e00ff3fcff3fcff
  86. ddcan121 canonical #7e00ff3fcff3fcff -> #7e00ff3fcff3fcff
  87. ddcan122 canonical #7e03ff3fcff3fcff -> #7e00ff3fcff3fcff
  88. ddcan123 canonical #7e00ffffcff3fcff -> #7e00ff3fcff3fcff
  89. ddcan124 canonical #7e00ff3ffff3fcff -> #7e00ff3fcff3fcff
  90. ddcan125 canonical #7e00ff3fcffffcff -> #7e00ff3fcff3fcff
  91. ddcan126 canonical #7e00ff3fcff3ffff -> #7e00ff3fcff3fcff
  92. ddcan127 canonical #7e00ff3fcff3ffff -> #7e00ff3fcff3fcff
  93. -- sNaN: exponent continuation bits [excluding sNaN selector]
  94. ddcan130 canonical #7e00ff3fcff3fcff -> #7e00ff3fcff3fcff
  95. ddcan132 canonical #7f00ff3fcff3fcff -> #7e00ff3fcff3fcff
  96. ddcan133 canonical #7e80ff3fcff3fcff -> #7e00ff3fcff3fcff
  97. ddcan134 canonical #7e40ff3fcff3fcff -> #7e00ff3fcff3fcff
  98. ddcan135 canonical #7e20ff3fcff3fcff -> #7e00ff3fcff3fcff
  99. ddcan136 canonical #7e10ff3fcff3fcff -> #7e00ff3fcff3fcff
  100. ddcan137 canonical #7e08ff3fcff3fcff -> #7e00ff3fcff3fcff
  101. ddcan138 canonical #7e04ff3fcff3fcff -> #7e00ff3fcff3fcff
  102. -- Inf: exponent continuation bits
  103. ddcan140 canonical #7800000000000000 -> #7800000000000000
  104. ddcan141 canonical #7900000000000000 -> #7800000000000000
  105. ddcan142 canonical #7a00000000000000 -> #7800000000000000
  106. ddcan143 canonical #7880000000000000 -> #7800000000000000
  107. ddcan144 canonical #7840000000000000 -> #7800000000000000
  108. ddcan145 canonical #7820000000000000 -> #7800000000000000
  109. ddcan146 canonical #7810000000000000 -> #7800000000000000
  110. ddcan147 canonical #7808000000000000 -> #7800000000000000
  111. ddcan148 canonical #7804000000000000 -> #7800000000000000
  112. -- Inf: coefficient continuation bits (first, last, and a few others)
  113. ddcan150 canonical #7800000000000000 -> #7800000000000000
  114. ddcan151 canonical #7802000000000000 -> #7800000000000000
  115. ddcan152 canonical #7800000000000001 -> #7800000000000000
  116. ddcan153 canonical #7801000000000000 -> #7800000000000000
  117. ddcan154 canonical #7800200000000000 -> #7800000000000000
  118. ddcan155 canonical #7800080000000000 -> #7800000000000000
  119. ddcan156 canonical #7800002000000000 -> #7800000000000000
  120. ddcan157 canonical #7800000400000000 -> #7800000000000000
  121. ddcan158 canonical #7800000040000000 -> #7800000000000000
  122. ddcan159 canonical #7800000008000000 -> #7800000000000000
  123. ddcan160 canonical #7800000000400000 -> #7800000000000000
  124. ddcan161 canonical #7800000000020000 -> #7800000000000000
  125. ddcan162 canonical #7800000000008000 -> #7800000000000000
  126. ddcan163 canonical #7800000000000200 -> #7800000000000000
  127. ddcan164 canonical #7800000000000040 -> #7800000000000000
  128. ddcan165 canonical #7800000000000008 -> #7800000000000000
  129. -- Now the operators -- trying to check paths that might fail to
  130. -- canonicalize propagated operands
  131. ----- Add:
  132. -- Finites: neutral 0
  133. ddcan202 add 0E+384 #77ffff3fcff3fcff -> #77fcff3fcff3fcff
  134. ddcan203 add #77fcffffcff3fcff 0E+384 -> #77fcff3fcff3fcff
  135. -- tiny zero
  136. ddcan204 add 0E-398 #77ffff3fcff3fcff -> #77fcff3fcff3fcff Rounded
  137. ddcan205 add #77fcffffcff3fcff 0E-398 -> #77fcff3fcff3fcff Rounded
  138. -- tiny non zero
  139. ddcan206 add -1E-398 #77ffff3fcff3fcff -> #77fcff3fcff3fcff Inexact Rounded
  140. ddcan207 add #77ffff3fcff3fcff -1E-398 -> #77fcff3fcff3fcff Inexact Rounded
  141. -- NaN: declets in payload
  142. ddcan211 add 0 #7c03ff3fcff3fcff -> #7c00ff3fcff3fcff
  143. ddcan212 add #7c03ff3fcff3fcff 0 -> #7c00ff3fcff3fcff
  144. -- NaN: exponent continuation bits [excluding sNaN selector]
  145. ddcan213 add 0 #7c40ff3fcff3fcff -> #7c00ff3fcff3fcff
  146. ddcan214 add #7c40ff3fcff3fcff 0 -> #7c00ff3fcff3fcff
  147. -- sNaN: declets in payload
  148. ddcan215 add 0 #7e00ffffcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  149. ddcan216 add #7e00ffffcff3fcff 0 -> #7c00ff3fcff3fcff Invalid_operation
  150. -- sNaN: exponent continuation bits [excluding sNaN selector]
  151. ddcan217 add 0 #7e80ff3fcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  152. ddcan218 add #7e80ff3fcff3fcff 0 -> #7c00ff3fcff3fcff Invalid_operation
  153. -- Inf: exponent continuation bits
  154. ddcan220 add 0 #7880000000000000 -> #7800000000000000
  155. ddcan221 add #7880000000000000 0 -> #7800000000000000
  156. -- Inf: coefficient continuation bits
  157. ddcan222 add 0 #7802000000000000 -> #7800000000000000
  158. ddcan223 add #7802000000000000 0 -> #7800000000000000
  159. ddcan224 add 0 #7800000000000001 -> #7800000000000000
  160. ddcan225 add #7800000000000001 0 -> #7800000000000000
  161. ddcan226 add 0 #7800002000000000 -> #7800000000000000
  162. ddcan227 add #7800002000000000 0 -> #7800000000000000
  163. ----- Class: [does not return encoded]
  164. ----- Compare:
  165. ddcan231 compare -Inf 1 -> #a238000000000001
  166. ddcan232 compare -Inf -Inf -> #2238000000000000
  167. ddcan233 compare 1 -Inf -> #2238000000000001
  168. ddcan234 compare #7c00ff3ffff3fcff -1000 -> #7c00ff3fcff3fcff
  169. ddcan235 compare #7e00ff3ffff3fcff -1000 -> #7c00ff3fcff3fcff Invalid_operation
  170. ----- CompareSig:
  171. ddcan241 comparesig -Inf 1 -> #a238000000000001
  172. ddcan242 comparesig -Inf -Inf -> #2238000000000000
  173. ddcan243 comparesig 1 -Inf -> #2238000000000001
  174. ddcan244 comparesig #7c00ff3ffff3fcff -1000 -> #7c00ff3fcff3fcff Invalid_operation
  175. ddcan245 comparesig #7e00ff3ffff3fcff -1000 -> #7c00ff3fcff3fcff Invalid_operation
  176. ----- Copy: [does not usually canonicalize]
  177. -- finites
  178. ddcan250 copy #77ffff3fcff3fcff -> #77ffff3fcff3fcff
  179. ddcan251 copy #77fcff3fdff3fcff -> #77fcff3fdff3fcff
  180. -- NaNs
  181. ddcan252 copy #7c03ff3fcff3fcff -> #7c03ff3fcff3fcff
  182. ddcan253 copy #7c00ff3fcff3ffff -> #7c00ff3fcff3ffff
  183. ddcan254 copy #7d00ff3fcff3fcff -> #7d00ff3fcff3fcff
  184. ddcan255 copy #7c04ff3fcff3fcff -> #7c04ff3fcff3fcff
  185. -- sNaN
  186. ddcan256 copy #7e00ff3fcffffcff -> #7e00ff3fcffffcff
  187. ddcan257 copy #7e40ff3fcff3fcff -> #7e40ff3fcff3fcff
  188. -- Inf
  189. ddcan258 copy #7a00000000000000 -> #7a00000000000000
  190. ddcan259 copy #7800200000000000 -> #7800200000000000
  191. ----- CopyAbs: [does not usually canonicalize]
  192. -- finites
  193. ddcan260 copyabs #f7ffff3fcff3fcff -> #77ffff3fcff3fcff
  194. ddcan261 copyabs #f7fcff3fdff3fcff -> #77fcff3fdff3fcff
  195. -- NaNs
  196. ddcan262 copyabs #fc03ff3fcff3fcff -> #7c03ff3fcff3fcff
  197. ddcan263 copyabs #fc00ff3fcff3ffff -> #7c00ff3fcff3ffff
  198. ddcan264 copyabs #fd00ff3fcff3fcff -> #7d00ff3fcff3fcff
  199. ddcan265 copyabs #fc04ff3fcff3fcff -> #7c04ff3fcff3fcff
  200. -- sNaN
  201. ddcan266 copyabs #fe00ff3fcffffcff -> #7e00ff3fcffffcff
  202. ddcan267 copyabs #fe40ff3fcff3fcff -> #7e40ff3fcff3fcff
  203. -- Inf
  204. ddcan268 copyabs #fa00000000000000 -> #7a00000000000000
  205. ddcan269 copyabs #f800200000000000 -> #7800200000000000
  206. ----- CopyNegate: [does not usually canonicalize]
  207. -- finites
  208. ddcan270 copynegate #77ffff3fcff3fcff -> #f7ffff3fcff3fcff
  209. ddcan271 copynegate #77fcff3fdff3fcff -> #f7fcff3fdff3fcff
  210. -- NaNs
  211. ddcan272 copynegate #7c03ff3fcff3fcff -> #fc03ff3fcff3fcff
  212. ddcan273 copynegate #7c00ff3fcff3ffff -> #fc00ff3fcff3ffff
  213. ddcan274 copynegate #7d00ff3fcff3fcff -> #fd00ff3fcff3fcff
  214. ddcan275 copynegate #7c04ff3fcff3fcff -> #fc04ff3fcff3fcff
  215. -- sNaN
  216. ddcan276 copynegate #7e00ff3fcffffcff -> #fe00ff3fcffffcff
  217. ddcan277 copynegate #7e40ff3fcff3fcff -> #fe40ff3fcff3fcff
  218. -- Inf
  219. ddcan278 copynegate #7a00000000000000 -> #fa00000000000000
  220. ddcan279 copynegate #7800200000000000 -> #f800200000000000
  221. ----- CopySign: [does not usually canonicalize]
  222. -- finites
  223. ddcan280 copysign #77ffff3fcff3fcff -1 -> #f7ffff3fcff3fcff
  224. ddcan281 copysign #77fcff3fdff3fcff 1 -> #77fcff3fdff3fcff
  225. -- NaNs
  226. ddcan282 copysign #7c03ff3fcff3fcff -1 -> #fc03ff3fcff3fcff
  227. ddcan283 copysign #7c00ff3fcff3ffff 1 -> #7c00ff3fcff3ffff
  228. ddcan284 copysign #7d00ff3fcff3fcff -1 -> #fd00ff3fcff3fcff
  229. ddcan285 copysign #7c04ff3fcff3fcff 1 -> #7c04ff3fcff3fcff
  230. -- sNaN
  231. ddcan286 copysign #7e00ff3fcffffcff -1 -> #fe00ff3fcffffcff
  232. ddcan287 copysign #7e40ff3fcff3fcff 1 -> #7e40ff3fcff3fcff
  233. -- Inf
  234. ddcan288 copysign #7a00000000000000 -1 -> #fa00000000000000
  235. ddcan289 copysign #7800200000000000 1 -> #7800200000000000
  236. ----- Multiply:
  237. -- Finites: neutral 0
  238. ddcan302 multiply 1 #77ffff3fcff3fcff -> #77fcff3fcff3fcff
  239. ddcan303 multiply #77fcffffcff3fcff 1 -> #77fcff3fcff3fcff
  240. -- negative
  241. ddcan306 multiply -1 #77ffff3fcff3fcff -> #f7fcff3fcff3fcff
  242. ddcan307 multiply #77fcffffcff3fcff -1 -> #f7fcff3fcff3fcff
  243. -- NaN: declets in payload
  244. ddcan311 multiply 1 #7c03ff3fcff3fcff -> #7c00ff3fcff3fcff
  245. ddcan312 multiply #7c03ff3fcff3fcff 1 -> #7c00ff3fcff3fcff
  246. -- NaN: exponent continuation bits [excluding sNaN selector]
  247. ddcan313 multiply 1 #7c40ff3fcff3fcff -> #7c00ff3fcff3fcff
  248. ddcan314 multiply #7c40ff3fcff3fcff 1 -> #7c00ff3fcff3fcff
  249. -- sNaN: declets in payload
  250. ddcan315 multiply 1 #7e00ffffcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  251. ddcan316 multiply #7e00ffffcff3fcff 1 -> #7c00ff3fcff3fcff Invalid_operation
  252. -- sNaN: exponent continuation bits [excluding sNaN selector]
  253. ddcan317 multiply 1 #7e80ff3fcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  254. ddcan318 multiply #7e80ff3fcff3fcff 1 -> #7c00ff3fcff3fcff Invalid_operation
  255. -- Inf: exponent continuation bits
  256. ddcan320 multiply 1 #7880000000000000 -> #7800000000000000
  257. ddcan321 multiply #7880000000000000 1 -> #7800000000000000
  258. -- Inf: coefficient continuation bits
  259. ddcan322 multiply 1 #7802000000000000 -> #7800000000000000
  260. ddcan323 multiply #7802000000000000 1 -> #7800000000000000
  261. ddcan324 multiply 1 #7800000000000001 -> #7800000000000000
  262. ddcan325 multiply #7800000000000001 1 -> #7800000000000000
  263. ddcan326 multiply 1 #7800002000000000 -> #7800000000000000
  264. ddcan327 multiply #7800002000000000 1 -> #7800000000000000
  265. ----- Quantize:
  266. ddcan401 quantize #6e38ff3ffff3fcff 1 -> #6e38ff3fcff3fcff
  267. ddcan402 quantize #6e38ff3fcff3fdff 0 -> #6e38ff3fcff3fcff
  268. ddcan403 quantize #7880000000000000 Inf -> #7800000000000000
  269. ddcan404 quantize #7802000000000000 -Inf -> #7800000000000000
  270. ddcan410 quantize #7c03ff3fcff3fcff 1 -> #7c00ff3fcff3fcff
  271. ddcan411 quantize #7c03ff3fcff3fcff 1 -> #7c00ff3fcff3fcff
  272. ddcan412 quantize #7c40ff3fcff3fcff 1 -> #7c00ff3fcff3fcff
  273. ddcan413 quantize #7c40ff3fcff3fcff 1 -> #7c00ff3fcff3fcff
  274. ddcan414 quantize #7e00ffffcff3fcff 1 -> #7c00ff3fcff3fcff Invalid_operation
  275. ddcan415 quantize #7e00ffffcff3fcff 1 -> #7c00ff3fcff3fcff Invalid_operation
  276. ddcan416 quantize #7e80ff3fcff3fcff 1 -> #7c00ff3fcff3fcff Invalid_operation
  277. ddcan417 quantize #7e80ff3fcff3fcff 1 -> #7c00ff3fcff3fcff Invalid_operation
  278. ----- Subtract:
  279. -- Finites: neutral 0
  280. ddcan502 subtract 0E+384 #77ffff3fcff3fcff -> #f7fcff3fcff3fcff
  281. ddcan503 subtract #77fcffffcff3fcff 0E+384 -> #77fcff3fcff3fcff
  282. -- tiny zero
  283. ddcan504 subtract 0E-398 #77ffff3fcff3fcff -> #f7fcff3fcff3fcff Rounded
  284. ddcan505 subtract #77fcffffcff3fcff 0E-398 -> #77fcff3fcff3fcff Rounded
  285. -- tiny non zero
  286. ddcan506 subtract -1E-398 #77ffff3fcff3fcff -> #f7fcff3fcff3fcff Inexact Rounded
  287. ddcan507 subtract #77ffff3fcff3fcff -1E-398 -> #77fcff3fcff3fcff Inexact Rounded
  288. -- NaN: declets in payload
  289. ddcan511 subtract 0 #7c03ff3fcff3fcff -> #7c00ff3fcff3fcff
  290. ddcan512 subtract #7c03ff3fcff3fcff 0 -> #7c00ff3fcff3fcff
  291. -- NaN: exponent continuation bits [excluding sNaN selector]
  292. ddcan513 subtract 0 #7c40ff3fcff3fcff -> #7c00ff3fcff3fcff
  293. ddcan514 subtract #7c40ff3fcff3fcff 0 -> #7c00ff3fcff3fcff
  294. -- sNaN: declets in payload
  295. ddcan515 subtract 0 #7e00ffffcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  296. ddcan516 subtract #7e00ffffcff3fcff 0 -> #7c00ff3fcff3fcff Invalid_operation
  297. -- sNaN: exponent continuation bits [excluding sNaN selector]
  298. ddcan517 subtract 0 #7e80ff3fcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  299. ddcan518 subtract #7e80ff3fcff3fcff 0 -> #7c00ff3fcff3fcff Invalid_operation
  300. -- Inf: exponent continuation bits
  301. ddcan520 subtract 0 #7880000000000000 -> #f800000000000000
  302. ddcan521 subtract #7880000000000000 0 -> #7800000000000000
  303. -- Inf: coefficient continuation bits
  304. ddcan522 subtract 0 #7802000000000000 -> #f800000000000000
  305. ddcan523 subtract #7802000000000000 0 -> #7800000000000000
  306. ddcan524 subtract 0 #7800000000000001 -> #f800000000000000
  307. ddcan525 subtract #7800000000000001 0 -> #7800000000000000
  308. ddcan526 subtract 0 #7800002000000000 -> #f800000000000000
  309. ddcan527 subtract #7800002000000000 0 -> #7800000000000000
  310. ----- ToIntegral:
  311. ddcan601 tointegralx #6e38ff3ffff3fcff -> #6e38ff3fcff3fcff
  312. ddcan602 tointegralx #6e38ff3fcff3fdff -> #6e38ff3fcff3fcff
  313. ddcan603 tointegralx #7880000000000000 -> #7800000000000000
  314. ddcan604 tointegralx #7802000000000000 -> #7800000000000000
  315. ddcan610 tointegralx #7c03ff3fcff3fcff -> #7c00ff3fcff3fcff
  316. ddcan611 tointegralx #7c03ff3fcff3fcff -> #7c00ff3fcff3fcff
  317. ddcan612 tointegralx #7c40ff3fcff3fcff -> #7c00ff3fcff3fcff
  318. ddcan613 tointegralx #7c40ff3fcff3fcff -> #7c00ff3fcff3fcff
  319. ddcan614 tointegralx #7e00ffffcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  320. ddcan615 tointegralx #7e00ffffcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  321. ddcan616 tointegralx #7e80ff3fcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  322. ddcan617 tointegralx #7e80ff3fcff3fcff -> #7c00ff3fcff3fcff Invalid_operation
  323. -- uncanonical 3999, 39.99, 3.99, 0.399, and negatives
  324. ddcan618 tointegralx #2238000000000fff -> #2238000000000cff
  325. ddcan619 tointegralx #2230000000000fff -> #2238000000000040 Inexact Rounded
  326. ddcan620 tointegralx #222c000000000fff -> #2238000000000004 Inexact Rounded
  327. ddcan621 tointegralx #2228000000000fff -> #2238000000000000 Inexact Rounded
  328. ddcan622 tointegralx #a238000000000fff -> #a238000000000cff
  329. ddcan623 tointegralx #a230000000000fff -> #a238000000000040 Inexact Rounded
  330. ddcan624 tointegralx #a22c000000000fff -> #a238000000000004 Inexact Rounded
  331. ddcan625 tointegralx #a228000000000fff -> #a238000000000000 Inexact Rounded