dqRotate.decTest 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. ------------------------------------------------------------------------
  2. -- dqRotate.decTest -- rotate decQuad coefficient left or right --
  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. clamp: 1
  23. precision: 34
  24. maxExponent: 6144
  25. minExponent: -6143
  26. rounding: half_even
  27. -- Sanity check
  28. dqrot001 rotate 0 0 -> 0
  29. dqrot002 rotate 0 2 -> 0
  30. dqrot003 rotate 1 2 -> 100
  31. dqrot004 rotate 1 33 -> 1000000000000000000000000000000000
  32. dqrot005 rotate 1 34 -> 1
  33. dqrot006 rotate 1 -1 -> 1000000000000000000000000000000000
  34. dqrot007 rotate 0 -2 -> 0
  35. dqrot008 rotate 1234567890123456789012345678901234 -1 -> 4123456789012345678901234567890123
  36. dqrot009 rotate 1234567890123456789012345678901234 -33 -> 2345678901234567890123456789012341
  37. dqrot010 rotate 1234567890123456789012345678901234 -34 -> 1234567890123456789012345678901234
  38. dqrot011 rotate 9934567890123456789012345678901234 -33 -> 9345678901234567890123456789012349
  39. dqrot012 rotate 9934567890123456789012345678901234 -34 -> 9934567890123456789012345678901234
  40. -- rhs must be an integer
  41. dqrot015 rotate 1 1.5 -> NaN Invalid_operation
  42. dqrot016 rotate 1 1.0 -> NaN Invalid_operation
  43. dqrot017 rotate 1 0.1 -> NaN Invalid_operation
  44. dqrot018 rotate 1 0.0 -> NaN Invalid_operation
  45. dqrot019 rotate 1 1E+1 -> NaN Invalid_operation
  46. dqrot020 rotate 1 1E+99 -> NaN Invalid_operation
  47. dqrot021 rotate 1 Inf -> NaN Invalid_operation
  48. dqrot022 rotate 1 -Inf -> NaN Invalid_operation
  49. -- and |rhs| <= precision
  50. dqrot025 rotate 1 -1000 -> NaN Invalid_operation
  51. dqrot026 rotate 1 -35 -> NaN Invalid_operation
  52. dqrot027 rotate 1 35 -> NaN Invalid_operation
  53. dqrot028 rotate 1 1000 -> NaN Invalid_operation
  54. -- full pattern
  55. dqrot030 rotate 1234567890123456789012345678901234 -34 -> 1234567890123456789012345678901234
  56. dqrot031 rotate 1234567890123456789012345678901234 -33 -> 2345678901234567890123456789012341
  57. dqrot032 rotate 1234567890123456789012345678901234 -32 -> 3456789012345678901234567890123412
  58. dqrot033 rotate 1234567890123456789012345678901234 -31 -> 4567890123456789012345678901234123
  59. dqrot034 rotate 1234567890123456789012345678901234 -30 -> 5678901234567890123456789012341234
  60. dqrot035 rotate 1234567890123456789012345678901234 -29 -> 6789012345678901234567890123412345
  61. dqrot036 rotate 1234567890123456789012345678901234 -28 -> 7890123456789012345678901234123456
  62. dqrot037 rotate 1234567890123456789012345678901234 -27 -> 8901234567890123456789012341234567
  63. dqrot038 rotate 1234567890123456789012345678901234 -26 -> 9012345678901234567890123412345678
  64. dqrot039 rotate 1234567890123456789012345678901234 -25 -> 123456789012345678901234123456789
  65. dqrot040 rotate 1234567890123456789012345678901234 -24 -> 1234567890123456789012341234567890
  66. dqrot041 rotate 1234567890123456789012345678901234 -23 -> 2345678901234567890123412345678901
  67. dqrot042 rotate 1234567890123456789012345678901234 -22 -> 3456789012345678901234123456789012
  68. dqrot043 rotate 1234567890123456789012345678901234 -21 -> 4567890123456789012341234567890123
  69. dqrot044 rotate 1234567890123456789012345678901234 -20 -> 5678901234567890123412345678901234
  70. dqrot045 rotate 1234567890123456789012345678901234 -19 -> 6789012345678901234123456789012345
  71. dqrot047 rotate 1234567890123456789012345678901234 -18 -> 7890123456789012341234567890123456
  72. dqrot048 rotate 1234567890123456789012345678901234 -17 -> 8901234567890123412345678901234567
  73. dqrot049 rotate 1234567890123456789012345678901234 -16 -> 9012345678901234123456789012345678
  74. dqrot050 rotate 1234567890123456789012345678901234 -15 -> 123456789012341234567890123456789
  75. dqrot051 rotate 1234567890123456789012345678901234 -14 -> 1234567890123412345678901234567890
  76. dqrot052 rotate 1234567890123456789012345678901234 -13 -> 2345678901234123456789012345678901
  77. dqrot053 rotate 1234567890123456789012345678901234 -12 -> 3456789012341234567890123456789012
  78. dqrot054 rotate 1234567890123456789012345678901234 -11 -> 4567890123412345678901234567890123
  79. dqrot055 rotate 1234567890123456789012345678901234 -10 -> 5678901234123456789012345678901234
  80. dqrot056 rotate 1234567890123456789012345678901234 -9 -> 6789012341234567890123456789012345
  81. dqrot057 rotate 1234567890123456789012345678901234 -8 -> 7890123412345678901234567890123456
  82. dqrot058 rotate 1234567890123456789012345678901234 -7 -> 8901234123456789012345678901234567
  83. dqrot059 rotate 1234567890123456789012345678901234 -6 -> 9012341234567890123456789012345678
  84. dqrot060 rotate 1234567890123456789012345678901234 -5 -> 123412345678901234567890123456789
  85. dqrot061 rotate 1234567890123456789012345678901234 -4 -> 1234123456789012345678901234567890
  86. dqrot062 rotate 1234567890123456789012345678901234 -3 -> 2341234567890123456789012345678901
  87. dqrot063 rotate 1234567890123456789012345678901234 -2 -> 3412345678901234567890123456789012
  88. dqrot064 rotate 1234567890123456789012345678901234 -1 -> 4123456789012345678901234567890123
  89. dqrot065 rotate 1234567890123456789012345678901234 -0 -> 1234567890123456789012345678901234
  90. dqrot066 rotate 1234567890123456789012345678901234 +0 -> 1234567890123456789012345678901234
  91. dqrot067 rotate 1234567890123456789012345678901234 +1 -> 2345678901234567890123456789012341
  92. dqrot068 rotate 1234567890123456789012345678901234 +2 -> 3456789012345678901234567890123412
  93. dqrot069 rotate 1234567890123456789012345678901234 +3 -> 4567890123456789012345678901234123
  94. dqrot070 rotate 1234567890123456789012345678901234 +4 -> 5678901234567890123456789012341234
  95. dqrot071 rotate 1234567890123456789012345678901234 +5 -> 6789012345678901234567890123412345
  96. dqrot072 rotate 1234567890123456789012345678901234 +6 -> 7890123456789012345678901234123456
  97. dqrot073 rotate 1234567890123456789012345678901234 +7 -> 8901234567890123456789012341234567
  98. dqrot074 rotate 1234567890123456789012345678901234 +8 -> 9012345678901234567890123412345678
  99. dqrot075 rotate 1234567890123456789012345678901234 +9 -> 123456789012345678901234123456789
  100. dqrot076 rotate 1234567890123456789012345678901234 +10 -> 1234567890123456789012341234567890
  101. dqrot077 rotate 1234567890123456789012345678901234 +11 -> 2345678901234567890123412345678901
  102. dqrot078 rotate 1234567890123456789012345678901234 +12 -> 3456789012345678901234123456789012
  103. dqrot079 rotate 1234567890123456789012345678901234 +13 -> 4567890123456789012341234567890123
  104. dqrot080 rotate 1234567890123456789012345678901234 +14 -> 5678901234567890123412345678901234
  105. dqrot081 rotate 1234567890123456789012345678901234 +15 -> 6789012345678901234123456789012345
  106. dqrot082 rotate 1234567890123456789012345678901234 +16 -> 7890123456789012341234567890123456
  107. dqrot083 rotate 1234567890123456789012345678901234 +17 -> 8901234567890123412345678901234567
  108. dqrot084 rotate 1234567890123456789012345678901234 +18 -> 9012345678901234123456789012345678
  109. dqrot085 rotate 1234567890123456789012345678901234 +19 -> 123456789012341234567890123456789
  110. dqrot086 rotate 1234567890123456789012345678901234 +20 -> 1234567890123412345678901234567890
  111. dqrot087 rotate 1234567890123456789012345678901234 +21 -> 2345678901234123456789012345678901
  112. dqrot088 rotate 1234567890123456789012345678901234 +22 -> 3456789012341234567890123456789012
  113. dqrot089 rotate 1234567890123456789012345678901234 +23 -> 4567890123412345678901234567890123
  114. dqrot090 rotate 1234567890123456789012345678901234 +24 -> 5678901234123456789012345678901234
  115. dqrot091 rotate 1234567890123456789012345678901234 +25 -> 6789012341234567890123456789012345
  116. dqrot092 rotate 1234567890123456789012345678901234 +26 -> 7890123412345678901234567890123456
  117. dqrot093 rotate 1234567890123456789012345678901234 +27 -> 8901234123456789012345678901234567
  118. dqrot094 rotate 1234567890123456789012345678901234 +28 -> 9012341234567890123456789012345678
  119. dqrot095 rotate 1234567890123456789012345678901234 +29 -> 123412345678901234567890123456789
  120. dqrot096 rotate 1234567890123456789012345678901234 +30 -> 1234123456789012345678901234567890
  121. dqrot097 rotate 1234567890123456789012345678901234 +31 -> 2341234567890123456789012345678901
  122. dqrot098 rotate 1234567890123456789012345678901234 +32 -> 3412345678901234567890123456789012
  123. dqrot099 rotate 1234567890123456789012345678901234 +33 -> 4123456789012345678901234567890123
  124. dqrot100 rotate 1234567890123456789012345678901234 +34 -> 1234567890123456789012345678901234
  125. -- zeros
  126. dqrot270 rotate 0E-10 +29 -> 0E-10
  127. dqrot271 rotate 0E-10 -29 -> 0E-10
  128. dqrot272 rotate 0.000 +29 -> 0.000
  129. dqrot273 rotate 0.000 -29 -> 0.000
  130. dqrot274 rotate 0E+10 +29 -> 0E+10
  131. dqrot275 rotate 0E+10 -29 -> 0E+10
  132. dqrot276 rotate -0E-10 +29 -> -0E-10
  133. dqrot277 rotate -0E-10 -29 -> -0E-10
  134. dqrot278 rotate -0.000 +29 -> -0.000
  135. dqrot279 rotate -0.000 -29 -> -0.000
  136. dqrot280 rotate -0E+10 +29 -> -0E+10
  137. dqrot281 rotate -0E+10 -29 -> -0E+10
  138. -- Nmax, Nmin, Ntiny
  139. dqrot141 rotate 9.999999999999999999999999999999999E+6144 -1 -> 9.999999999999999999999999999999999E+6144
  140. dqrot142 rotate 9.999999999999999999999999999999999E+6144 -33 -> 9.999999999999999999999999999999999E+6144
  141. dqrot143 rotate 9.999999999999999999999999999999999E+6144 1 -> 9.999999999999999999999999999999999E+6144
  142. dqrot144 rotate 9.999999999999999999999999999999999E+6144 33 -> 9.999999999999999999999999999999999E+6144
  143. dqrot145 rotate 1E-6143 -1 -> 1.000000000000000000000000000000000E-6110
  144. dqrot146 rotate 1E-6143 -33 -> 1.0E-6142
  145. dqrot147 rotate 1E-6143 1 -> 1.0E-6142
  146. dqrot148 rotate 1E-6143 33 -> 1.000000000000000000000000000000000E-6110
  147. dqrot151 rotate 1.000000000000000000000000000000000E-6143 -1 -> 1.00000000000000000000000000000000E-6144
  148. dqrot152 rotate 1.000000000000000000000000000000000E-6143 -33 -> 1E-6176
  149. dqrot153 rotate 1.000000000000000000000000000000000E-6143 1 -> 1E-6176
  150. dqrot154 rotate 1.000000000000000000000000000000000E-6143 33 -> 1.00000000000000000000000000000000E-6144
  151. dqrot155 rotate 9.000000000000000000000000000000000E-6143 -1 -> 9.00000000000000000000000000000000E-6144
  152. dqrot156 rotate 9.000000000000000000000000000000000E-6143 -33 -> 9E-6176
  153. dqrot157 rotate 9.000000000000000000000000000000000E-6143 1 -> 9E-6176
  154. dqrot158 rotate 9.000000000000000000000000000000000E-6143 33 -> 9.00000000000000000000000000000000E-6144
  155. dqrot160 rotate 1E-6176 -1 -> 1.000000000000000000000000000000000E-6143
  156. dqrot161 rotate 1E-6176 -33 -> 1.0E-6175
  157. dqrot162 rotate 1E-6176 1 -> 1.0E-6175
  158. dqrot163 rotate 1E-6176 33 -> 1.000000000000000000000000000000000E-6143
  159. -- negatives
  160. dqrot171 rotate -9.999999999999999999999999999999999E+6144 -1 -> -9.999999999999999999999999999999999E+6144
  161. dqrot172 rotate -9.999999999999999999999999999999999E+6144 -33 -> -9.999999999999999999999999999999999E+6144
  162. dqrot173 rotate -9.999999999999999999999999999999999E+6144 1 -> -9.999999999999999999999999999999999E+6144
  163. dqrot174 rotate -9.999999999999999999999999999999999E+6144 33 -> -9.999999999999999999999999999999999E+6144
  164. dqrot175 rotate -1E-6143 -1 -> -1.000000000000000000000000000000000E-6110
  165. dqrot176 rotate -1E-6143 -33 -> -1.0E-6142
  166. dqrot177 rotate -1E-6143 1 -> -1.0E-6142
  167. dqrot178 rotate -1E-6143 33 -> -1.000000000000000000000000000000000E-6110
  168. dqrot181 rotate -1.000000000000000000000000000000000E-6143 -1 -> -1.00000000000000000000000000000000E-6144
  169. dqrot182 rotate -1.000000000000000000000000000000000E-6143 -33 -> -1E-6176
  170. dqrot183 rotate -1.000000000000000000000000000000000E-6143 1 -> -1E-6176
  171. dqrot184 rotate -1.000000000000000000000000000000000E-6143 33 -> -1.00000000000000000000000000000000E-6144
  172. dqrot185 rotate -9.000000000000000000000000000000000E-6143 -1 -> -9.00000000000000000000000000000000E-6144
  173. dqrot186 rotate -9.000000000000000000000000000000000E-6143 -33 -> -9E-6176
  174. dqrot187 rotate -9.000000000000000000000000000000000E-6143 1 -> -9E-6176
  175. dqrot188 rotate -9.000000000000000000000000000000000E-6143 33 -> -9.00000000000000000000000000000000E-6144
  176. dqrot190 rotate -1E-6176 -1 -> -1.000000000000000000000000000000000E-6143
  177. dqrot191 rotate -1E-6176 -33 -> -1.0E-6175
  178. dqrot192 rotate -1E-6176 1 -> -1.0E-6175
  179. dqrot193 rotate -1E-6176 33 -> -1.000000000000000000000000000000000E-6143
  180. -- more negatives (of sanities)
  181. dqrot201 rotate -0 0 -> -0
  182. dqrot202 rotate -0 2 -> -0
  183. dqrot203 rotate -1 2 -> -100
  184. dqrot204 rotate -1 33 -> -1000000000000000000000000000000000
  185. dqrot205 rotate -1 34 -> -1
  186. dqrot206 rotate -1 -1 -> -1000000000000000000000000000000000
  187. dqrot207 rotate -0 -2 -> -0
  188. dqrot208 rotate -1234567890123456789012345678901234 -1 -> -4123456789012345678901234567890123
  189. dqrot209 rotate -1234567890123456789012345678901234 -33 -> -2345678901234567890123456789012341
  190. dqrot210 rotate -1234567890123456789012345678901234 -34 -> -1234567890123456789012345678901234
  191. dqrot211 rotate -9934567890123456789012345678901234 -33 -> -9345678901234567890123456789012349
  192. dqrot212 rotate -9934567890123456789012345678901234 -34 -> -9934567890123456789012345678901234
  193. -- Specials; NaNs are handled as usual
  194. dqrot781 rotate -Inf -8 -> -Infinity
  195. dqrot782 rotate -Inf -1 -> -Infinity
  196. dqrot783 rotate -Inf -0 -> -Infinity
  197. dqrot784 rotate -Inf 0 -> -Infinity
  198. dqrot785 rotate -Inf 1 -> -Infinity
  199. dqrot786 rotate -Inf 8 -> -Infinity
  200. dqrot787 rotate -1000 -Inf -> NaN Invalid_operation
  201. dqrot788 rotate -Inf -Inf -> NaN Invalid_operation
  202. dqrot789 rotate -1 -Inf -> NaN Invalid_operation
  203. dqrot790 rotate -0 -Inf -> NaN Invalid_operation
  204. dqrot791 rotate 0 -Inf -> NaN Invalid_operation
  205. dqrot792 rotate 1 -Inf -> NaN Invalid_operation
  206. dqrot793 rotate 1000 -Inf -> NaN Invalid_operation
  207. dqrot794 rotate Inf -Inf -> NaN Invalid_operation
  208. dqrot800 rotate Inf -Inf -> NaN Invalid_operation
  209. dqrot801 rotate Inf -8 -> Infinity
  210. dqrot802 rotate Inf -1 -> Infinity
  211. dqrot803 rotate Inf -0 -> Infinity
  212. dqrot804 rotate Inf 0 -> Infinity
  213. dqrot805 rotate Inf 1 -> Infinity
  214. dqrot806 rotate Inf 8 -> Infinity
  215. dqrot807 rotate Inf Inf -> NaN Invalid_operation
  216. dqrot808 rotate -1000 Inf -> NaN Invalid_operation
  217. dqrot809 rotate -Inf Inf -> NaN Invalid_operation
  218. dqrot810 rotate -1 Inf -> NaN Invalid_operation
  219. dqrot811 rotate -0 Inf -> NaN Invalid_operation
  220. dqrot812 rotate 0 Inf -> NaN Invalid_operation
  221. dqrot813 rotate 1 Inf -> NaN Invalid_operation
  222. dqrot814 rotate 1000 Inf -> NaN Invalid_operation
  223. dqrot815 rotate Inf Inf -> NaN Invalid_operation
  224. dqrot821 rotate NaN -Inf -> NaN
  225. dqrot822 rotate NaN -1000 -> NaN
  226. dqrot823 rotate NaN -1 -> NaN
  227. dqrot824 rotate NaN -0 -> NaN
  228. dqrot825 rotate NaN 0 -> NaN
  229. dqrot826 rotate NaN 1 -> NaN
  230. dqrot827 rotate NaN 1000 -> NaN
  231. dqrot828 rotate NaN Inf -> NaN
  232. dqrot829 rotate NaN NaN -> NaN
  233. dqrot830 rotate -Inf NaN -> NaN
  234. dqrot831 rotate -1000 NaN -> NaN
  235. dqrot832 rotate -1 NaN -> NaN
  236. dqrot833 rotate -0 NaN -> NaN
  237. dqrot834 rotate 0 NaN -> NaN
  238. dqrot835 rotate 1 NaN -> NaN
  239. dqrot836 rotate 1000 NaN -> NaN
  240. dqrot837 rotate Inf NaN -> NaN
  241. dqrot841 rotate sNaN -Inf -> NaN Invalid_operation
  242. dqrot842 rotate sNaN -1000 -> NaN Invalid_operation
  243. dqrot843 rotate sNaN -1 -> NaN Invalid_operation
  244. dqrot844 rotate sNaN -0 -> NaN Invalid_operation
  245. dqrot845 rotate sNaN 0 -> NaN Invalid_operation
  246. dqrot846 rotate sNaN 1 -> NaN Invalid_operation
  247. dqrot847 rotate sNaN 1000 -> NaN Invalid_operation
  248. dqrot848 rotate sNaN NaN -> NaN Invalid_operation
  249. dqrot849 rotate sNaN sNaN -> NaN Invalid_operation
  250. dqrot850 rotate NaN sNaN -> NaN Invalid_operation
  251. dqrot851 rotate -Inf sNaN -> NaN Invalid_operation
  252. dqrot852 rotate -1000 sNaN -> NaN Invalid_operation
  253. dqrot853 rotate -1 sNaN -> NaN Invalid_operation
  254. dqrot854 rotate -0 sNaN -> NaN Invalid_operation
  255. dqrot855 rotate 0 sNaN -> NaN Invalid_operation
  256. dqrot856 rotate 1 sNaN -> NaN Invalid_operation
  257. dqrot857 rotate 1000 sNaN -> NaN Invalid_operation
  258. dqrot858 rotate Inf sNaN -> NaN Invalid_operation
  259. dqrot859 rotate NaN sNaN -> NaN Invalid_operation
  260. -- propagating NaNs
  261. dqrot861 rotate NaN1 -Inf -> NaN1
  262. dqrot862 rotate +NaN2 -1000 -> NaN2
  263. dqrot863 rotate NaN3 1000 -> NaN3
  264. dqrot864 rotate NaN4 Inf -> NaN4
  265. dqrot865 rotate NaN5 +NaN6 -> NaN5
  266. dqrot866 rotate -Inf NaN7 -> NaN7
  267. dqrot867 rotate -1000 NaN8 -> NaN8
  268. dqrot868 rotate 1000 NaN9 -> NaN9
  269. dqrot869 rotate Inf +NaN10 -> NaN10
  270. dqrot871 rotate sNaN11 -Inf -> NaN11 Invalid_operation
  271. dqrot872 rotate sNaN12 -1000 -> NaN12 Invalid_operation
  272. dqrot873 rotate sNaN13 1000 -> NaN13 Invalid_operation
  273. dqrot874 rotate sNaN14 NaN17 -> NaN14 Invalid_operation
  274. dqrot875 rotate sNaN15 sNaN18 -> NaN15 Invalid_operation
  275. dqrot876 rotate NaN16 sNaN19 -> NaN19 Invalid_operation
  276. dqrot877 rotate -Inf +sNaN20 -> NaN20 Invalid_operation
  277. dqrot878 rotate -1000 sNaN21 -> NaN21 Invalid_operation
  278. dqrot879 rotate 1000 sNaN22 -> NaN22 Invalid_operation
  279. dqrot880 rotate Inf sNaN23 -> NaN23 Invalid_operation
  280. dqrot881 rotate +NaN25 +sNaN24 -> NaN24 Invalid_operation
  281. dqrot882 rotate -NaN26 NaN28 -> -NaN26
  282. dqrot883 rotate -sNaN27 sNaN29 -> -NaN27 Invalid_operation
  283. dqrot884 rotate 1000 -NaN30 -> -NaN30
  284. dqrot885 rotate 1000 -sNaN31 -> -NaN31 Invalid_operation