Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 1 | ------------------------------------------------------------------------ |
| 2 | -- rounding.decTest -- decimal rounding modes testcases -- |
Benjamin Peterson | f17ff4e | 2008-07-31 16:32:12 +0000 | [diff] [blame] | 3 | -- Copyright (c) IBM Corporation, 1981, 2008. All rights reserved. -- |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 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 | ------------------------------------------------------------------------ |
Mark Dickinson | 8a54653 | 2009-10-08 16:30:38 +0000 | [diff] [blame] | 20 | version: 2.59 |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 21 | |
| 22 | -- These tests require that implementations take account of residues in |
| 23 | -- order to get correct results for some rounding modes. Rather than |
| 24 | -- single rounding tests we therefore need tests for most operators. |
| 25 | -- [We do assume add/minus/plus/subtract are common paths, however, as |
| 26 | -- is rounding of negatives (if the latter works for addition, assume it |
| 27 | -- works for the others, too).] |
| 28 | -- |
Thomas Wouters | 1b7f891 | 2007-09-19 03:06:30 +0000 | [diff] [blame] | 29 | -- Round-for-reround (05UP) is tested as a separate block, mostly for |
| 30 | -- 'historical' reasons. |
| 31 | -- |
| 32 | -- Underflow Subnormal and overflow behaviours are tested under the |
| 33 | -- individual operators. |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 34 | |
| 35 | extended: 1 |
| 36 | precision: 5 -- for easier visual inspection |
| 37 | maxExponent: 999 |
| 38 | minexponent: -999 |
| 39 | |
| 40 | -- Addition operators ------------------------------------------------- |
| 41 | rounding: down |
| 42 | |
| 43 | radx100 add 12345 -0.1 -> 12344 Inexact Rounded |
| 44 | radx101 add 12345 -0.01 -> 12344 Inexact Rounded |
| 45 | radx102 add 12345 -0.001 -> 12344 Inexact Rounded |
| 46 | radx103 add 12345 -0.00001 -> 12344 Inexact Rounded |
| 47 | radx104 add 12345 -0.000001 -> 12344 Inexact Rounded |
| 48 | radx105 add 12345 -0.0000001 -> 12344 Inexact Rounded |
| 49 | radx106 add 12345 0 -> 12345 |
| 50 | radx107 add 12345 0.0000001 -> 12345 Inexact Rounded |
| 51 | radx108 add 12345 0.000001 -> 12345 Inexact Rounded |
| 52 | radx109 add 12345 0.00001 -> 12345 Inexact Rounded |
| 53 | radx110 add 12345 0.0001 -> 12345 Inexact Rounded |
| 54 | radx111 add 12345 0.001 -> 12345 Inexact Rounded |
| 55 | radx112 add 12345 0.01 -> 12345 Inexact Rounded |
| 56 | radx113 add 12345 0.1 -> 12345 Inexact Rounded |
| 57 | |
| 58 | radx115 add 12346 0.49999 -> 12346 Inexact Rounded |
| 59 | radx116 add 12346 0.5 -> 12346 Inexact Rounded |
| 60 | radx117 add 12346 0.50001 -> 12346 Inexact Rounded |
| 61 | |
| 62 | radx120 add 12345 0.4 -> 12345 Inexact Rounded |
| 63 | radx121 add 12345 0.49 -> 12345 Inexact Rounded |
| 64 | radx122 add 12345 0.499 -> 12345 Inexact Rounded |
| 65 | radx123 add 12345 0.49999 -> 12345 Inexact Rounded |
| 66 | radx124 add 12345 0.5 -> 12345 Inexact Rounded |
| 67 | radx125 add 12345 0.50001 -> 12345 Inexact Rounded |
| 68 | radx126 add 12345 0.5001 -> 12345 Inexact Rounded |
| 69 | radx127 add 12345 0.501 -> 12345 Inexact Rounded |
| 70 | radx128 add 12345 0.51 -> 12345 Inexact Rounded |
| 71 | radx129 add 12345 0.6 -> 12345 Inexact Rounded |
| 72 | |
| 73 | rounding: half_down |
| 74 | |
| 75 | radx140 add 12345 -0.1 -> 12345 Inexact Rounded |
| 76 | radx141 add 12345 -0.01 -> 12345 Inexact Rounded |
| 77 | radx142 add 12345 -0.001 -> 12345 Inexact Rounded |
| 78 | radx143 add 12345 -0.00001 -> 12345 Inexact Rounded |
| 79 | radx144 add 12345 -0.000001 -> 12345 Inexact Rounded |
| 80 | radx145 add 12345 -0.0000001 -> 12345 Inexact Rounded |
| 81 | radx146 add 12345 0 -> 12345 |
| 82 | radx147 add 12345 0.0000001 -> 12345 Inexact Rounded |
| 83 | radx148 add 12345 0.000001 -> 12345 Inexact Rounded |
| 84 | radx149 add 12345 0.00001 -> 12345 Inexact Rounded |
| 85 | radx150 add 12345 0.0001 -> 12345 Inexact Rounded |
| 86 | radx151 add 12345 0.001 -> 12345 Inexact Rounded |
| 87 | radx152 add 12345 0.01 -> 12345 Inexact Rounded |
| 88 | radx153 add 12345 0.1 -> 12345 Inexact Rounded |
| 89 | |
| 90 | radx155 add 12346 0.49999 -> 12346 Inexact Rounded |
| 91 | radx156 add 12346 0.5 -> 12346 Inexact Rounded |
| 92 | radx157 add 12346 0.50001 -> 12347 Inexact Rounded |
| 93 | |
| 94 | radx160 add 12345 0.4 -> 12345 Inexact Rounded |
| 95 | radx161 add 12345 0.49 -> 12345 Inexact Rounded |
| 96 | radx162 add 12345 0.499 -> 12345 Inexact Rounded |
| 97 | radx163 add 12345 0.49999 -> 12345 Inexact Rounded |
| 98 | radx164 add 12345 0.5 -> 12345 Inexact Rounded |
| 99 | radx165 add 12345 0.50001 -> 12346 Inexact Rounded |
| 100 | radx166 add 12345 0.5001 -> 12346 Inexact Rounded |
| 101 | radx167 add 12345 0.501 -> 12346 Inexact Rounded |
| 102 | radx168 add 12345 0.51 -> 12346 Inexact Rounded |
| 103 | radx169 add 12345 0.6 -> 12346 Inexact Rounded |
| 104 | |
| 105 | rounding: half_even |
| 106 | |
| 107 | radx170 add 12345 -0.1 -> 12345 Inexact Rounded |
| 108 | radx171 add 12345 -0.01 -> 12345 Inexact Rounded |
| 109 | radx172 add 12345 -0.001 -> 12345 Inexact Rounded |
| 110 | radx173 add 12345 -0.00001 -> 12345 Inexact Rounded |
| 111 | radx174 add 12345 -0.000001 -> 12345 Inexact Rounded |
| 112 | radx175 add 12345 -0.0000001 -> 12345 Inexact Rounded |
| 113 | radx176 add 12345 0 -> 12345 |
| 114 | radx177 add 12345 0.0000001 -> 12345 Inexact Rounded |
| 115 | radx178 add 12345 0.000001 -> 12345 Inexact Rounded |
| 116 | radx179 add 12345 0.00001 -> 12345 Inexact Rounded |
| 117 | radx180 add 12345 0.0001 -> 12345 Inexact Rounded |
| 118 | radx181 add 12345 0.001 -> 12345 Inexact Rounded |
| 119 | radx182 add 12345 0.01 -> 12345 Inexact Rounded |
| 120 | radx183 add 12345 0.1 -> 12345 Inexact Rounded |
| 121 | |
| 122 | radx185 add 12346 0.49999 -> 12346 Inexact Rounded |
| 123 | radx186 add 12346 0.5 -> 12346 Inexact Rounded |
| 124 | radx187 add 12346 0.50001 -> 12347 Inexact Rounded |
| 125 | |
| 126 | radx190 add 12345 0.4 -> 12345 Inexact Rounded |
| 127 | radx191 add 12345 0.49 -> 12345 Inexact Rounded |
| 128 | radx192 add 12345 0.499 -> 12345 Inexact Rounded |
| 129 | radx193 add 12345 0.49999 -> 12345 Inexact Rounded |
| 130 | radx194 add 12345 0.5 -> 12346 Inexact Rounded |
| 131 | radx195 add 12345 0.50001 -> 12346 Inexact Rounded |
| 132 | radx196 add 12345 0.5001 -> 12346 Inexact Rounded |
| 133 | radx197 add 12345 0.501 -> 12346 Inexact Rounded |
| 134 | radx198 add 12345 0.51 -> 12346 Inexact Rounded |
| 135 | radx199 add 12345 0.6 -> 12346 Inexact Rounded |
| 136 | |
| 137 | rounding: half_up |
| 138 | |
| 139 | radx200 add 12345 -0.1 -> 12345 Inexact Rounded |
| 140 | radx201 add 12345 -0.01 -> 12345 Inexact Rounded |
| 141 | radx202 add 12345 -0.001 -> 12345 Inexact Rounded |
| 142 | radx203 add 12345 -0.00001 -> 12345 Inexact Rounded |
| 143 | radx204 add 12345 -0.000001 -> 12345 Inexact Rounded |
| 144 | radx205 add 12345 -0.0000001 -> 12345 Inexact Rounded |
| 145 | radx206 add 12345 0 -> 12345 |
| 146 | radx207 add 12345 0.0000001 -> 12345 Inexact Rounded |
| 147 | radx208 add 12345 0.000001 -> 12345 Inexact Rounded |
| 148 | radx209 add 12345 0.00001 -> 12345 Inexact Rounded |
| 149 | radx210 add 12345 0.0001 -> 12345 Inexact Rounded |
| 150 | radx211 add 12345 0.001 -> 12345 Inexact Rounded |
| 151 | radx212 add 12345 0.01 -> 12345 Inexact Rounded |
| 152 | radx213 add 12345 0.1 -> 12345 Inexact Rounded |
| 153 | |
| 154 | radx215 add 12346 0.49999 -> 12346 Inexact Rounded |
| 155 | radx216 add 12346 0.5 -> 12347 Inexact Rounded |
| 156 | radx217 add 12346 0.50001 -> 12347 Inexact Rounded |
| 157 | |
| 158 | radx220 add 12345 0.4 -> 12345 Inexact Rounded |
| 159 | radx221 add 12345 0.49 -> 12345 Inexact Rounded |
| 160 | radx222 add 12345 0.499 -> 12345 Inexact Rounded |
| 161 | radx223 add 12345 0.49999 -> 12345 Inexact Rounded |
| 162 | radx224 add 12345 0.5 -> 12346 Inexact Rounded |
| 163 | radx225 add 12345 0.50001 -> 12346 Inexact Rounded |
| 164 | radx226 add 12345 0.5001 -> 12346 Inexact Rounded |
| 165 | radx227 add 12345 0.501 -> 12346 Inexact Rounded |
| 166 | radx228 add 12345 0.51 -> 12346 Inexact Rounded |
| 167 | radx229 add 12345 0.6 -> 12346 Inexact Rounded |
| 168 | |
| 169 | rounding: up |
| 170 | |
| 171 | radx230 add 12345 -0.1 -> 12345 Inexact Rounded |
| 172 | radx231 add 12345 -0.01 -> 12345 Inexact Rounded |
| 173 | radx232 add 12345 -0.001 -> 12345 Inexact Rounded |
| 174 | radx233 add 12345 -0.00001 -> 12345 Inexact Rounded |
| 175 | radx234 add 12345 -0.000001 -> 12345 Inexact Rounded |
| 176 | radx235 add 12345 -0.0000001 -> 12345 Inexact Rounded |
| 177 | radx236 add 12345 0 -> 12345 |
| 178 | radx237 add 12345 0.0000001 -> 12346 Inexact Rounded |
| 179 | radx238 add 12345 0.000001 -> 12346 Inexact Rounded |
| 180 | radx239 add 12345 0.00001 -> 12346 Inexact Rounded |
| 181 | radx240 add 12345 0.0001 -> 12346 Inexact Rounded |
| 182 | radx241 add 12345 0.001 -> 12346 Inexact Rounded |
| 183 | radx242 add 12345 0.01 -> 12346 Inexact Rounded |
| 184 | radx243 add 12345 0.1 -> 12346 Inexact Rounded |
| 185 | |
| 186 | radx245 add 12346 0.49999 -> 12347 Inexact Rounded |
| 187 | radx246 add 12346 0.5 -> 12347 Inexact Rounded |
| 188 | radx247 add 12346 0.50001 -> 12347 Inexact Rounded |
| 189 | |
| 190 | radx250 add 12345 0.4 -> 12346 Inexact Rounded |
| 191 | radx251 add 12345 0.49 -> 12346 Inexact Rounded |
| 192 | radx252 add 12345 0.499 -> 12346 Inexact Rounded |
| 193 | radx253 add 12345 0.49999 -> 12346 Inexact Rounded |
| 194 | radx254 add 12345 0.5 -> 12346 Inexact Rounded |
| 195 | radx255 add 12345 0.50001 -> 12346 Inexact Rounded |
| 196 | radx256 add 12345 0.5001 -> 12346 Inexact Rounded |
| 197 | radx257 add 12345 0.501 -> 12346 Inexact Rounded |
| 198 | radx258 add 12345 0.51 -> 12346 Inexact Rounded |
| 199 | radx259 add 12345 0.6 -> 12346 Inexact Rounded |
| 200 | |
| 201 | rounding: floor |
| 202 | |
| 203 | radx300 add 12345 -0.1 -> 12344 Inexact Rounded |
| 204 | radx301 add 12345 -0.01 -> 12344 Inexact Rounded |
| 205 | radx302 add 12345 -0.001 -> 12344 Inexact Rounded |
| 206 | radx303 add 12345 -0.00001 -> 12344 Inexact Rounded |
| 207 | radx304 add 12345 -0.000001 -> 12344 Inexact Rounded |
| 208 | radx305 add 12345 -0.0000001 -> 12344 Inexact Rounded |
| 209 | radx306 add 12345 0 -> 12345 |
| 210 | radx307 add 12345 0.0000001 -> 12345 Inexact Rounded |
| 211 | radx308 add 12345 0.000001 -> 12345 Inexact Rounded |
| 212 | radx309 add 12345 0.00001 -> 12345 Inexact Rounded |
| 213 | radx310 add 12345 0.0001 -> 12345 Inexact Rounded |
| 214 | radx311 add 12345 0.001 -> 12345 Inexact Rounded |
| 215 | radx312 add 12345 0.01 -> 12345 Inexact Rounded |
| 216 | radx313 add 12345 0.1 -> 12345 Inexact Rounded |
| 217 | |
| 218 | radx315 add 12346 0.49999 -> 12346 Inexact Rounded |
| 219 | radx316 add 12346 0.5 -> 12346 Inexact Rounded |
| 220 | radx317 add 12346 0.50001 -> 12346 Inexact Rounded |
| 221 | |
| 222 | radx320 add 12345 0.4 -> 12345 Inexact Rounded |
| 223 | radx321 add 12345 0.49 -> 12345 Inexact Rounded |
| 224 | radx322 add 12345 0.499 -> 12345 Inexact Rounded |
| 225 | radx323 add 12345 0.49999 -> 12345 Inexact Rounded |
| 226 | radx324 add 12345 0.5 -> 12345 Inexact Rounded |
| 227 | radx325 add 12345 0.50001 -> 12345 Inexact Rounded |
| 228 | radx326 add 12345 0.5001 -> 12345 Inexact Rounded |
| 229 | radx327 add 12345 0.501 -> 12345 Inexact Rounded |
| 230 | radx328 add 12345 0.51 -> 12345 Inexact Rounded |
| 231 | radx329 add 12345 0.6 -> 12345 Inexact Rounded |
| 232 | |
| 233 | rounding: ceiling |
| 234 | |
| 235 | radx330 add 12345 -0.1 -> 12345 Inexact Rounded |
| 236 | radx331 add 12345 -0.01 -> 12345 Inexact Rounded |
| 237 | radx332 add 12345 -0.001 -> 12345 Inexact Rounded |
| 238 | radx333 add 12345 -0.00001 -> 12345 Inexact Rounded |
| 239 | radx334 add 12345 -0.000001 -> 12345 Inexact Rounded |
| 240 | radx335 add 12345 -0.0000001 -> 12345 Inexact Rounded |
| 241 | radx336 add 12345 0 -> 12345 |
| 242 | radx337 add 12345 0.0000001 -> 12346 Inexact Rounded |
| 243 | radx338 add 12345 0.000001 -> 12346 Inexact Rounded |
| 244 | radx339 add 12345 0.00001 -> 12346 Inexact Rounded |
| 245 | radx340 add 12345 0.0001 -> 12346 Inexact Rounded |
| 246 | radx341 add 12345 0.001 -> 12346 Inexact Rounded |
| 247 | radx342 add 12345 0.01 -> 12346 Inexact Rounded |
| 248 | radx343 add 12345 0.1 -> 12346 Inexact Rounded |
| 249 | |
| 250 | radx345 add 12346 0.49999 -> 12347 Inexact Rounded |
| 251 | radx346 add 12346 0.5 -> 12347 Inexact Rounded |
| 252 | radx347 add 12346 0.50001 -> 12347 Inexact Rounded |
| 253 | |
| 254 | radx350 add 12345 0.4 -> 12346 Inexact Rounded |
| 255 | radx351 add 12345 0.49 -> 12346 Inexact Rounded |
| 256 | radx352 add 12345 0.499 -> 12346 Inexact Rounded |
| 257 | radx353 add 12345 0.49999 -> 12346 Inexact Rounded |
| 258 | radx354 add 12345 0.5 -> 12346 Inexact Rounded |
| 259 | radx355 add 12345 0.50001 -> 12346 Inexact Rounded |
| 260 | radx356 add 12345 0.5001 -> 12346 Inexact Rounded |
| 261 | radx357 add 12345 0.501 -> 12346 Inexact Rounded |
| 262 | radx358 add 12345 0.51 -> 12346 Inexact Rounded |
| 263 | radx359 add 12345 0.6 -> 12346 Inexact Rounded |
| 264 | |
| 265 | -- negatives... |
| 266 | |
| 267 | rounding: down |
| 268 | |
| 269 | rsux100 add -12345 -0.1 -> -12345 Inexact Rounded |
| 270 | rsux101 add -12345 -0.01 -> -12345 Inexact Rounded |
| 271 | rsux102 add -12345 -0.001 -> -12345 Inexact Rounded |
| 272 | rsux103 add -12345 -0.00001 -> -12345 Inexact Rounded |
| 273 | rsux104 add -12345 -0.000001 -> -12345 Inexact Rounded |
| 274 | rsux105 add -12345 -0.0000001 -> -12345 Inexact Rounded |
| 275 | rsux106 add -12345 0 -> -12345 |
| 276 | rsux107 add -12345 0.0000001 -> -12344 Inexact Rounded |
| 277 | rsux108 add -12345 0.000001 -> -12344 Inexact Rounded |
| 278 | rsux109 add -12345 0.00001 -> -12344 Inexact Rounded |
| 279 | rsux110 add -12345 0.0001 -> -12344 Inexact Rounded |
| 280 | rsux111 add -12345 0.001 -> -12344 Inexact Rounded |
| 281 | rsux112 add -12345 0.01 -> -12344 Inexact Rounded |
| 282 | rsux113 add -12345 0.1 -> -12344 Inexact Rounded |
| 283 | |
| 284 | rsux115 add -12346 0.49999 -> -12345 Inexact Rounded |
| 285 | rsux116 add -12346 0.5 -> -12345 Inexact Rounded |
| 286 | rsux117 add -12346 0.50001 -> -12345 Inexact Rounded |
| 287 | |
| 288 | rsux120 add -12345 0.4 -> -12344 Inexact Rounded |
| 289 | rsux121 add -12345 0.49 -> -12344 Inexact Rounded |
| 290 | rsux122 add -12345 0.499 -> -12344 Inexact Rounded |
| 291 | rsux123 add -12345 0.49999 -> -12344 Inexact Rounded |
| 292 | rsux124 add -12345 0.5 -> -12344 Inexact Rounded |
| 293 | rsux125 add -12345 0.50001 -> -12344 Inexact Rounded |
| 294 | rsux126 add -12345 0.5001 -> -12344 Inexact Rounded |
| 295 | rsux127 add -12345 0.501 -> -12344 Inexact Rounded |
| 296 | rsux128 add -12345 0.51 -> -12344 Inexact Rounded |
| 297 | rsux129 add -12345 0.6 -> -12344 Inexact Rounded |
| 298 | |
| 299 | rounding: half_down |
| 300 | |
| 301 | rsux140 add -12345 -0.1 -> -12345 Inexact Rounded |
| 302 | rsux141 add -12345 -0.01 -> -12345 Inexact Rounded |
| 303 | rsux142 add -12345 -0.001 -> -12345 Inexact Rounded |
| 304 | rsux143 add -12345 -0.00001 -> -12345 Inexact Rounded |
| 305 | rsux144 add -12345 -0.000001 -> -12345 Inexact Rounded |
| 306 | rsux145 add -12345 -0.0000001 -> -12345 Inexact Rounded |
| 307 | rsux146 add -12345 0 -> -12345 |
| 308 | rsux147 add -12345 0.0000001 -> -12345 Inexact Rounded |
| 309 | rsux148 add -12345 0.000001 -> -12345 Inexact Rounded |
| 310 | rsux149 add -12345 0.00001 -> -12345 Inexact Rounded |
| 311 | rsux150 add -12345 0.0001 -> -12345 Inexact Rounded |
| 312 | rsux151 add -12345 0.001 -> -12345 Inexact Rounded |
| 313 | rsux152 add -12345 0.01 -> -12345 Inexact Rounded |
| 314 | rsux153 add -12345 0.1 -> -12345 Inexact Rounded |
| 315 | |
| 316 | rsux155 add -12346 0.49999 -> -12346 Inexact Rounded |
| 317 | rsux156 add -12346 0.5 -> -12345 Inexact Rounded |
| 318 | rsux157 add -12346 0.50001 -> -12345 Inexact Rounded |
| 319 | |
| 320 | rsux160 add -12345 0.4 -> -12345 Inexact Rounded |
| 321 | rsux161 add -12345 0.49 -> -12345 Inexact Rounded |
| 322 | rsux162 add -12345 0.499 -> -12345 Inexact Rounded |
| 323 | rsux163 add -12345 0.49999 -> -12345 Inexact Rounded |
| 324 | rsux164 add -12345 0.5 -> -12344 Inexact Rounded |
| 325 | rsux165 add -12345 0.50001 -> -12344 Inexact Rounded |
| 326 | rsux166 add -12345 0.5001 -> -12344 Inexact Rounded |
| 327 | rsux167 add -12345 0.501 -> -12344 Inexact Rounded |
| 328 | rsux168 add -12345 0.51 -> -12344 Inexact Rounded |
| 329 | rsux169 add -12345 0.6 -> -12344 Inexact Rounded |
| 330 | |
| 331 | rounding: half_even |
| 332 | |
| 333 | rsux170 add -12345 -0.1 -> -12345 Inexact Rounded |
| 334 | rsux171 add -12345 -0.01 -> -12345 Inexact Rounded |
| 335 | rsux172 add -12345 -0.001 -> -12345 Inexact Rounded |
| 336 | rsux173 add -12345 -0.00001 -> -12345 Inexact Rounded |
| 337 | rsux174 add -12345 -0.000001 -> -12345 Inexact Rounded |
| 338 | rsux175 add -12345 -0.0000001 -> -12345 Inexact Rounded |
| 339 | rsux176 add -12345 0 -> -12345 |
| 340 | rsux177 add -12345 0.0000001 -> -12345 Inexact Rounded |
| 341 | rsux178 add -12345 0.000001 -> -12345 Inexact Rounded |
| 342 | rsux179 add -12345 0.00001 -> -12345 Inexact Rounded |
| 343 | rsux180 add -12345 0.0001 -> -12345 Inexact Rounded |
| 344 | rsux181 add -12345 0.001 -> -12345 Inexact Rounded |
| 345 | rsux182 add -12345 0.01 -> -12345 Inexact Rounded |
| 346 | rsux183 add -12345 0.1 -> -12345 Inexact Rounded |
| 347 | |
| 348 | rsux185 add -12346 0.49999 -> -12346 Inexact Rounded |
| 349 | rsux186 add -12346 0.5 -> -12346 Inexact Rounded |
| 350 | rsux187 add -12346 0.50001 -> -12345 Inexact Rounded |
| 351 | |
| 352 | rsux190 add -12345 0.4 -> -12345 Inexact Rounded |
| 353 | rsux191 add -12345 0.49 -> -12345 Inexact Rounded |
| 354 | rsux192 add -12345 0.499 -> -12345 Inexact Rounded |
| 355 | rsux193 add -12345 0.49999 -> -12345 Inexact Rounded |
| 356 | rsux194 add -12345 0.5 -> -12344 Inexact Rounded |
| 357 | rsux195 add -12345 0.50001 -> -12344 Inexact Rounded |
| 358 | rsux196 add -12345 0.5001 -> -12344 Inexact Rounded |
| 359 | rsux197 add -12345 0.501 -> -12344 Inexact Rounded |
| 360 | rsux198 add -12345 0.51 -> -12344 Inexact Rounded |
| 361 | rsux199 add -12345 0.6 -> -12344 Inexact Rounded |
| 362 | |
| 363 | rounding: half_up |
| 364 | |
| 365 | rsux200 add -12345 -0.1 -> -12345 Inexact Rounded |
| 366 | rsux201 add -12345 -0.01 -> -12345 Inexact Rounded |
| 367 | rsux202 add -12345 -0.001 -> -12345 Inexact Rounded |
| 368 | rsux203 add -12345 -0.00001 -> -12345 Inexact Rounded |
| 369 | rsux204 add -12345 -0.000001 -> -12345 Inexact Rounded |
| 370 | rsux205 add -12345 -0.0000001 -> -12345 Inexact Rounded |
| 371 | rsux206 add -12345 0 -> -12345 |
| 372 | rsux207 add -12345 0.0000001 -> -12345 Inexact Rounded |
| 373 | rsux208 add -12345 0.000001 -> -12345 Inexact Rounded |
| 374 | rsux209 add -12345 0.00001 -> -12345 Inexact Rounded |
| 375 | rsux210 add -12345 0.0001 -> -12345 Inexact Rounded |
| 376 | rsux211 add -12345 0.001 -> -12345 Inexact Rounded |
| 377 | rsux212 add -12345 0.01 -> -12345 Inexact Rounded |
| 378 | rsux213 add -12345 0.1 -> -12345 Inexact Rounded |
| 379 | |
| 380 | rsux215 add -12346 0.49999 -> -12346 Inexact Rounded |
| 381 | rsux216 add -12346 0.5 -> -12346 Inexact Rounded |
| 382 | rsux217 add -12346 0.50001 -> -12345 Inexact Rounded |
| 383 | |
| 384 | rsux220 add -12345 0.4 -> -12345 Inexact Rounded |
| 385 | rsux221 add -12345 0.49 -> -12345 Inexact Rounded |
| 386 | rsux222 add -12345 0.499 -> -12345 Inexact Rounded |
| 387 | rsux223 add -12345 0.49999 -> -12345 Inexact Rounded |
| 388 | rsux224 add -12345 0.5 -> -12345 Inexact Rounded |
| 389 | rsux225 add -12345 0.50001 -> -12344 Inexact Rounded |
| 390 | rsux226 add -12345 0.5001 -> -12344 Inexact Rounded |
| 391 | rsux227 add -12345 0.501 -> -12344 Inexact Rounded |
| 392 | rsux228 add -12345 0.51 -> -12344 Inexact Rounded |
| 393 | rsux229 add -12345 0.6 -> -12344 Inexact Rounded |
| 394 | |
| 395 | rounding: up |
| 396 | |
| 397 | rsux230 add -12345 -0.1 -> -12346 Inexact Rounded |
| 398 | rsux231 add -12345 -0.01 -> -12346 Inexact Rounded |
| 399 | rsux232 add -12345 -0.001 -> -12346 Inexact Rounded |
| 400 | rsux233 add -12345 -0.00001 -> -12346 Inexact Rounded |
| 401 | rsux234 add -12345 -0.000001 -> -12346 Inexact Rounded |
| 402 | rsux235 add -12345 -0.0000001 -> -12346 Inexact Rounded |
| 403 | rsux236 add -12345 0 -> -12345 |
| 404 | rsux237 add -12345 0.0000001 -> -12345 Inexact Rounded |
| 405 | rsux238 add -12345 0.000001 -> -12345 Inexact Rounded |
| 406 | rsux239 add -12345 0.00001 -> -12345 Inexact Rounded |
| 407 | rsux240 add -12345 0.0001 -> -12345 Inexact Rounded |
| 408 | rsux241 add -12345 0.001 -> -12345 Inexact Rounded |
| 409 | rsux242 add -12345 0.01 -> -12345 Inexact Rounded |
| 410 | rsux243 add -12345 0.1 -> -12345 Inexact Rounded |
| 411 | |
| 412 | rsux245 add -12346 0.49999 -> -12346 Inexact Rounded |
| 413 | rsux246 add -12346 0.5 -> -12346 Inexact Rounded |
| 414 | rsux247 add -12346 0.50001 -> -12346 Inexact Rounded |
| 415 | |
| 416 | rsux250 add -12345 0.4 -> -12345 Inexact Rounded |
| 417 | rsux251 add -12345 0.49 -> -12345 Inexact Rounded |
| 418 | rsux252 add -12345 0.499 -> -12345 Inexact Rounded |
| 419 | rsux253 add -12345 0.49999 -> -12345 Inexact Rounded |
| 420 | rsux254 add -12345 0.5 -> -12345 Inexact Rounded |
| 421 | rsux255 add -12345 0.50001 -> -12345 Inexact Rounded |
| 422 | rsux256 add -12345 0.5001 -> -12345 Inexact Rounded |
| 423 | rsux257 add -12345 0.501 -> -12345 Inexact Rounded |
| 424 | rsux258 add -12345 0.51 -> -12345 Inexact Rounded |
| 425 | rsux259 add -12345 0.6 -> -12345 Inexact Rounded |
| 426 | |
| 427 | rounding: floor |
| 428 | |
| 429 | rsux300 add -12345 -0.1 -> -12346 Inexact Rounded |
| 430 | rsux301 add -12345 -0.01 -> -12346 Inexact Rounded |
| 431 | rsux302 add -12345 -0.001 -> -12346 Inexact Rounded |
| 432 | rsux303 add -12345 -0.00001 -> -12346 Inexact Rounded |
| 433 | rsux304 add -12345 -0.000001 -> -12346 Inexact Rounded |
| 434 | rsux305 add -12345 -0.0000001 -> -12346 Inexact Rounded |
| 435 | rsux306 add -12345 0 -> -12345 |
| 436 | rsux307 add -12345 0.0000001 -> -12345 Inexact Rounded |
| 437 | rsux308 add -12345 0.000001 -> -12345 Inexact Rounded |
| 438 | rsux309 add -12345 0.00001 -> -12345 Inexact Rounded |
| 439 | rsux310 add -12345 0.0001 -> -12345 Inexact Rounded |
| 440 | rsux311 add -12345 0.001 -> -12345 Inexact Rounded |
| 441 | rsux312 add -12345 0.01 -> -12345 Inexact Rounded |
| 442 | rsux313 add -12345 0.1 -> -12345 Inexact Rounded |
| 443 | |
| 444 | rsux315 add -12346 0.49999 -> -12346 Inexact Rounded |
| 445 | rsux316 add -12346 0.5 -> -12346 Inexact Rounded |
| 446 | rsux317 add -12346 0.50001 -> -12346 Inexact Rounded |
| 447 | |
| 448 | rsux320 add -12345 0.4 -> -12345 Inexact Rounded |
| 449 | rsux321 add -12345 0.49 -> -12345 Inexact Rounded |
| 450 | rsux322 add -12345 0.499 -> -12345 Inexact Rounded |
| 451 | rsux323 add -12345 0.49999 -> -12345 Inexact Rounded |
| 452 | rsux324 add -12345 0.5 -> -12345 Inexact Rounded |
| 453 | rsux325 add -12345 0.50001 -> -12345 Inexact Rounded |
| 454 | rsux326 add -12345 0.5001 -> -12345 Inexact Rounded |
| 455 | rsux327 add -12345 0.501 -> -12345 Inexact Rounded |
| 456 | rsux328 add -12345 0.51 -> -12345 Inexact Rounded |
| 457 | rsux329 add -12345 0.6 -> -12345 Inexact Rounded |
| 458 | |
| 459 | rounding: ceiling |
| 460 | |
| 461 | rsux330 add -12345 -0.1 -> -12345 Inexact Rounded |
| 462 | rsux331 add -12345 -0.01 -> -12345 Inexact Rounded |
| 463 | rsux332 add -12345 -0.001 -> -12345 Inexact Rounded |
| 464 | rsux333 add -12345 -0.00001 -> -12345 Inexact Rounded |
| 465 | rsux334 add -12345 -0.000001 -> -12345 Inexact Rounded |
| 466 | rsux335 add -12345 -0.0000001 -> -12345 Inexact Rounded |
| 467 | rsux336 add -12345 0 -> -12345 |
| 468 | rsux337 add -12345 0.0000001 -> -12344 Inexact Rounded |
| 469 | rsux338 add -12345 0.000001 -> -12344 Inexact Rounded |
| 470 | rsux339 add -12345 0.00001 -> -12344 Inexact Rounded |
| 471 | rsux340 add -12345 0.0001 -> -12344 Inexact Rounded |
| 472 | rsux341 add -12345 0.001 -> -12344 Inexact Rounded |
| 473 | rsux342 add -12345 0.01 -> -12344 Inexact Rounded |
| 474 | rsux343 add -12345 0.1 -> -12344 Inexact Rounded |
| 475 | |
| 476 | rsux345 add -12346 0.49999 -> -12345 Inexact Rounded |
| 477 | rsux346 add -12346 0.5 -> -12345 Inexact Rounded |
| 478 | rsux347 add -12346 0.50001 -> -12345 Inexact Rounded |
| 479 | |
| 480 | rsux350 add -12345 0.4 -> -12344 Inexact Rounded |
| 481 | rsux351 add -12345 0.49 -> -12344 Inexact Rounded |
| 482 | rsux352 add -12345 0.499 -> -12344 Inexact Rounded |
| 483 | rsux353 add -12345 0.49999 -> -12344 Inexact Rounded |
| 484 | rsux354 add -12345 0.5 -> -12344 Inexact Rounded |
| 485 | rsux355 add -12345 0.50001 -> -12344 Inexact Rounded |
| 486 | rsux356 add -12345 0.5001 -> -12344 Inexact Rounded |
| 487 | rsux357 add -12345 0.501 -> -12344 Inexact Rounded |
| 488 | rsux358 add -12345 0.51 -> -12344 Inexact Rounded |
| 489 | rsux359 add -12345 0.6 -> -12344 Inexact Rounded |
| 490 | |
| 491 | -- Check cancellation subtractions |
| 492 | -- (The IEEE 854 'curious rule' in $6.3) |
| 493 | |
| 494 | rounding: down |
| 495 | rzex001 add 0 0 -> 0 |
| 496 | rzex002 add 0 -0 -> 0 |
| 497 | rzex003 add -0 0 -> 0 |
| 498 | rzex004 add -0 -0 -> -0 |
| 499 | rzex005 add 1 -1 -> 0 |
| 500 | rzex006 add -1 1 -> 0 |
| 501 | rzex007 add 1.5 -1.5 -> 0.0 |
| 502 | rzex008 add -1.5 1.5 -> 0.0 |
| 503 | rzex009 add 2 -2 -> 0 |
| 504 | rzex010 add -2 2 -> 0 |
| 505 | |
| 506 | rounding: up |
| 507 | rzex011 add 0 0 -> 0 |
| 508 | rzex012 add 0 -0 -> 0 |
| 509 | rzex013 add -0 0 -> 0 |
| 510 | rzex014 add -0 -0 -> -0 |
| 511 | rzex015 add 1 -1 -> 0 |
| 512 | rzex016 add -1 1 -> 0 |
| 513 | rzex017 add 1.5 -1.5 -> 0.0 |
| 514 | rzex018 add -1.5 1.5 -> 0.0 |
| 515 | rzex019 add 2 -2 -> 0 |
| 516 | rzex020 add -2 2 -> 0 |
| 517 | |
| 518 | rounding: half_up |
| 519 | rzex021 add 0 0 -> 0 |
| 520 | rzex022 add 0 -0 -> 0 |
| 521 | rzex023 add -0 0 -> 0 |
| 522 | rzex024 add -0 -0 -> -0 |
| 523 | rzex025 add 1 -1 -> 0 |
| 524 | rzex026 add -1 1 -> 0 |
| 525 | rzex027 add 1.5 -1.5 -> 0.0 |
| 526 | rzex028 add -1.5 1.5 -> 0.0 |
| 527 | rzex029 add 2 -2 -> 0 |
| 528 | rzex030 add -2 2 -> 0 |
| 529 | |
| 530 | rounding: half_down |
| 531 | rzex031 add 0 0 -> 0 |
| 532 | rzex032 add 0 -0 -> 0 |
| 533 | rzex033 add -0 0 -> 0 |
| 534 | rzex034 add -0 -0 -> -0 |
| 535 | rzex035 add 1 -1 -> 0 |
| 536 | rzex036 add -1 1 -> 0 |
| 537 | rzex037 add 1.5 -1.5 -> 0.0 |
| 538 | rzex038 add -1.5 1.5 -> 0.0 |
| 539 | rzex039 add 2 -2 -> 0 |
| 540 | rzex040 add -2 2 -> 0 |
| 541 | |
| 542 | rounding: half_even |
| 543 | rzex041 add 0 0 -> 0 |
| 544 | rzex042 add 0 -0 -> 0 |
| 545 | rzex043 add -0 0 -> 0 |
| 546 | rzex044 add -0 -0 -> -0 |
| 547 | rzex045 add 1 -1 -> 0 |
| 548 | rzex046 add -1 1 -> 0 |
| 549 | rzex047 add 1.5 -1.5 -> 0.0 |
| 550 | rzex048 add -1.5 1.5 -> 0.0 |
| 551 | rzex049 add 2 -2 -> 0 |
| 552 | rzex050 add -2 2 -> 0 |
| 553 | |
| 554 | rounding: floor |
| 555 | rzex051 add 0 0 -> 0 |
| 556 | rzex052 add 0 -0 -> -0 -- here are two 'curious' |
| 557 | rzex053 add -0 0 -> -0 -- |
| 558 | rzex054 add -0 -0 -> -0 |
| 559 | rzex055 add 1 -1 -> -0 -- here are the rest |
| 560 | rzex056 add -1 1 -> -0 -- .. |
| 561 | rzex057 add 1.5 -1.5 -> -0.0 -- .. |
| 562 | rzex058 add -1.5 1.5 -> -0.0 -- .. |
| 563 | rzex059 add 2 -2 -> -0 -- .. |
| 564 | rzex060 add -2 2 -> -0 -- .. |
| 565 | |
| 566 | rounding: ceiling |
| 567 | rzex061 add 0 0 -> 0 |
| 568 | rzex062 add 0 -0 -> 0 |
| 569 | rzex063 add -0 0 -> 0 |
| 570 | rzex064 add -0 -0 -> -0 |
| 571 | rzex065 add 1 -1 -> 0 |
| 572 | rzex066 add -1 1 -> 0 |
| 573 | rzex067 add 1.5 -1.5 -> 0.0 |
| 574 | rzex068 add -1.5 1.5 -> 0.0 |
| 575 | rzex069 add 2 -2 -> 0 |
| 576 | rzex070 add -2 2 -> 0 |
| 577 | |
| 578 | |
| 579 | -- Division operators ------------------------------------------------- |
| 580 | |
| 581 | rounding: down |
| 582 | rdvx101 divide 12345 1 -> 12345 |
| 583 | rdvx102 divide 12345 1.0001 -> 12343 Inexact Rounded |
| 584 | rdvx103 divide 12345 1.001 -> 12332 Inexact Rounded |
| 585 | rdvx104 divide 12345 1.01 -> 12222 Inexact Rounded |
| 586 | rdvx105 divide 12345 1.1 -> 11222 Inexact Rounded |
| 587 | rdvx106 divide 12355 4 -> 3088.7 Inexact Rounded |
| 588 | rdvx107 divide 12345 4 -> 3086.2 Inexact Rounded |
| 589 | rdvx108 divide 12355 4.0001 -> 3088.6 Inexact Rounded |
| 590 | rdvx109 divide 12345 4.0001 -> 3086.1 Inexact Rounded |
| 591 | rdvx110 divide 12345 4.9 -> 2519.3 Inexact Rounded |
| 592 | rdvx111 divide 12345 4.99 -> 2473.9 Inexact Rounded |
| 593 | rdvx112 divide 12345 4.999 -> 2469.4 Inexact Rounded |
| 594 | rdvx113 divide 12345 4.9999 -> 2469.0 Inexact Rounded |
| 595 | rdvx114 divide 12345 5 -> 2469 |
| 596 | rdvx115 divide 12345 5.0001 -> 2468.9 Inexact Rounded |
| 597 | rdvx116 divide 12345 5.001 -> 2468.5 Inexact Rounded |
| 598 | rdvx117 divide 12345 5.01 -> 2464.0 Inexact Rounded |
| 599 | rdvx118 divide 12345 5.1 -> 2420.5 Inexact Rounded |
| 600 | |
| 601 | rounding: half_down |
| 602 | rdvx201 divide 12345 1 -> 12345 |
| 603 | rdvx202 divide 12345 1.0001 -> 12344 Inexact Rounded |
| 604 | rdvx203 divide 12345 1.001 -> 12333 Inexact Rounded |
| 605 | rdvx204 divide 12345 1.01 -> 12223 Inexact Rounded |
| 606 | rdvx205 divide 12345 1.1 -> 11223 Inexact Rounded |
| 607 | rdvx206 divide 12355 4 -> 3088.7 Inexact Rounded |
| 608 | rdvx207 divide 12345 4 -> 3086.2 Inexact Rounded |
| 609 | rdvx208 divide 12355 4.0001 -> 3088.7 Inexact Rounded |
| 610 | rdvx209 divide 12345 4.0001 -> 3086.2 Inexact Rounded |
| 611 | rdvx210 divide 12345 4.9 -> 2519.4 Inexact Rounded |
| 612 | rdvx211 divide 12345 4.99 -> 2473.9 Inexact Rounded |
| 613 | rdvx212 divide 12345 4.999 -> 2469.5 Inexact Rounded |
| 614 | rdvx213 divide 12345 4.9999 -> 2469.0 Inexact Rounded |
| 615 | rdvx214 divide 12345 5 -> 2469 |
| 616 | rdvx215 divide 12345 5.0001 -> 2469.0 Inexact Rounded |
| 617 | rdvx216 divide 12345 5.001 -> 2468.5 Inexact Rounded |
| 618 | rdvx217 divide 12345 5.01 -> 2464.1 Inexact Rounded |
| 619 | rdvx218 divide 12345 5.1 -> 2420.6 Inexact Rounded |
| 620 | |
| 621 | rounding: half_even |
| 622 | rdvx301 divide 12345 1 -> 12345 |
| 623 | rdvx302 divide 12345 1.0001 -> 12344 Inexact Rounded |
| 624 | rdvx303 divide 12345 1.001 -> 12333 Inexact Rounded |
| 625 | rdvx304 divide 12345 1.01 -> 12223 Inexact Rounded |
| 626 | rdvx305 divide 12345 1.1 -> 11223 Inexact Rounded |
| 627 | rdvx306 divide 12355 4 -> 3088.8 Inexact Rounded |
| 628 | rdvx307 divide 12345 4 -> 3086.2 Inexact Rounded |
| 629 | rdvx308 divide 12355 4.0001 -> 3088.7 Inexact Rounded |
| 630 | rdvx309 divide 12345 4.0001 -> 3086.2 Inexact Rounded |
| 631 | rdvx310 divide 12345 4.9 -> 2519.4 Inexact Rounded |
| 632 | rdvx311 divide 12345 4.99 -> 2473.9 Inexact Rounded |
| 633 | rdvx312 divide 12345 4.999 -> 2469.5 Inexact Rounded |
| 634 | rdvx313 divide 12345 4.9999 -> 2469.0 Inexact Rounded |
| 635 | rdvx314 divide 12345 5 -> 2469 |
| 636 | rdvx315 divide 12345 5.0001 -> 2469.0 Inexact Rounded |
| 637 | rdvx316 divide 12345 5.001 -> 2468.5 Inexact Rounded |
| 638 | rdvx317 divide 12345 5.01 -> 2464.1 Inexact Rounded |
| 639 | rdvx318 divide 12345 5.1 -> 2420.6 Inexact Rounded |
| 640 | |
| 641 | rounding: half_up |
| 642 | rdvx401 divide 12345 1 -> 12345 |
| 643 | rdvx402 divide 12345 1.0001 -> 12344 Inexact Rounded |
| 644 | rdvx403 divide 12345 1.001 -> 12333 Inexact Rounded |
| 645 | rdvx404 divide 12345 1.01 -> 12223 Inexact Rounded |
| 646 | rdvx405 divide 12345 1.1 -> 11223 Inexact Rounded |
| 647 | rdvx406 divide 12355 4 -> 3088.8 Inexact Rounded |
| 648 | rdvx407 divide 12345 4 -> 3086.3 Inexact Rounded |
| 649 | rdvx408 divide 12355 4.0001 -> 3088.7 Inexact Rounded |
| 650 | rdvx409 divide 12345 4.0001 -> 3086.2 Inexact Rounded |
| 651 | rdvx410 divide 12345 4.9 -> 2519.4 Inexact Rounded |
| 652 | rdvx411 divide 12345 4.99 -> 2473.9 Inexact Rounded |
| 653 | rdvx412 divide 12345 4.999 -> 2469.5 Inexact Rounded |
| 654 | rdvx413 divide 12345 4.9999 -> 2469.0 Inexact Rounded |
| 655 | rdvx414 divide 12345 5 -> 2469 |
| 656 | rdvx415 divide 12345 5.0001 -> 2469.0 Inexact Rounded |
| 657 | rdvx416 divide 12345 5.001 -> 2468.5 Inexact Rounded |
| 658 | rdvx417 divide 12345 5.01 -> 2464.1 Inexact Rounded |
| 659 | rdvx418 divide 12345 5.1 -> 2420.6 Inexact Rounded |
| 660 | |
| 661 | rounding: up |
| 662 | rdvx501 divide 12345 1 -> 12345 |
| 663 | rdvx502 divide 12345 1.0001 -> 12344 Inexact Rounded |
| 664 | rdvx503 divide 12345 1.001 -> 12333 Inexact Rounded |
| 665 | rdvx504 divide 12345 1.01 -> 12223 Inexact Rounded |
| 666 | rdvx505 divide 12345 1.1 -> 11223 Inexact Rounded |
| 667 | rdvx506 divide 12355 4 -> 3088.8 Inexact Rounded |
| 668 | rdvx507 divide 12345 4 -> 3086.3 Inexact Rounded |
| 669 | rdvx508 divide 12355 4.0001 -> 3088.7 Inexact Rounded |
| 670 | rdvx509 divide 12345 4.0001 -> 3086.2 Inexact Rounded |
| 671 | rdvx510 divide 12345 4.9 -> 2519.4 Inexact Rounded |
| 672 | rdvx511 divide 12345 4.99 -> 2474.0 Inexact Rounded |
| 673 | rdvx512 divide 12345 4.999 -> 2469.5 Inexact Rounded |
| 674 | rdvx513 divide 12345 4.9999 -> 2469.1 Inexact Rounded |
| 675 | rdvx514 divide 12345 5 -> 2469 |
| 676 | rdvx515 divide 12345 5.0001 -> 2469.0 Inexact Rounded |
| 677 | rdvx516 divide 12345 5.001 -> 2468.6 Inexact Rounded |
| 678 | rdvx517 divide 12345 5.01 -> 2464.1 Inexact Rounded |
| 679 | rdvx518 divide 12345 5.1 -> 2420.6 Inexact Rounded |
| 680 | |
| 681 | rounding: floor |
| 682 | rdvx601 divide 12345 1 -> 12345 |
| 683 | rdvx602 divide 12345 1.0001 -> 12343 Inexact Rounded |
| 684 | rdvx603 divide 12345 1.001 -> 12332 Inexact Rounded |
| 685 | rdvx604 divide 12345 1.01 -> 12222 Inexact Rounded |
| 686 | rdvx605 divide 12345 1.1 -> 11222 Inexact Rounded |
| 687 | rdvx606 divide 12355 4 -> 3088.7 Inexact Rounded |
| 688 | rdvx607 divide 12345 4 -> 3086.2 Inexact Rounded |
| 689 | rdvx608 divide 12355 4.0001 -> 3088.6 Inexact Rounded |
| 690 | rdvx609 divide 12345 4.0001 -> 3086.1 Inexact Rounded |
| 691 | rdvx610 divide 12345 4.9 -> 2519.3 Inexact Rounded |
| 692 | rdvx611 divide 12345 4.99 -> 2473.9 Inexact Rounded |
| 693 | rdvx612 divide 12345 4.999 -> 2469.4 Inexact Rounded |
| 694 | rdvx613 divide 12345 4.9999 -> 2469.0 Inexact Rounded |
| 695 | rdvx614 divide 12345 5 -> 2469 |
| 696 | rdvx615 divide 12345 5.0001 -> 2468.9 Inexact Rounded |
| 697 | rdvx616 divide 12345 5.001 -> 2468.5 Inexact Rounded |
| 698 | rdvx617 divide 12345 5.01 -> 2464.0 Inexact Rounded |
| 699 | rdvx618 divide 12345 5.1 -> 2420.5 Inexact Rounded |
| 700 | |
| 701 | rounding: ceiling |
| 702 | rdvx701 divide 12345 1 -> 12345 |
| 703 | rdvx702 divide 12345 1.0001 -> 12344 Inexact Rounded |
| 704 | rdvx703 divide 12345 1.001 -> 12333 Inexact Rounded |
| 705 | rdvx704 divide 12345 1.01 -> 12223 Inexact Rounded |
| 706 | rdvx705 divide 12345 1.1 -> 11223 Inexact Rounded |
| 707 | rdvx706 divide 12355 4 -> 3088.8 Inexact Rounded |
| 708 | rdvx707 divide 12345 4 -> 3086.3 Inexact Rounded |
| 709 | rdvx708 divide 12355 4.0001 -> 3088.7 Inexact Rounded |
| 710 | rdvx709 divide 12345 4.0001 -> 3086.2 Inexact Rounded |
| 711 | rdvx710 divide 12345 4.9 -> 2519.4 Inexact Rounded |
| 712 | rdvx711 divide 12345 4.99 -> 2474.0 Inexact Rounded |
| 713 | rdvx712 divide 12345 4.999 -> 2469.5 Inexact Rounded |
| 714 | rdvx713 divide 12345 4.9999 -> 2469.1 Inexact Rounded |
| 715 | rdvx714 divide 12345 5 -> 2469 |
| 716 | rdvx715 divide 12345 5.0001 -> 2469.0 Inexact Rounded |
| 717 | rdvx716 divide 12345 5.001 -> 2468.6 Inexact Rounded |
| 718 | rdvx717 divide 12345 5.01 -> 2464.1 Inexact Rounded |
| 719 | rdvx718 divide 12345 5.1 -> 2420.6 Inexact Rounded |
| 720 | |
| 721 | -- [divideInteger and remainder unaffected] |
| 722 | |
| 723 | -- Multiplication operator -------------------------------------------- |
| 724 | |
| 725 | rounding: down |
| 726 | rmux101 multiply 12345 1 -> 12345 |
| 727 | rmux102 multiply 12345 1.0001 -> 12346 Inexact Rounded |
| 728 | rmux103 multiply 12345 1.001 -> 12357 Inexact Rounded |
| 729 | rmux104 multiply 12345 1.01 -> 12468 Inexact Rounded |
| 730 | rmux105 multiply 12345 1.1 -> 13579 Inexact Rounded |
| 731 | rmux106 multiply 12345 4 -> 49380 |
| 732 | rmux107 multiply 12345 4.0001 -> 49381 Inexact Rounded |
| 733 | rmux108 multiply 12345 4.9 -> 60490 Inexact Rounded |
| 734 | rmux109 multiply 12345 4.99 -> 61601 Inexact Rounded |
| 735 | rmux110 multiply 12345 4.999 -> 61712 Inexact Rounded |
| 736 | rmux111 multiply 12345 4.9999 -> 61723 Inexact Rounded |
| 737 | rmux112 multiply 12345 5 -> 61725 |
| 738 | rmux113 multiply 12345 5.0001 -> 61726 Inexact Rounded |
| 739 | rmux114 multiply 12345 5.001 -> 61737 Inexact Rounded |
| 740 | rmux115 multiply 12345 5.01 -> 61848 Inexact Rounded |
| 741 | rmux116 multiply 12345 12 -> 1.4814E+5 Rounded |
| 742 | rmux117 multiply 12345 13 -> 1.6048E+5 Inexact Rounded |
| 743 | rmux118 multiply 12355 12 -> 1.4826E+5 Rounded |
| 744 | rmux119 multiply 12355 13 -> 1.6061E+5 Inexact Rounded |
| 745 | |
| 746 | rounding: half_down |
| 747 | rmux201 multiply 12345 1 -> 12345 |
| 748 | rmux202 multiply 12345 1.0001 -> 12346 Inexact Rounded |
| 749 | rmux203 multiply 12345 1.001 -> 12357 Inexact Rounded |
| 750 | rmux204 multiply 12345 1.01 -> 12468 Inexact Rounded |
| 751 | rmux205 multiply 12345 1.1 -> 13579 Inexact Rounded |
| 752 | rmux206 multiply 12345 4 -> 49380 |
| 753 | rmux207 multiply 12345 4.0001 -> 49381 Inexact Rounded |
| 754 | rmux208 multiply 12345 4.9 -> 60490 Inexact Rounded |
| 755 | rmux209 multiply 12345 4.99 -> 61602 Inexact Rounded |
| 756 | rmux210 multiply 12345 4.999 -> 61713 Inexact Rounded |
| 757 | rmux211 multiply 12345 4.9999 -> 61724 Inexact Rounded |
| 758 | rmux212 multiply 12345 5 -> 61725 |
| 759 | rmux213 multiply 12345 5.0001 -> 61726 Inexact Rounded |
| 760 | rmux214 multiply 12345 5.001 -> 61737 Inexact Rounded |
| 761 | rmux215 multiply 12345 5.01 -> 61848 Inexact Rounded |
| 762 | rmux216 multiply 12345 12 -> 1.4814E+5 Rounded |
| 763 | rmux217 multiply 12345 13 -> 1.6048E+5 Inexact Rounded |
| 764 | rmux218 multiply 12355 12 -> 1.4826E+5 Rounded |
| 765 | rmux219 multiply 12355 13 -> 1.6061E+5 Inexact Rounded |
| 766 | |
| 767 | rounding: half_even |
| 768 | rmux301 multiply 12345 1 -> 12345 |
| 769 | rmux302 multiply 12345 1.0001 -> 12346 Inexact Rounded |
| 770 | rmux303 multiply 12345 1.001 -> 12357 Inexact Rounded |
| 771 | rmux304 multiply 12345 1.01 -> 12468 Inexact Rounded |
| 772 | rmux305 multiply 12345 1.1 -> 13580 Inexact Rounded |
| 773 | rmux306 multiply 12345 4 -> 49380 |
| 774 | rmux307 multiply 12345 4.0001 -> 49381 Inexact Rounded |
| 775 | rmux308 multiply 12345 4.9 -> 60490 Inexact Rounded |
| 776 | rmux309 multiply 12345 4.99 -> 61602 Inexact Rounded |
| 777 | rmux310 multiply 12345 4.999 -> 61713 Inexact Rounded |
| 778 | rmux311 multiply 12345 4.9999 -> 61724 Inexact Rounded |
| 779 | rmux312 multiply 12345 5 -> 61725 |
| 780 | rmux313 multiply 12345 5.0001 -> 61726 Inexact Rounded |
| 781 | rmux314 multiply 12345 5.001 -> 61737 Inexact Rounded |
| 782 | rmux315 multiply 12345 5.01 -> 61848 Inexact Rounded |
| 783 | rmux316 multiply 12345 12 -> 1.4814E+5 Rounded |
| 784 | rmux317 multiply 12345 13 -> 1.6048E+5 Inexact Rounded |
| 785 | rmux318 multiply 12355 12 -> 1.4826E+5 Rounded |
| 786 | rmux319 multiply 12355 13 -> 1.6062E+5 Inexact Rounded |
| 787 | |
| 788 | rounding: half_up |
| 789 | rmux401 multiply 12345 1 -> 12345 |
| 790 | rmux402 multiply 12345 1.0001 -> 12346 Inexact Rounded |
| 791 | rmux403 multiply 12345 1.001 -> 12357 Inexact Rounded |
| 792 | rmux404 multiply 12345 1.01 -> 12468 Inexact Rounded |
| 793 | rmux405 multiply 12345 1.1 -> 13580 Inexact Rounded |
| 794 | rmux406 multiply 12345 4 -> 49380 |
| 795 | rmux407 multiply 12345 4.0001 -> 49381 Inexact Rounded |
| 796 | rmux408 multiply 12345 4.9 -> 60491 Inexact Rounded |
| 797 | rmux409 multiply 12345 4.99 -> 61602 Inexact Rounded |
| 798 | rmux410 multiply 12345 4.999 -> 61713 Inexact Rounded |
| 799 | rmux411 multiply 12345 4.9999 -> 61724 Inexact Rounded |
| 800 | rmux412 multiply 12345 5 -> 61725 |
| 801 | rmux413 multiply 12345 5.0001 -> 61726 Inexact Rounded |
| 802 | rmux414 multiply 12345 5.001 -> 61737 Inexact Rounded |
| 803 | rmux415 multiply 12345 5.01 -> 61848 Inexact Rounded |
| 804 | rmux416 multiply 12345 12 -> 1.4814E+5 Rounded |
| 805 | rmux417 multiply 12345 13 -> 1.6049E+5 Inexact Rounded |
| 806 | rmux418 multiply 12355 12 -> 1.4826E+5 Rounded |
| 807 | rmux419 multiply 12355 13 -> 1.6062E+5 Inexact Rounded |
| 808 | |
| 809 | rounding: up |
| 810 | rmux501 multiply 12345 1 -> 12345 |
| 811 | rmux502 multiply 12345 1.0001 -> 12347 Inexact Rounded |
| 812 | rmux503 multiply 12345 1.001 -> 12358 Inexact Rounded |
| 813 | rmux504 multiply 12345 1.01 -> 12469 Inexact Rounded |
| 814 | rmux505 multiply 12345 1.1 -> 13580 Inexact Rounded |
| 815 | rmux506 multiply 12345 4 -> 49380 |
| 816 | rmux507 multiply 12345 4.0001 -> 49382 Inexact Rounded |
| 817 | rmux508 multiply 12345 4.9 -> 60491 Inexact Rounded |
| 818 | rmux509 multiply 12345 4.99 -> 61602 Inexact Rounded |
| 819 | rmux510 multiply 12345 4.999 -> 61713 Inexact Rounded |
| 820 | rmux511 multiply 12345 4.9999 -> 61724 Inexact Rounded |
| 821 | rmux512 multiply 12345 5 -> 61725 |
| 822 | rmux513 multiply 12345 5.0001 -> 61727 Inexact Rounded |
| 823 | rmux514 multiply 12345 5.001 -> 61738 Inexact Rounded |
| 824 | rmux515 multiply 12345 5.01 -> 61849 Inexact Rounded |
| 825 | rmux516 multiply 12345 12 -> 1.4814E+5 Rounded |
| 826 | rmux517 multiply 12345 13 -> 1.6049E+5 Inexact Rounded |
| 827 | rmux518 multiply 12355 12 -> 1.4826E+5 Rounded |
| 828 | rmux519 multiply 12355 13 -> 1.6062E+5 Inexact Rounded |
| 829 | -- [rmux516 & rmux518] can surprise |
| 830 | |
| 831 | rounding: floor |
| 832 | rmux601 multiply 12345 1 -> 12345 |
| 833 | rmux602 multiply 12345 1.0001 -> 12346 Inexact Rounded |
| 834 | rmux603 multiply 12345 1.001 -> 12357 Inexact Rounded |
| 835 | rmux604 multiply 12345 1.01 -> 12468 Inexact Rounded |
| 836 | rmux605 multiply 12345 1.1 -> 13579 Inexact Rounded |
| 837 | rmux606 multiply 12345 4 -> 49380 |
| 838 | rmux607 multiply 12345 4.0001 -> 49381 Inexact Rounded |
| 839 | rmux608 multiply 12345 4.9 -> 60490 Inexact Rounded |
| 840 | rmux609 multiply 12345 4.99 -> 61601 Inexact Rounded |
| 841 | rmux610 multiply 12345 4.999 -> 61712 Inexact Rounded |
| 842 | rmux611 multiply 12345 4.9999 -> 61723 Inexact Rounded |
| 843 | rmux612 multiply 12345 5 -> 61725 |
| 844 | rmux613 multiply 12345 5.0001 -> 61726 Inexact Rounded |
| 845 | rmux614 multiply 12345 5.001 -> 61737 Inexact Rounded |
| 846 | rmux615 multiply 12345 5.01 -> 61848 Inexact Rounded |
| 847 | rmux616 multiply 12345 12 -> 1.4814E+5 Rounded |
| 848 | rmux617 multiply 12345 13 -> 1.6048E+5 Inexact Rounded |
| 849 | rmux618 multiply 12355 12 -> 1.4826E+5 Rounded |
| 850 | rmux619 multiply 12355 13 -> 1.6061E+5 Inexact Rounded |
| 851 | |
| 852 | rounding: ceiling |
| 853 | rmux701 multiply 12345 1 -> 12345 |
| 854 | rmux702 multiply 12345 1.0001 -> 12347 Inexact Rounded |
| 855 | rmux703 multiply 12345 1.001 -> 12358 Inexact Rounded |
| 856 | rmux704 multiply 12345 1.01 -> 12469 Inexact Rounded |
| 857 | rmux705 multiply 12345 1.1 -> 13580 Inexact Rounded |
| 858 | rmux706 multiply 12345 4 -> 49380 |
| 859 | rmux707 multiply 12345 4.0001 -> 49382 Inexact Rounded |
| 860 | rmux708 multiply 12345 4.9 -> 60491 Inexact Rounded |
| 861 | rmux709 multiply 12345 4.99 -> 61602 Inexact Rounded |
| 862 | rmux710 multiply 12345 4.999 -> 61713 Inexact Rounded |
| 863 | rmux711 multiply 12345 4.9999 -> 61724 Inexact Rounded |
| 864 | rmux712 multiply 12345 5 -> 61725 |
| 865 | rmux713 multiply 12345 5.0001 -> 61727 Inexact Rounded |
| 866 | rmux714 multiply 12345 5.001 -> 61738 Inexact Rounded |
| 867 | rmux715 multiply 12345 5.01 -> 61849 Inexact Rounded |
| 868 | rmux716 multiply 12345 12 -> 1.4814E+5 Rounded |
| 869 | rmux717 multiply 12345 13 -> 1.6049E+5 Inexact Rounded |
| 870 | rmux718 multiply 12355 12 -> 1.4826E+5 Rounded |
| 871 | rmux719 multiply 12355 13 -> 1.6062E+5 Inexact Rounded |
| 872 | |
| 873 | -- Power operator ----------------------------------------------------- |
| 874 | |
| 875 | rounding: down |
| 876 | rpox101 power 12345 -5 -> 3.4877E-21 Inexact Rounded |
| 877 | rpox102 power 12345 -4 -> 4.3056E-17 Inexact Rounded |
| 878 | rpox103 power 12345 -3 -> 5.3152E-13 Inexact Rounded |
| 879 | rpox104 power 12345 -2 -> 6.5617E-9 Inexact Rounded |
| 880 | rpox105 power 12345 -1 -> 0.000081004 Inexact Rounded |
| 881 | rpox106 power 12345 0 -> 1 |
| 882 | rpox107 power 12345 1 -> 12345 |
| 883 | rpox108 power 12345 2 -> 1.5239E+8 Inexact Rounded |
| 884 | rpox109 power 12345 3 -> 1.8813E+12 Inexact Rounded |
| 885 | rpox110 power 12345 4 -> 2.3225E+16 Inexact Rounded |
| 886 | rpox111 power 12345 5 -> 2.8671E+20 Inexact Rounded |
| 887 | rpox112 power 415 2 -> 1.7222E+5 Inexact Rounded |
| 888 | rpox113 power 75 3 -> 4.2187E+5 Inexact Rounded |
| 889 | |
| 890 | rounding: half_down |
| 891 | rpox201 power 12345 -5 -> 3.4877E-21 Inexact Rounded |
| 892 | rpox202 power 12345 -4 -> 4.3056E-17 Inexact Rounded |
| 893 | rpox203 power 12345 -3 -> 5.3153E-13 Inexact Rounded |
| 894 | rpox204 power 12345 -2 -> 6.5617E-9 Inexact Rounded |
| 895 | rpox205 power 12345 -1 -> 0.000081004 Inexact Rounded |
| 896 | rpox206 power 12345 0 -> 1 |
| 897 | rpox207 power 12345 1 -> 12345 |
| 898 | rpox208 power 12345 2 -> 1.5240E+8 Inexact Rounded |
| 899 | rpox209 power 12345 3 -> 1.8814E+12 Inexact Rounded |
| 900 | rpox210 power 12345 4 -> 2.3225E+16 Inexact Rounded |
| 901 | rpox211 power 12345 5 -> 2.8672E+20 Inexact Rounded |
| 902 | rpox212 power 415 2 -> 1.7222E+5 Inexact Rounded |
| 903 | rpox213 power 75 3 -> 4.2187E+5 Inexact Rounded |
| 904 | |
| 905 | rounding: half_even |
| 906 | rpox301 power 12345 -5 -> 3.4877E-21 Inexact Rounded |
| 907 | rpox302 power 12345 -4 -> 4.3056E-17 Inexact Rounded |
| 908 | rpox303 power 12345 -3 -> 5.3153E-13 Inexact Rounded |
| 909 | rpox304 power 12345 -2 -> 6.5617E-9 Inexact Rounded |
| 910 | rpox305 power 12345 -1 -> 0.000081004 Inexact Rounded |
| 911 | rpox306 power 12345 0 -> 1 |
| 912 | rpox307 power 12345 1 -> 12345 |
| 913 | rpox308 power 12345 2 -> 1.5240E+8 Inexact Rounded |
| 914 | rpox309 power 12345 3 -> 1.8814E+12 Inexact Rounded |
| 915 | rpox310 power 12345 4 -> 2.3225E+16 Inexact Rounded |
| 916 | rpox311 power 12345 5 -> 2.8672E+20 Inexact Rounded |
| 917 | rpox312 power 415 2 -> 1.7222E+5 Inexact Rounded |
| 918 | rpox313 power 75 3 -> 4.2188E+5 Inexact Rounded |
| 919 | |
| 920 | rounding: half_up |
| 921 | rpox401 power 12345 -5 -> 3.4877E-21 Inexact Rounded |
| 922 | rpox402 power 12345 -4 -> 4.3056E-17 Inexact Rounded |
| 923 | rpox403 power 12345 -3 -> 5.3153E-13 Inexact Rounded |
| 924 | rpox404 power 12345 -2 -> 6.5617E-9 Inexact Rounded |
| 925 | rpox405 power 12345 -1 -> 0.000081004 Inexact Rounded |
| 926 | rpox406 power 12345 0 -> 1 |
| 927 | rpox407 power 12345 1 -> 12345 |
| 928 | rpox408 power 12345 2 -> 1.5240E+8 Inexact Rounded |
| 929 | rpox409 power 12345 3 -> 1.8814E+12 Inexact Rounded |
| 930 | rpox410 power 12345 4 -> 2.3225E+16 Inexact Rounded |
| 931 | rpox411 power 12345 5 -> 2.8672E+20 Inexact Rounded |
| 932 | rpox412 power 415 2 -> 1.7223E+5 Inexact Rounded |
| 933 | rpox413 power 75 3 -> 4.2188E+5 Inexact Rounded |
| 934 | |
| 935 | rounding: up |
| 936 | rpox501 power 12345 -5 -> 3.4878E-21 Inexact Rounded |
| 937 | rpox502 power 12345 -4 -> 4.3057E-17 Inexact Rounded |
| 938 | rpox503 power 12345 -3 -> 5.3153E-13 Inexact Rounded |
| 939 | rpox504 power 12345 -2 -> 6.5618E-9 Inexact Rounded |
| 940 | rpox505 power 12345 -1 -> 0.000081005 Inexact Rounded |
| 941 | rpox506 power 12345 0 -> 1 |
| 942 | rpox507 power 12345 1 -> 12345 |
| 943 | rpox508 power 12345 2 -> 1.5240E+8 Inexact Rounded |
| 944 | rpox509 power 12345 3 -> 1.8814E+12 Inexact Rounded |
| 945 | rpox510 power 12345 4 -> 2.3226E+16 Inexact Rounded |
| 946 | rpox511 power 12345 5 -> 2.8672E+20 Inexact Rounded |
| 947 | rpox512 power 415 2 -> 1.7223E+5 Inexact Rounded |
| 948 | rpox513 power 75 3 -> 4.2188E+5 Inexact Rounded |
| 949 | |
| 950 | rounding: floor |
| 951 | rpox601 power 12345 -5 -> 3.4877E-21 Inexact Rounded |
| 952 | rpox602 power 12345 -4 -> 4.3056E-17 Inexact Rounded |
| 953 | rpox603 power 12345 -3 -> 5.3152E-13 Inexact Rounded |
| 954 | rpox604 power 12345 -2 -> 6.5617E-9 Inexact Rounded |
| 955 | rpox605 power 12345 -1 -> 0.000081004 Inexact Rounded |
| 956 | rpox606 power 12345 0 -> 1 |
| 957 | rpox607 power 12345 1 -> 12345 |
| 958 | rpox608 power 12345 2 -> 1.5239E+8 Inexact Rounded |
| 959 | rpox609 power 12345 3 -> 1.8813E+12 Inexact Rounded |
| 960 | rpox610 power 12345 4 -> 2.3225E+16 Inexact Rounded |
| 961 | rpox611 power 12345 5 -> 2.8671E+20 Inexact Rounded |
| 962 | rpox612 power 415 2 -> 1.7222E+5 Inexact Rounded |
| 963 | rpox613 power 75 3 -> 4.2187E+5 Inexact Rounded |
| 964 | |
| 965 | rounding: ceiling |
| 966 | rpox701 power 12345 -5 -> 3.4878E-21 Inexact Rounded |
| 967 | rpox702 power 12345 -4 -> 4.3057E-17 Inexact Rounded |
| 968 | rpox703 power 12345 -3 -> 5.3153E-13 Inexact Rounded |
| 969 | rpox704 power 12345 -2 -> 6.5618E-9 Inexact Rounded |
| 970 | rpox705 power 12345 -1 -> 0.000081005 Inexact Rounded |
| 971 | rpox706 power 12345 0 -> 1 |
| 972 | rpox707 power 12345 1 -> 12345 |
| 973 | rpox708 power 12345 2 -> 1.5240E+8 Inexact Rounded |
| 974 | rpox709 power 12345 3 -> 1.8814E+12 Inexact Rounded |
| 975 | rpox710 power 12345 4 -> 2.3226E+16 Inexact Rounded |
| 976 | rpox711 power 12345 5 -> 2.8672E+20 Inexact Rounded |
| 977 | rpox712 power 415 2 -> 1.7223E+5 Inexact Rounded |
| 978 | rpox713 power 75 3 -> 4.2188E+5 Inexact Rounded |
| 979 | |
| 980 | -- Underflow Subnormal and overflow values vary with rounding mode and sign |
| 981 | maxexponent: 999999999 |
| 982 | minexponent: -999999999 |
| 983 | rounding: down |
| 984 | rovx100 multiply 10 9E+999999999 -> 9.9999E+999999999 Overflow Inexact Rounded |
| 985 | rovx101 multiply -10 9E+999999999 -> -9.9999E+999999999 Overflow Inexact Rounded |
Thomas Wouters | 1b7f891 | 2007-09-19 03:06:30 +0000 | [diff] [blame] | 986 | rovx102 divide 1E-9 9E+999999999 -> 0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
| 987 | rovx104 divide -1E-9 9E+999999999 -> -0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 988 | |
| 989 | rounding: up |
| 990 | rovx110 multiply 10 9E+999999999 -> Infinity Overflow Inexact Rounded |
| 991 | rovx111 multiply -10 9E+999999999 -> -Infinity Overflow Inexact Rounded |
| 992 | rovx112 divide 1E-9 9E+999999999 -> 1E-1000000003 Underflow Subnormal Inexact Rounded |
| 993 | rovx114 divide -1E-9 9E+999999999 -> -1E-1000000003 Underflow Subnormal Inexact Rounded |
| 994 | |
| 995 | rounding: ceiling |
| 996 | rovx120 multiply 10 9E+999999999 -> Infinity Overflow Inexact Rounded |
| 997 | rovx121 multiply -10 9E+999999999 -> -9.9999E+999999999 Overflow Inexact Rounded |
| 998 | rovx122 divide 1E-9 9E+999999999 -> 1E-1000000003 Underflow Subnormal Inexact Rounded |
Thomas Wouters | 1b7f891 | 2007-09-19 03:06:30 +0000 | [diff] [blame] | 999 | rovx124 divide -1E-9 9E+999999999 -> -0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 1000 | |
| 1001 | rounding: floor |
| 1002 | rovx130 multiply 10 9E+999999999 -> 9.9999E+999999999 Overflow Inexact Rounded |
| 1003 | rovx131 multiply -10 9E+999999999 -> -Infinity Overflow Inexact Rounded |
Thomas Wouters | 1b7f891 | 2007-09-19 03:06:30 +0000 | [diff] [blame] | 1004 | rovx132 divide 1E-9 9E+999999999 -> 0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 1005 | rovx134 divide -1E-9 9E+999999999 -> -1E-1000000003 Underflow Subnormal Inexact Rounded |
| 1006 | |
| 1007 | rounding: half_up |
| 1008 | rovx140 multiply 10 9E+999999999 -> Infinity Overflow Inexact Rounded |
| 1009 | rovx141 multiply -10 9E+999999999 -> -Infinity Overflow Inexact Rounded |
Thomas Wouters | 1b7f891 | 2007-09-19 03:06:30 +0000 | [diff] [blame] | 1010 | rovx142 divide 1E-9 9E+999999999 -> 0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
| 1011 | rovx144 divide -1E-9 9E+999999999 -> -0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 1012 | |
| 1013 | rounding: half_even |
| 1014 | rovx150 multiply 10 9E+999999999 -> Infinity Overflow Inexact Rounded |
| 1015 | rovx151 multiply -10 9E+999999999 -> -Infinity Overflow Inexact Rounded |
Thomas Wouters | 1b7f891 | 2007-09-19 03:06:30 +0000 | [diff] [blame] | 1016 | rovx152 divide 1E-9 9E+999999999 -> 0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
| 1017 | rovx154 divide -1E-9 9E+999999999 -> -0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 1018 | |
| 1019 | rounding: half_down |
| 1020 | rovx160 multiply 10 9E+999999999 -> Infinity Overflow Inexact Rounded |
| 1021 | rovx161 multiply -10 9E+999999999 -> -Infinity Overflow Inexact Rounded |
Thomas Wouters | 1b7f891 | 2007-09-19 03:06:30 +0000 | [diff] [blame] | 1022 | rovx162 divide 1E-9 9E+999999999 -> 0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
| 1023 | rovx164 divide -1E-9 9E+999999999 -> -0E-1000000003 Underflow Subnormal Inexact Rounded Clamped |
Raymond Hettinger | 7c85fa4 | 2004-07-01 11:01:35 +0000 | [diff] [blame] | 1024 | |
| 1025 | -- check maximum finite value over a range of precisions |
| 1026 | rounding: down |
| 1027 | precision: 1 |
| 1028 | rovx200 multiply 10 9E+999999999 -> 9E+999999999 Overflow Inexact Rounded |
| 1029 | rovx201 multiply -10 9E+999999999 -> -9E+999999999 Overflow Inexact Rounded |
| 1030 | precision: 2 |
| 1031 | rovx210 multiply 10 9E+999999999 -> 9.9E+999999999 Overflow Inexact Rounded |
| 1032 | rovx211 multiply -10 9E+999999999 -> -9.9E+999999999 Overflow Inexact Rounded |
| 1033 | precision: 3 |
| 1034 | rovx220 multiply 10 9E+999999999 -> 9.99E+999999999 Overflow Inexact Rounded |
| 1035 | rovx221 multiply -10 9E+999999999 -> -9.99E+999999999 Overflow Inexact Rounded |
| 1036 | precision: 4 |
| 1037 | rovx230 multiply 10 9E+999999999 -> 9.999E+999999999 Overflow Inexact Rounded |
| 1038 | rovx231 multiply -10 9E+999999999 -> -9.999E+999999999 Overflow Inexact Rounded |
| 1039 | precision: 5 |
| 1040 | rovx240 multiply 10 9E+999999999 -> 9.9999E+999999999 Overflow Inexact Rounded |
| 1041 | rovx241 multiply -10 9E+999999999 -> -9.9999E+999999999 Overflow Inexact Rounded |
| 1042 | precision: 6 |
| 1043 | rovx250 multiply 10 9E+999999999 -> 9.99999E+999999999 Overflow Inexact Rounded |
| 1044 | rovx251 multiply -10 9E+999999999 -> -9.99999E+999999999 Overflow Inexact Rounded |
| 1045 | precision: 7 |
| 1046 | rovx260 multiply 10 9E+999999999 -> 9.999999E+999999999 Overflow Inexact Rounded |
| 1047 | rovx261 multiply -10 9E+999999999 -> -9.999999E+999999999 Overflow Inexact Rounded |
| 1048 | precision: 8 |
| 1049 | rovx270 multiply 10 9E+999999999 -> 9.9999999E+999999999 Overflow Inexact Rounded |
| 1050 | rovx271 multiply -10 9E+999999999 -> -9.9999999E+999999999 Overflow Inexact Rounded |
| 1051 | precision: 9 |
| 1052 | rovx280 multiply 10 9E+999999999 -> 9.99999999E+999999999 Overflow Inexact Rounded |
| 1053 | rovx281 multiply -10 9E+999999999 -> -9.99999999E+999999999 Overflow Inexact Rounded |
| 1054 | precision: 10 |
| 1055 | rovx290 multiply 10 9E+999999999 -> 9.999999999E+999999999 Overflow Inexact Rounded |
| 1056 | rovx291 multiply -10 9E+999999999 -> -9.999999999E+999999999 Overflow Inexact Rounded |
| 1057 | |
| 1058 | -- reprise rounding mode effect (using multiplies so precision directive used) |
| 1059 | precision: 9 |
| 1060 | maxexponent: 999999999 |
| 1061 | rounding: half_up |
| 1062 | rmex400 multiply -9.999E+999999999 10 -> -Infinity Overflow Inexact Rounded |
| 1063 | rmex401 multiply 9.999E+999999999 10 -> Infinity Overflow Inexact Rounded |
| 1064 | rounding: half_down |
| 1065 | rmex402 multiply -9.999E+999999999 10 -> -Infinity Overflow Inexact Rounded |
| 1066 | rmex403 multiply 9.999E+999999999 10 -> Infinity Overflow Inexact Rounded |
| 1067 | rounding: half_even |
| 1068 | rmex404 multiply -9.999E+999999999 10 -> -Infinity Overflow Inexact Rounded |
| 1069 | rmex405 multiply 9.999E+999999999 10 -> Infinity Overflow Inexact Rounded |
| 1070 | rounding: floor |
| 1071 | rmex406 multiply -9.999E+999999999 10 -> -Infinity Overflow Inexact Rounded |
| 1072 | rmex407 multiply 9.999E+999999999 10 -> 9.99999999E+999999999 Overflow Inexact Rounded |
| 1073 | rounding: ceiling |
| 1074 | rmex408 multiply -9.999E+999999999 10 -> -9.99999999E+999999999 Overflow Inexact Rounded |
| 1075 | rmex409 multiply 9.999E+999999999 10 -> Infinity Overflow Inexact Rounded |
| 1076 | rounding: up |
| 1077 | rmex410 multiply -9.999E+999999999 10 -> -Infinity Overflow Inexact Rounded |
| 1078 | rmex411 multiply 9.999E+999999999 10 -> Infinity Overflow Inexact Rounded |
| 1079 | rounding: down |
| 1080 | rmex412 multiply -9.999E+999999999 10 -> -9.99999999E+999999999 Overflow Inexact Rounded |
| 1081 | rmex413 multiply 9.999E+999999999 10 -> 9.99999999E+999999999 Overflow Inexact Rounded |
| 1082 | |
Thomas Wouters | 1b7f891 | 2007-09-19 03:06:30 +0000 | [diff] [blame] | 1083 | ----- Round-for-reround ----- |
| 1084 | rounding: 05up |
| 1085 | precision: 5 -- for easier visual inspection |
| 1086 | maxExponent: 999 |
| 1087 | minexponent: -999 |
| 1088 | |
| 1089 | -- basic rounding; really is just 0 and 5 up |
| 1090 | r05up001 add 12340 0.001 -> 12341 Inexact Rounded |
| 1091 | r05up002 add 12341 0.001 -> 12341 Inexact Rounded |
| 1092 | r05up003 add 12342 0.001 -> 12342 Inexact Rounded |
| 1093 | r05up004 add 12343 0.001 -> 12343 Inexact Rounded |
| 1094 | r05up005 add 12344 0.001 -> 12344 Inexact Rounded |
| 1095 | r05up006 add 12345 0.001 -> 12346 Inexact Rounded |
| 1096 | r05up007 add 12346 0.001 -> 12346 Inexact Rounded |
| 1097 | r05up008 add 12347 0.001 -> 12347 Inexact Rounded |
| 1098 | r05up009 add 12348 0.001 -> 12348 Inexact Rounded |
| 1099 | r05up010 add 12349 0.001 -> 12349 Inexact Rounded |
| 1100 | |
| 1101 | r05up011 add 12340 0.000 -> 12340 Rounded |
| 1102 | r05up012 add 12341 0.000 -> 12341 Rounded |
| 1103 | r05up013 add 12342 0.000 -> 12342 Rounded |
| 1104 | r05up014 add 12343 0.000 -> 12343 Rounded |
| 1105 | r05up015 add 12344 0.000 -> 12344 Rounded |
| 1106 | r05up016 add 12345 0.000 -> 12345 Rounded |
| 1107 | r05up017 add 12346 0.000 -> 12346 Rounded |
| 1108 | r05up018 add 12347 0.000 -> 12347 Rounded |
| 1109 | r05up019 add 12348 0.000 -> 12348 Rounded |
| 1110 | r05up020 add 12349 0.000 -> 12349 Rounded |
| 1111 | |
| 1112 | r05up021 add 12340 0.901 -> 12341 Inexact Rounded |
| 1113 | r05up022 add 12341 0.901 -> 12341 Inexact Rounded |
| 1114 | r05up023 add 12342 0.901 -> 12342 Inexact Rounded |
| 1115 | r05up024 add 12343 0.901 -> 12343 Inexact Rounded |
| 1116 | r05up025 add 12344 0.901 -> 12344 Inexact Rounded |
| 1117 | r05up026 add 12345 0.901 -> 12346 Inexact Rounded |
| 1118 | r05up027 add 12346 0.901 -> 12346 Inexact Rounded |
| 1119 | r05up028 add 12347 0.901 -> 12347 Inexact Rounded |
| 1120 | r05up029 add 12348 0.901 -> 12348 Inexact Rounded |
| 1121 | r05up030 add 12349 0.901 -> 12349 Inexact Rounded |
| 1122 | |
| 1123 | r05up031 add -12340 -0.001 -> -12341 Inexact Rounded |
| 1124 | r05up032 add -12341 -0.001 -> -12341 Inexact Rounded |
| 1125 | r05up033 add -12342 -0.001 -> -12342 Inexact Rounded |
| 1126 | r05up034 add -12343 -0.001 -> -12343 Inexact Rounded |
| 1127 | r05up035 add -12344 -0.001 -> -12344 Inexact Rounded |
| 1128 | r05up036 add -12345 -0.001 -> -12346 Inexact Rounded |
| 1129 | r05up037 add -12346 -0.001 -> -12346 Inexact Rounded |
| 1130 | r05up038 add -12347 -0.001 -> -12347 Inexact Rounded |
| 1131 | r05up039 add -12348 -0.001 -> -12348 Inexact Rounded |
| 1132 | r05up040 add -12349 -0.001 -> -12349 Inexact Rounded |
| 1133 | |
| 1134 | r05up041 add -12340 0.001 -> -12339 Inexact Rounded |
| 1135 | r05up042 add -12341 0.001 -> -12341 Inexact Rounded |
| 1136 | r05up043 add -12342 0.001 -> -12341 Inexact Rounded |
| 1137 | r05up044 add -12343 0.001 -> -12342 Inexact Rounded |
| 1138 | r05up045 add -12344 0.001 -> -12343 Inexact Rounded |
| 1139 | r05up046 add -12345 0.001 -> -12344 Inexact Rounded |
| 1140 | r05up047 add -12346 0.001 -> -12346 Inexact Rounded |
| 1141 | r05up048 add -12347 0.001 -> -12346 Inexact Rounded |
| 1142 | r05up049 add -12348 0.001 -> -12347 Inexact Rounded |
| 1143 | r05up050 add -12349 0.001 -> -12348 Inexact Rounded |
| 1144 | |
| 1145 | -- Addition operators ------------------------------------------------- |
| 1146 | -- [The first few of these check negative residue possibilities; these |
| 1147 | -- cases may be implemented as a negative residue in fastpaths] |
| 1148 | |
| 1149 | r0adx100 add 12345 -0.1 -> 12344 Inexact Rounded |
| 1150 | r0adx101 add 12345 -0.01 -> 12344 Inexact Rounded |
| 1151 | r0adx102 add 12345 -0.001 -> 12344 Inexact Rounded |
| 1152 | r0adx103 add 12345 -0.00001 -> 12344 Inexact Rounded |
| 1153 | r0adx104 add 12345 -0.000001 -> 12344 Inexact Rounded |
| 1154 | r0adx105 add 12345 -0.0000001 -> 12344 Inexact Rounded |
| 1155 | r0adx106 add 12345 0 -> 12345 |
| 1156 | r0adx107 add 12345 0.0000001 -> 12346 Inexact Rounded |
| 1157 | r0adx108 add 12345 0.000001 -> 12346 Inexact Rounded |
| 1158 | r0adx109 add 12345 0.00001 -> 12346 Inexact Rounded |
| 1159 | r0adx110 add 12345 0.0001 -> 12346 Inexact Rounded |
| 1160 | r0adx111 add 12345 0.001 -> 12346 Inexact Rounded |
| 1161 | r0adx112 add 12345 0.01 -> 12346 Inexact Rounded |
| 1162 | r0adx113 add 12345 0.1 -> 12346 Inexact Rounded |
| 1163 | |
| 1164 | r0adx115 add 12346 0.49999 -> 12346 Inexact Rounded |
| 1165 | r0adx116 add 12346 0.5 -> 12346 Inexact Rounded |
| 1166 | r0adx117 add 12346 0.50001 -> 12346 Inexact Rounded |
| 1167 | |
| 1168 | r0adx120 add 12345 0.4 -> 12346 Inexact Rounded |
| 1169 | r0adx121 add 12345 0.49 -> 12346 Inexact Rounded |
| 1170 | r0adx122 add 12345 0.499 -> 12346 Inexact Rounded |
| 1171 | r0adx123 add 12345 0.49999 -> 12346 Inexact Rounded |
| 1172 | r0adx124 add 12345 0.5 -> 12346 Inexact Rounded |
| 1173 | r0adx125 add 12345 0.50001 -> 12346 Inexact Rounded |
| 1174 | r0adx126 add 12345 0.5001 -> 12346 Inexact Rounded |
| 1175 | r0adx127 add 12345 0.501 -> 12346 Inexact Rounded |
| 1176 | r0adx128 add 12345 0.51 -> 12346 Inexact Rounded |
| 1177 | r0adx129 add 12345 0.6 -> 12346 Inexact Rounded |
| 1178 | |
| 1179 | -- negatives... |
| 1180 | |
| 1181 | r0sux100 add -12345 -0.1 -> -12346 Inexact Rounded |
| 1182 | r0sux101 add -12345 -0.01 -> -12346 Inexact Rounded |
| 1183 | r0sux102 add -12345 -0.001 -> -12346 Inexact Rounded |
| 1184 | r0sux103 add -12345 -0.00001 -> -12346 Inexact Rounded |
| 1185 | r0sux104 add -12345 -0.000001 -> -12346 Inexact Rounded |
| 1186 | r0sux105 add -12345 -0.0000001 -> -12346 Inexact Rounded |
| 1187 | r0sux106 add -12345 0 -> -12345 |
| 1188 | r0sux107 add -12345 0.0000001 -> -12344 Inexact Rounded |
| 1189 | r0sux108 add -12345 0.000001 -> -12344 Inexact Rounded |
| 1190 | r0sux109 add -12345 0.00001 -> -12344 Inexact Rounded |
| 1191 | r0sux110 add -12345 0.0001 -> -12344 Inexact Rounded |
| 1192 | r0sux111 add -12345 0.001 -> -12344 Inexact Rounded |
| 1193 | r0sux112 add -12345 0.01 -> -12344 Inexact Rounded |
| 1194 | r0sux113 add -12345 0.1 -> -12344 Inexact Rounded |
| 1195 | |
| 1196 | r0sux115 add -12346 0.49999 -> -12346 Inexact Rounded |
| 1197 | r0sux116 add -12346 0.5 -> -12346 Inexact Rounded |
| 1198 | r0sux117 add -12346 0.50001 -> -12346 Inexact Rounded |
| 1199 | |
| 1200 | r0sux120 add -12345 0.4 -> -12344 Inexact Rounded |
| 1201 | r0sux121 add -12345 0.49 -> -12344 Inexact Rounded |
| 1202 | r0sux122 add -12345 0.499 -> -12344 Inexact Rounded |
| 1203 | r0sux123 add -12345 0.49999 -> -12344 Inexact Rounded |
| 1204 | r0sux124 add -12345 0.5 -> -12344 Inexact Rounded |
| 1205 | r0sux125 add -12345 0.50001 -> -12344 Inexact Rounded |
| 1206 | r0sux126 add -12345 0.5001 -> -12344 Inexact Rounded |
| 1207 | r0sux127 add -12345 0.501 -> -12344 Inexact Rounded |
| 1208 | r0sux128 add -12345 0.51 -> -12344 Inexact Rounded |
| 1209 | r0sux129 add -12345 0.6 -> -12344 Inexact Rounded |
| 1210 | |
| 1211 | -- Check cancellation subtractions |
| 1212 | -- (The IEEE 854 'curious rule' in $6.3) |
| 1213 | |
| 1214 | r0zex001 add 0 0 -> 0 |
| 1215 | r0zex002 add 0 -0 -> 0 |
| 1216 | r0zex003 add -0 0 -> 0 |
| 1217 | r0zex004 add -0 -0 -> -0 |
| 1218 | r0zex005 add 1 -1 -> 0 |
| 1219 | r0zex006 add -1 1 -> 0 |
| 1220 | r0zex007 add 1.5 -1.5 -> 0.0 |
| 1221 | r0zex008 add -1.5 1.5 -> 0.0 |
| 1222 | r0zex009 add 2 -2 -> 0 |
| 1223 | r0zex010 add -2 2 -> 0 |
| 1224 | |
| 1225 | |
| 1226 | -- Division operators ------------------------------------------------- |
| 1227 | |
| 1228 | r0dvx101 divide 12345 1 -> 12345 |
| 1229 | r0dvx102 divide 12345 1.0001 -> 12343 Inexact Rounded |
| 1230 | r0dvx103 divide 12345 1.001 -> 12332 Inexact Rounded |
| 1231 | r0dvx104 divide 12345 1.01 -> 12222 Inexact Rounded |
| 1232 | r0dvx105 divide 12345 1.1 -> 11222 Inexact Rounded |
| 1233 | r0dvx106 divide 12355 4 -> 3088.7 Inexact Rounded |
| 1234 | r0dvx107 divide 12345 4 -> 3086.2 Inexact Rounded |
| 1235 | r0dvx108 divide 12355 4.0001 -> 3088.6 Inexact Rounded |
| 1236 | r0dvx109 divide 12345 4.0001 -> 3086.1 Inexact Rounded |
| 1237 | r0dvx110 divide 12345 4.9 -> 2519.3 Inexact Rounded |
| 1238 | r0dvx111 divide 12345 4.99 -> 2473.9 Inexact Rounded |
| 1239 | r0dvx112 divide 12345 4.999 -> 2469.4 Inexact Rounded |
| 1240 | r0dvx113 divide 12345 4.9999 -> 2469.1 Inexact Rounded |
| 1241 | r0dvx114 divide 12345 5 -> 2469 |
| 1242 | r0dvx115 divide 12345 5.0001 -> 2468.9 Inexact Rounded |
| 1243 | r0dvx116 divide 12345 5.001 -> 2468.6 Inexact Rounded |
| 1244 | r0dvx117 divide 12345 5.01 -> 2464.1 Inexact Rounded |
| 1245 | r0dvx118 divide 12345 5.1 -> 2420.6 Inexact Rounded |
| 1246 | |
| 1247 | -- [divideInteger and remainder unaffected] |
| 1248 | |
| 1249 | -- Multiplication operator -------------------------------------------- |
| 1250 | |
| 1251 | r0mux101 multiply 12345 1 -> 12345 |
| 1252 | r0mux102 multiply 12345 1.0001 -> 12346 Inexact Rounded |
| 1253 | r0mux103 multiply 12345 1.001 -> 12357 Inexact Rounded |
| 1254 | r0mux104 multiply 12345 1.01 -> 12468 Inexact Rounded |
| 1255 | r0mux105 multiply 12345 1.1 -> 13579 Inexact Rounded |
| 1256 | r0mux106 multiply 12345 4 -> 49380 |
| 1257 | r0mux107 multiply 12345 4.0001 -> 49381 Inexact Rounded |
| 1258 | r0mux108 multiply 12345 4.9 -> 60491 Inexact Rounded |
| 1259 | r0mux109 multiply 12345 4.99 -> 61601 Inexact Rounded |
| 1260 | r0mux110 multiply 12345 4.999 -> 61712 Inexact Rounded |
| 1261 | r0mux111 multiply 12345 4.9999 -> 61723 Inexact Rounded |
| 1262 | r0mux112 multiply 12345 5 -> 61725 |
| 1263 | r0mux113 multiply 12345 5.0001 -> 61726 Inexact Rounded |
| 1264 | r0mux114 multiply 12345 5.001 -> 61737 Inexact Rounded |
| 1265 | r0mux115 multiply 12345 5.01 -> 61848 Inexact Rounded |
| 1266 | r0mux116 multiply 12345 12 -> 1.4814E+5 Rounded |
| 1267 | r0mux117 multiply 12345 13 -> 1.6048E+5 Inexact Rounded |
| 1268 | r0mux118 multiply 12355 12 -> 1.4826E+5 Rounded |
| 1269 | r0mux119 multiply 12355 13 -> 1.6061E+5 Inexact Rounded |
| 1270 | |
| 1271 | |
| 1272 | -- Power operator ----------------------------------------------------- |
| 1273 | |
| 1274 | r0pox101 power 12345 -5 -> 3.4877E-21 Inexact Rounded |
| 1275 | r0pox102 power 12345 -4 -> 4.3056E-17 Inexact Rounded |
| 1276 | r0pox103 power 12345 -3 -> 5.3152E-13 Inexact Rounded |
| 1277 | r0pox104 power 12345 -2 -> 6.5617E-9 Inexact Rounded |
| 1278 | r0pox105 power 12345 -1 -> 0.000081004 Inexact Rounded |
| 1279 | r0pox106 power 12345 0 -> 1 |
| 1280 | r0pox107 power 12345 1 -> 12345 |
| 1281 | r0pox108 power 12345 2 -> 1.5239E+8 Inexact Rounded |
| 1282 | r0pox109 power 12345 3 -> 1.8813E+12 Inexact Rounded |
| 1283 | r0pox110 power 12345 4 -> 2.3226E+16 Inexact Rounded |
| 1284 | r0pox111 power 12345 5 -> 2.8671E+20 Inexact Rounded |
| 1285 | r0pox112 power 415 2 -> 1.7222E+5 Inexact Rounded |
| 1286 | r0pox113 power 75 3 -> 4.2187E+5 Inexact Rounded |
| 1287 | |
| 1288 | |
| 1289 | -- Underflow Subnormal and overflow values vary with rounding mode and sign |
| 1290 | maxexponent: 999999999 |
| 1291 | minexponent: -999999999 |
| 1292 | -- [round down gives Nmax on first two and .0E... on the next two] |
| 1293 | r0ovx100 multiply 10 9E+999999999 -> 9.9999E+999999999 Overflow Inexact Rounded |
| 1294 | r0ovx101 multiply -10 9E+999999999 -> -9.9999E+999999999 Overflow Inexact Rounded |
| 1295 | r0ovx102 divide 1E-9 9E+999999999 -> 1E-1000000003 Underflow Subnormal Inexact Rounded |
| 1296 | r0ovx104 divide -1E-9 9E+999999999 -> -1E-1000000003 Underflow Subnormal Inexact Rounded |
| 1297 | |
| 1298 | -- reprise rounding mode effect (using multiplies so precision directive used) |
| 1299 | precision: 9 |
| 1300 | maxexponent: 999999999 |
| 1301 | r0mex412 multiply -9.999E+999999999 10 -> -9.99999999E+999999999 Overflow Inexact Rounded |
| 1302 | r0mex413 multiply 9.999E+999999999 10 -> 9.99999999E+999999999 Overflow Inexact Rounded |
| 1303 | |