github.com/cockroachdb/apd/v3@v3.2.0/testdata/power.decTest (about) 1 ------------------------------------------------------------------------ 2 -- power.decTest -- decimal exponentiation [power(x, y)] -- 3 -- Copyright (c) Mike Cowlishaw, 1981, 2010. All rights reserved. -- 4 -- Parts copyright (c) IBM Corporation, 1981, 2008. -- 5 ------------------------------------------------------------------------ 6 -- Please see the document "General Decimal Arithmetic Testcases" -- 7 -- at http://speleotrove.com/decimal for the description of -- 8 -- these testcases. -- 9 -- -- 10 -- These testcases are experimental ('beta' versions), and they -- 11 -- may contain errors. They are offered on an as-is basis. In -- 12 -- particular, achieving the same results as the tests here is not -- 13 -- a guarantee that an implementation complies with any Standard -- 14 -- or specification. The tests are not exhaustive. -- 15 -- -- 16 -- Please send comments, suggestions, and corrections to the author: -- 17 -- Mike Cowlishaw, mfc@speleotrove.com -- 18 ------------------------------------------------------------------------ 19 version: 2.62 20 21 -- In addition to the power operator testcases here, see also the file 22 -- powersqrt.decTest which includes all the tests from 23 -- squareroot.decTest implemented using power(x, 0.5) 24 25 extended: 1 26 precision: 16 27 rounding: half_even 28 maxExponent: 384 29 minExponent: -383 30 31 -- base checks. Note 0**0 is an error. 32 powx001 power '0' '0' -> NaN Invalid_operation 33 powx002 power '0' '1' -> '0' 34 powx003 power '0' '2' -> '0' 35 powx004 power '1' '0' -> '1' 36 powx005 power '1' '1' -> '1' 37 powx006 power '1' '2' -> '1' 38 39 powx010 power '2' '0' -> '1' 40 powx011 power '2' '1' -> '2' 41 powx012 power '2' '2' -> '4' 42 powx013 power '2' '3' -> '8' 43 powx014 power '2' '4' -> '16' 44 powx015 power '2' '5' -> '32' 45 powx016 power '2' '6' -> '64' 46 powx017 power '2' '7' -> '128' 47 powx018 power '2' '8' -> '256' 48 powx019 power '2' '9' -> '512' 49 powx020 power '2' '10' -> '1024' 50 powx021 power '2' '11' -> '2048' 51 powx022 power '2' '12' -> '4096' 52 powx023 power '2' '15' -> '32768' 53 powx024 power '2' '16' -> '65536' 54 powx025 power '2' '31' -> '2147483648' 55 -- NB 0 not stripped in next 56 powx026 power '2' '32' -> '4294967296' 57 58 precision: 9 59 powx027 power '2' '31' -> '2.14748365E+9' Inexact Rounded 60 -- NB 0 not stripped in next 61 powx028 power '2' '32' -> '4.29496730E+9' Inexact Rounded 62 precision: 10 63 powx029 power '2' '31' -> '2147483648' 64 powx030 power '2' '32' -> '4294967296' 65 precision: 9 66 67 powx031 power '3' '2' -> 9 68 powx032 power '4' '2' -> 16 69 powx033 power '5' '2' -> 25 70 powx034 power '6' '2' -> 36 71 powx035 power '7' '2' -> 49 72 powx036 power '8' '2' -> 64 73 powx037 power '9' '2' -> 81 74 powx038 power '10' '2' -> 100 75 powx039 power '11' '2' -> 121 76 powx040 power '12' '2' -> 144 77 78 powx041 power '3' '3' -> 27 79 powx042 power '4' '3' -> 64 80 powx043 power '5' '3' -> 125 81 powx044 power '6' '3' -> 216 82 powx045 power '7' '3' -> 343 83 powx047 power '-3' '3' -> -27 84 powx048 power '-4' '3' -> -64 85 powx049 power '-5' '3' -> -125 86 powx050 power '-6' '3' -> -216 87 powx051 power '-7' '3' -> -343 88 89 powx052 power '10' '0' -> 1 90 powx053 power '10' '1' -> 10 91 powx054 power '10' '2' -> 100 92 powx055 power '10' '3' -> 1000 93 powx056 power '10' '4' -> 10000 94 powx057 power '10' '5' -> 100000 95 powx058 power '10' '6' -> 1000000 96 powx059 power '10' '7' -> 10000000 97 powx060 power '10' '8' -> 100000000 98 powx061 power '10' '9' -> 1.00000000E+9 Rounded 99 powx062 power '10' '22' -> 1.00000000E+22 Rounded 100 powx063 power '10' '77' -> 1.00000000E+77 Rounded 101 powx064 power '10' '99' -> 1.00000000E+99 Rounded 102 103 powx070 power '0.3' '0' -> '1' 104 powx071 power '0.3' '1' -> '0.3' 105 powx072 power '0.3' '1.00' -> '0.3' 106 powx073 power '0.3' '2.00' -> '0.09' 107 powx074 power '0.3' '2.000000000' -> '0.09' 108 powx075 power '6.0' '1' -> '6.0' -- NB zeros not stripped 109 powx076 power '6.0' '2' -> '36.00' -- .. 110 powx077 power '-3' '2' -> '9' -- from NetRexx book 111 powx078 power '4' '3' -> '64' -- .. (sort of) 112 113 powx080 power 0.1 0 -> 1 114 powx081 power 0.1 1 -> 0.1 115 powx082 power 0.1 2 -> 0.01 116 powx083 power 0.1 3 -> 0.001 117 powx084 power 0.1 4 -> 0.0001 118 powx085 power 0.1 5 -> 0.00001 119 powx086 power 0.1 6 -> 0.000001 120 powx087 power 0.1 7 -> 1E-7 121 powx088 power 0.1 8 -> 1E-8 122 powx089 power 0.1 9 -> 1E-9 123 124 powx090 power 101 2 -> 10201 125 powx091 power 101 3 -> 1030301 126 powx092 power 101 4 -> 104060401 127 powx093 power 101 5 -> 1.05101005E+10 Inexact Rounded 128 powx094 power 101 6 -> 1.06152015E+12 Inexact Rounded 129 powx095 power 101 7 -> 1.07213535E+14 Inexact Rounded 130 131 -- negative powers 132 powx099 power '1' '-1' -> 1 133 powx100 power '3' '-1' -> 0.333333333 Inexact Rounded 134 powx101 power '2' '-1' -> 0.5 135 powx102 power '2' '-2' -> 0.25 136 powx103 power '2' '-4' -> 0.0625 137 powx104 power '2' '-8' -> 0.00390625 138 powx105 power '2' '-16' -> 0.0000152587891 Inexact Rounded 139 powx106 power '2' '-32' -> 2.32830644E-10 Inexact Rounded 140 powx108 power '2' '-64' -> 5.42101086E-20 Inexact Rounded 141 powx110 power '10' '-8' -> 1E-8 142 powx111 power '10' '-7' -> 1E-7 143 powx112 power '10' '-6' -> 0.000001 144 powx113 power '10' '-5' -> 0.00001 145 powx114 power '10' '-4' -> 0.0001 146 powx115 power '10' '-3' -> 0.001 147 powx116 power '10' '-2' -> 0.01 148 powx117 power '10' '-1' -> 0.1 149 powx121 power '10' '-77' -> '1E-77' 150 powx122 power '10' '-22' -> '1E-22' 151 152 powx123 power '2' '-1' -> '0.5' 153 powx124 power '2' '-2' -> '0.25' 154 powx125 power '2' '-4' -> '0.0625' 155 156 powx126 power '0' '-1' -> Infinity 157 powx127 power '0' '-2' -> Infinity 158 powx128 power -0 '-1' -> -Infinity 159 powx129 power -0 '-2' -> Infinity 160 161 -- "0.5" tests from original Rexx diagnostics [loop unrolled] 162 powx200 power 0.5 0 -> 1 163 powx201 power 0.5 1 -> 0.5 164 powx202 power 0.5 2 -> 0.25 165 powx203 power 0.5 3 -> 0.125 166 powx204 power 0.5 4 -> 0.0625 167 powx205 power 0.5 5 -> 0.03125 168 powx206 power 0.5 6 -> 0.015625 169 powx207 power 0.5 7 -> 0.0078125 170 powx208 power 0.5 8 -> 0.00390625 171 powx209 power 0.5 9 -> 0.001953125 172 powx210 power 0.5 10 -> 0.0009765625 173 174 powx211 power 1 100000000 -> 1 175 powx212 power 1 999999998 -> 1 176 powx213 power 1 999999999 -> 1 177 178 179 -- The Vienna case. Checks both setup and 1/acc working precision 180 -- Modified 1998.12.14 as RHS no longer rounded before use (must fit) 181 -- Modified 1990.02.04 as LHS is now rounded (instead of truncated to guard) 182 -- '123456789E+10' -- lhs .. rounded to 1.23E+18 183 -- '-1.23000e+2' -- rhs .. [was: -1.23455e+2, rounds to -123] 184 -- Modified 2002.10.06 -- finally, no input rounding 185 -- With input rounding, result would be 8.74E-2226 186 precision: 3 187 maxexponent: 5000 188 minexponent: -5000 189 powx219 power '123456789E+10' '-1.23000e+2' -> '5.54E-2226' Inexact Rounded 190 191 -- zeros 192 maxexponent: +96 193 minexponent: -95 194 precision: 7 195 powx223 power 0E-30 3 -> 0 196 powx224 power 0E-10 3 -> 0 197 powx225 power 0E-1 3 -> 0 198 powx226 power 0E+0 3 -> 0 199 powx227 power 0 3 -> 0 200 powx228 power 0E+1 3 -> 0 201 powx229 power 0E+10 3 -> 0 202 powx230 power 0E+30 3 -> 0 203 powx231 power 3 0E-30 -> 1 204 powx232 power 3 0E-10 -> 1 205 powx233 power 3 0E-1 -> 1 206 powx234 power 3 0E+0 -> 1 207 powx235 power 3 0 -> 1 208 powx236 power 3 0E+1 -> 1 209 powx237 power 3 0E+10 -> 1 210 powx238 power 3 0E+30 -> 1 211 powx239 power 0E-30 -3 -> Infinity 212 powx240 power 0E-10 -3 -> Infinity 213 powx241 power 0E-1 -3 -> Infinity 214 powx242 power 0E+0 -3 -> Infinity 215 powx243 power 0 -3 -> Infinity 216 powx244 power 0E+1 -3 -> Infinity 217 powx245 power 0E+10 -3 -> Infinity 218 powx246 power 0E+30 -3 -> Infinity 219 powx247 power -3 0E-30 -> 1 220 powx248 power -3 0E-10 -> 1 221 powx249 power -3 0E-1 -> 1 222 powx250 power -3 0E+0 -> 1 223 powx251 power -3 0 -> 1 224 powx252 power -3 0E+1 -> 1 225 powx253 power -3 0E+10 -> 1 226 powx254 power -3 0E+30 -> 1 227 228 -- a few lhs negatives 229 precision: 9 230 maxExponent: 999 231 minexponent: -999 232 powx260 power -10 '0' -> 1 233 powx261 power -10 '1' -> -10 234 powx262 power -10 '2' -> 100 235 powx263 power -10 '3' -> -1000 236 powx264 power -10 '4' -> 10000 237 powx265 power -10 '5' -> -100000 238 powx266 power -10 '6' -> 1000000 239 powx267 power -10 '7' -> -10000000 240 powx268 power -10 '8' -> 100000000 241 powx269 power -10 '9' -> -1.00000000E+9 Rounded 242 powx270 power -10 '22' -> 1.00000000E+22 Rounded 243 powx271 power -10 '77' -> -1.00000000E+77 Rounded 244 powx272 power -10 '99' -> -1.00000000E+99 Rounded 245 246 -- some more edge cases 247 precision: 15 248 maxExponent: 999 249 minexponent: -999 250 powx391 power 0.1 999 -> 1E-999 251 powx392 power 0.099 999 -> 4.360732062E-1004 Underflow Subnormal Inexact Rounded 252 powx393 power 0.098 999 -> 1.71731E-1008 Underflow Subnormal Inexact Rounded 253 powx394 power 0.097 999 -> 6E-1013 Underflow Subnormal Inexact Rounded 254 powx395 power 0.096 999 -> 0E-1013 Underflow Subnormal Inexact Rounded Clamped 255 powx396 power 0.01 999 -> 0E-1013 Underflow Subnormal Inexact Rounded Clamped 256 powx397 power 0.02 100000000 -> 0E-1013 Underflow Subnormal Inexact Rounded Clamped 257 258 -- multiply tests are here to aid checking and test for consistent handling 259 -- of underflow 260 precision: 5 261 maxexponent: 999 262 minexponent: -999 263 264 -- squares 265 mulx400 multiply 1E-502 1e-502 -> 0E-1003 Subnormal Inexact Underflow Rounded Clamped 266 mulx401 multiply 1E-501 1e-501 -> 1E-1002 Subnormal 267 mulx402 multiply 2E-501 2e-501 -> 4E-1002 Subnormal 268 mulx403 multiply 4E-501 4e-501 -> 1.6E-1001 Subnormal 269 mulx404 multiply 10E-501 10e-501 -> 1.00E-1000 Subnormal 270 mulx405 multiply 30E-501 30e-501 -> 9.00E-1000 Subnormal 271 mulx406 multiply 40E-501 40e-501 -> 1.600E-999 272 273 powx400 power 1E-502 2 -> 0E-1003 Underflow Subnormal Inexact Rounded Clamped 274 powx401 power 1E-501 2 -> 1E-1002 Subnormal 275 powx402 power 2E-501 2 -> 4E-1002 Subnormal 276 powx403 power 4E-501 2 -> 1.6E-1001 Subnormal 277 powx404 power 10E-501 2 -> 1.00E-1000 Subnormal 278 powx405 power 30E-501 2 -> 9.00E-1000 Subnormal 279 powx406 power 40E-501 2 -> 1.600E-999 280 281 -- cubes 282 mulx410 multiply 1E-670 1e-335 -> 0E-1003 Underflow Subnormal Inexact Rounded Clamped 283 mulx411 multiply 1E-668 1e-334 -> 1E-1002 Subnormal 284 mulx412 multiply 4E-668 2e-334 -> 8E-1002 Subnormal 285 mulx413 multiply 9E-668 3e-334 -> 2.7E-1001 Subnormal 286 mulx414 multiply 16E-668 4e-334 -> 6.4E-1001 Subnormal 287 mulx415 multiply 25E-668 5e-334 -> 1.25E-1000 Subnormal 288 mulx416 multiply 10E-668 100e-334 -> 1.000E-999 289 290 powx410 power 1E-335 3 -> 0E-1003 Underflow Subnormal Inexact Rounded Clamped 291 powx411 power 1E-334 3 -> 1E-1002 Subnormal 292 powx412 power 2E-334 3 -> 8E-1002 Subnormal 293 powx413 power 3E-334 3 -> 2.7E-1001 Subnormal 294 powx414 power 4E-334 3 -> 6.4E-1001 Subnormal 295 powx415 power 5E-334 3 -> 1.25E-1000 Subnormal 296 powx416 power 10E-334 3 -> 1.000E-999 297 298 -- negative powers, testing subnormals 299 precision: 5 300 maxExponent: 999 301 minexponent: -999 302 powx421 power 2.5E-501 -2 -> Infinity Overflow Inexact Rounded 303 powx422 power 2.5E-500 -2 -> 1.6E+999 304 305 powx423 power 2.5E+499 -2 -> 1.6E-999 306 powx424 power 2.5E+500 -2 -> 1.6E-1001 Subnormal 307 powx425 power 2.5E+501 -2 -> 2E-1003 Underflow Subnormal Inexact Rounded 308 powx426 power 2.5E+502 -2 -> 0E-1003 Underflow Subnormal Inexact Rounded Clamped 309 310 powx427 power 0.25E+499 -2 -> 1.6E-997 311 powx428 power 0.25E+500 -2 -> 1.6E-999 312 powx429 power 0.25E+501 -2 -> 1.6E-1001 Subnormal 313 powx430 power 0.25E+502 -2 -> 2E-1003 Underflow Subnormal Inexact Rounded 314 powx431 power 0.25E+503 -2 -> 0E-1003 Underflow Subnormal Inexact Rounded Clamped 315 316 powx432 power 0.04E+499 -2 -> 6.25E-996 317 powx433 power 0.04E+500 -2 -> 6.25E-998 318 powx434 power 0.04E+501 -2 -> 6.25E-1000 Subnormal 319 powx435 power 0.04E+502 -2 -> 6.2E-1002 Underflow Subnormal Inexact Rounded 320 powx436 power 0.04E+503 -2 -> 1E-1003 Underflow Subnormal Inexact Rounded 321 powx437 power 0.04E+504 -2 -> 0E-1003 Underflow Subnormal Inexact Rounded Clamped 322 323 powx441 power 0.04E+334 -3 -> 1.5625E-998 324 powx442 power 0.04E+335 -3 -> 1.56E-1001 Underflow Subnormal Inexact Rounded 325 powx443 power 0.04E+336 -3 -> 0E-1003 Underflow Subnormal Inexact Rounded Clamped 326 powx444 power 0.25E+333 -3 -> 6.4E-998 327 powx445 power 0.25E+334 -3 -> 6.4E-1001 Subnormal 328 powx446 power 0.25E+335 -3 -> 1E-1003 Underflow Subnormal Inexact Rounded 329 powx447 power 0.25E+336 -3 -> 0E-1003 Underflow Subnormal Inexact Rounded Clamped 330 -- check sign for cubes and a few squares 331 powx448 power -0.04E+334 -3 -> -1.5625E-998 332 powx449 power -0.04E+335 -3 -> -1.56E-1001 Underflow Subnormal Inexact Rounded 333 powx450 power -0.04E+336 -3 -> -0E-1003 Underflow Subnormal Inexact Rounded Clamped 334 powx451 power -0.25E+333 -3 -> -6.4E-998 335 powx452 power -0.25E+334 -3 -> -6.4E-1001 Subnormal 336 powx453 power -0.25E+335 -3 -> -1E-1003 Underflow Subnormal Inexact Rounded 337 powx454 power -0.25E+336 -3 -> -0E-1003 Underflow Subnormal Inexact Rounded Clamped 338 powx455 power -0.04E+499 -2 -> 6.25E-996 339 powx456 power -0.04E+500 -2 -> 6.25E-998 340 powx457 power -0.04E+501 -2 -> 6.25E-1000 Subnormal 341 powx458 power -0.04E+502 -2 -> 6.2E-1002 Underflow Subnormal Inexact Rounded 342 343 -- test -0s 344 precision: 9 345 powx560 power 0 0 -> NaN Invalid_operation 346 powx561 power 0 -0 -> NaN Invalid_operation 347 powx562 power -0 0 -> NaN Invalid_operation 348 powx563 power -0 -0 -> NaN Invalid_operation 349 powx564 power 1 0 -> 1 350 powx565 power 1 -0 -> 1 351 powx566 power -1 0 -> 1 352 powx567 power -1 -0 -> 1 353 powx568 power 0 1 -> 0 354 powx569 power 0 -1 -> Infinity 355 powx570 power -0 1 -> -0 356 powx571 power -0 -1 -> -Infinity 357 powx572 power 0 2 -> 0 358 powx573 power 0 -2 -> Infinity 359 powx574 power -0 2 -> 0 360 powx575 power -0 -2 -> Infinity 361 powx576 power 0 3 -> 0 362 powx577 power 0 -3 -> Infinity 363 powx578 power -0 3 -> -0 364 powx579 power -0 -3 -> -Infinity 365 366 -- Specials 367 powx580 power Inf -Inf -> 0 368 powx581 power Inf -1000 -> 0 369 powx582 power Inf -1 -> 0 370 powx583 power Inf -0.5 -> 0 371 powx584 power Inf -0 -> 1 372 powx585 power Inf 0 -> 1 373 powx586 power Inf 0.5 -> Infinity 374 powx587 power Inf 1 -> Infinity 375 powx588 power Inf 1000 -> Infinity 376 powx589 power Inf Inf -> Infinity 377 powx590 power -1000 Inf -> NaN Invalid_operation 378 powx591 power -Inf Inf -> NaN Invalid_operation 379 powx592 power -1 Inf -> NaN Invalid_operation 380 powx593 power -0.5 Inf -> NaN Invalid_operation 381 powx594 power -0 Inf -> 0 382 powx595 power 0 Inf -> 0 383 powx596 power 0.5 Inf -> 0 384 powx597 power 1 Inf -> 1.00000000 Inexact Rounded 385 powx598 power 1000 Inf -> Infinity 386 powx599 power Inf Inf -> Infinity 387 388 powx600 power -Inf -Inf -> NaN Invalid_operation 389 powx601 power -Inf -1000 -> 0 390 powx602 power -Inf -1 -> -0 391 powx603 power -Inf -0.5 -> NaN Invalid_operation 392 powx604 power -Inf -0 -> 1 393 powx605 power -Inf 0 -> 1 394 powx606 power -Inf 0.5 -> NaN Invalid_operation 395 powx607 power -Inf 1 -> -Infinity 396 powx608 power -Inf 1000 -> Infinity 397 powx609 power -Inf Inf -> NaN Invalid_operation 398 powx610 power -1000 Inf -> NaN Invalid_operation 399 powx611 power -Inf -Inf -> NaN Invalid_operation 400 powx612 power -1 -Inf -> NaN Invalid_operation 401 powx613 power -0.5 -Inf -> NaN Invalid_operation 402 powx614 power -0 -Inf -> Infinity 403 powx615 power 0 -Inf -> Infinity 404 powx616 power 0.5 -Inf -> Infinity 405 powx617 power 1 -Inf -> 1.00000000 Inexact Rounded 406 powx618 power 1000 -Inf -> 0 407 powx619 power Inf -Inf -> 0 408 409 powx621 power NaN -Inf -> NaN 410 powx622 power NaN -1000 -> NaN 411 powx623 power NaN -1 -> NaN 412 powx624 power NaN -0.5 -> NaN 413 powx625 power NaN -0 -> NaN 414 powx626 power NaN 0 -> NaN 415 powx627 power NaN 0.5 -> NaN 416 powx628 power NaN 1 -> NaN 417 powx629 power NaN 1000 -> NaN 418 powx630 power NaN Inf -> NaN 419 powx631 power NaN NaN -> NaN 420 powx632 power -Inf NaN -> NaN 421 powx633 power -1000 NaN -> NaN 422 powx634 power -1 NaN -> NaN 423 powx635 power -0 NaN -> NaN 424 powx636 power 0 NaN -> NaN 425 powx637 power 1 NaN -> NaN 426 powx638 power 1000 NaN -> NaN 427 powx639 power Inf NaN -> NaN 428 429 powx641 power sNaN -Inf -> NaN Invalid_operation 430 powx642 power sNaN -1000 -> NaN Invalid_operation 431 powx643 power sNaN -1 -> NaN Invalid_operation 432 powx644 power sNaN -0.5 -> NaN Invalid_operation 433 powx645 power sNaN -0 -> NaN Invalid_operation 434 powx646 power sNaN 0 -> NaN Invalid_operation 435 powx647 power sNaN 0.5 -> NaN Invalid_operation 436 powx648 power sNaN 1 -> NaN Invalid_operation 437 powx649 power sNaN 1000 -> NaN Invalid_operation 438 powx650 power sNaN NaN -> NaN Invalid_operation 439 powx651 power sNaN sNaN -> NaN Invalid_operation 440 powx652 power NaN sNaN -> NaN Invalid_operation 441 powx653 power -Inf sNaN -> NaN Invalid_operation 442 powx654 power -1000 sNaN -> NaN Invalid_operation 443 powx655 power -1 sNaN -> NaN Invalid_operation 444 powx656 power -0.5 sNaN -> NaN Invalid_operation 445 powx657 power -0 sNaN -> NaN Invalid_operation 446 powx658 power 0 sNaN -> NaN Invalid_operation 447 powx659 power 0.5 sNaN -> NaN Invalid_operation 448 powx660 power 1 sNaN -> NaN Invalid_operation 449 powx661 power 1000 sNaN -> NaN Invalid_operation 450 powx662 power Inf sNaN -> NaN Invalid_operation 451 powx663 power NaN sNaN -> NaN Invalid_operation 452 453 -- NaN propagation 454 powx670 power NaN3 sNaN7 -> NaN7 Invalid_operation 455 powx671 power sNaN8 NaN6 -> NaN8 Invalid_operation 456 powx672 power 1 sNaN7 -> NaN7 Invalid_operation 457 powx673 power sNaN8 1 -> NaN8 Invalid_operation 458 powx674 power Inf sNaN7 -> NaN7 Invalid_operation 459 powx675 power sNaN8 Inf -> NaN8 Invalid_operation 460 powx676 power Inf NaN9 -> NaN9 461 powx677 power NaN6 Inf -> NaN6 462 powx678 power 1 NaN5 -> NaN5 463 powx679 power NaN2 1 -> NaN2 464 powx680 power NaN2 Nan4 -> NaN2 465 powx681 power NaN Nan4 -> NaN 466 powx682 power NaN345 Nan -> NaN345 467 powx683 power Inf -sNaN7 -> -NaN7 Invalid_operation 468 powx684 power -sNaN8 Inf -> -NaN8 Invalid_operation 469 powx685 power Inf -NaN9 -> -NaN9 470 powx686 power -NaN6 Inf -> -NaN6 471 powx687 power -NaN2 -Nan4 -> -NaN2 472 473 -- long operand and RHS range checks 474 maxexponent: 999 475 minexponent: -999 476 precision: 9 477 powx701 power 12345678000 1 -> 1.23456780E+10 Rounded 478 powx702 power 1234567800 1 -> 1.23456780E+9 Rounded 479 powx703 power 1234567890 1 -> 1.23456789E+9 Rounded 480 powx704 power 1234567891 1 -> 1.23456789E+9 Inexact Rounded 481 powx705 power 12345678901 1 -> 1.23456789E+10 Inexact Rounded 482 powx706 power 1234567896 1 -> 1.23456790E+9 Inexact Rounded 483 484 precision: 15 485 -- still checking 486 powx741 power 12345678000 1 -> 12345678000 487 powx742 power 1234567800 1 -> 1234567800 488 powx743 power 1234567890 1 -> 1234567890 489 powx744 power 1234567891 1 -> 1234567891 490 powx745 power 12345678901 1 -> 12345678901 491 powx746 power 1234567896 1 -> 1234567896 492 493 maxexponent: 999999 494 minexponent: -999999 495 precision: 9 496 497 -- near out-of-range edge cases 498 powx163 power '10' '999999' -> '1.00000000E+999999' Rounded 499 powx164 power '10' '999998' -> '1.00000000E+999998' Rounded 500 powx165 power '10' '999997' -> '1.00000000E+999997' Rounded 501 powx166 power '10' '333333' -> '1.00000000E+333333' Rounded 502 powx183 power '7' '1000000' -> 1.09651419E+845098 Inexact Rounded 503 powx184 power '7' '1000001' -> 7.67559934E+845098 Inexact Rounded 504 powx186 power '7' '-1000001' -> 1.30282986E-845099 Inexact Rounded 505 powx187 power '7' '-1000000' -> 9.11980901E-845099 Inexact Rounded 506 powx118 power '10' '-333333' -> 1E-333333 507 powx119 power '10' '-999998' -> 1E-999998 508 powx120 power '10' '-999999' -> 1E-999999 509 powx181 power '7' '999998' -> 2.23778406E+845096 Inexact Rounded 510 powx182 power '7' '999999' -> 1.56644884E+845097 Inexact Rounded 511 powx189 power '7' '-999999' -> 6.38386631E-845098 Inexact Rounded 512 powx190 power '7' '-999998' -> 4.46870641E-845097 Inexact Rounded 513 514 -- overflow and underflow tests 515 precision: 9 516 517 powx277 power 9 999999 -> 3.59084629E+954241 Inexact Rounded 518 powx278 power 9.99999999 999999 -> 9.99000501E+999998 Inexact Rounded 519 powx279 power 10 999999 -> 1.00000000E+999999 Rounded 520 powx280 power 10.0000001 999999 -> 1.01005016E+999999 Inexact Rounded 521 powx281 power 10.000001 999999 -> 1.10517080E+999999 Inexact Rounded 522 powx282 power 10.00001 999999 -> 2.71827775E+999999 Inexact Rounded 523 powx283 power 10.0001 999999 -> Infinity Overflow Inexact Rounded 524 powx285 power 11 999999 -> Infinity Overflow Inexact Rounded 525 powx286 power 12 999999 -> Infinity Overflow Inexact Rounded 526 powx287 power 999 999999 -> Infinity Overflow Inexact Rounded 527 powx288 power 999999999 999999 -> Infinity Overflow Inexact Rounded 528 powx289 power 9.9E999999999 999999 -> Infinity Overflow Inexact Rounded 529 530 powx290 power 0.5 999999 -> 2.02006812E-301030 Inexact Rounded 531 powx291 power 0.1 999999 -> 1E-999999 -- unrounded 532 powx292 power 0.09 999999 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 533 powx293 power 0.05 999999 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 534 powx294 power 0.01 999999 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 535 powx295 power 0.0001 999999 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 536 powx297 power 0.0000001 999999 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 537 powx298 power 0.0000000001 999999 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 538 powx299 power 1E-999999999 999999 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 539 540 powx310 power -9 999999 -> -3.59084629E+954241 Inexact Rounded 541 powx311 power -10 999999 -> -1.00000000E+999999 Rounded 542 powx312 power -10.0001 999999 -> -Infinity Overflow Inexact Rounded 543 powx313 power -10.1 999999 -> -Infinity Overflow Inexact Rounded 544 powx314 power -11 999999 -> -Infinity Overflow Inexact Rounded 545 powx315 power -12 999999 -> -Infinity Overflow Inexact Rounded 546 powx316 power -999 999999 -> -Infinity Overflow Inexact Rounded 547 powx317 power -999999 999999 -> -Infinity Overflow Inexact Rounded 548 powx318 power -999999999 999999 -> -Infinity Overflow Inexact Rounded 549 powx319 power -9.9E999999999 999999 -> -Infinity Overflow Inexact Rounded 550 551 powx320 power -0.5 999999 -> -2.02006812E-301030 Inexact Rounded 552 powx321 power -0.1 999999 -> -1E-999999 553 powx322 power -0.09 999999 -> -0E-1000007 Underflow Subnormal Inexact Rounded Clamped 554 powx323 power -0.05 999999 -> -0E-1000007 Underflow Subnormal Inexact Rounded Clamped 555 powx324 power -0.01 999999 -> -0E-1000007 Underflow Subnormal Inexact Rounded Clamped 556 powx325 power -0.0001 999999 -> -0E-1000007 Underflow Subnormal Inexact Rounded Clamped 557 powx327 power -0.0000001 999999 -> -0E-1000007 Underflow Subnormal Inexact Rounded Clamped 558 powx328 power -0.0000000001 999999 -> -0E-1000007 Underflow Subnormal Inexact Rounded Clamped 559 powx329 power -1E-999999999 999999 -> -0E-1000007 Underflow Subnormal Inexact Rounded Clamped 560 561 -- note no trim of next result 562 powx330 power -9 999998 -> 3.98982921E+954240 Inexact Rounded 563 powx331 power -10 999998 -> 1.00000000E+999998 Rounded 564 powx332 power -10.0001 999998 -> Infinity Overflow Inexact Rounded 565 powx333 power -10.1 999998 -> Infinity Overflow Inexact Rounded 566 powx334 power -11 999998 -> Infinity Overflow Inexact Rounded 567 powx335 power -12 999998 -> Infinity Overflow Inexact Rounded 568 powx336 power -999 999998 -> Infinity Overflow Inexact Rounded 569 powx337 power -999999 999998 -> Infinity Overflow Inexact Rounded 570 powx338 power -999999999 999998 -> Infinity Overflow Inexact Rounded 571 powx339 power -9.9E999999999 999998 -> Infinity Overflow Inexact Rounded 572 573 powx340 power -0.5 999998 -> 4.04013624E-301030 Inexact Rounded 574 powx341 power -0.1 999998 -> 1E-999998 -- NB exact unrounded 575 powx342 power -0.09 999998 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 576 powx343 power -0.05 999998 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 577 powx344 power -0.01 999998 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 578 powx345 power -0.0001 999998 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 579 powx347 power -0.0000001 999998 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 580 powx348 power -0.0000000001 999998 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 581 powx349 power -1E-999999999 999998 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 582 583 -- some subnormals 584 precision: 9 585 -- [precision is 9, so smallest exponent is -1000000007 586 powx350 power 1e-1 500000 -> 1E-500000 587 powx351 power 1e-2 999999 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 588 powx352 power 1e-2 500000 -> 1E-1000000 Subnormal 589 powx353 power 1e-2 500001 -> 1E-1000002 Subnormal 590 powx354 power 1e-2 500002 -> 1E-1000004 Subnormal 591 powx355 power 1e-2 500003 -> 1E-1000006 Subnormal 592 powx356 power 1e-2 500004 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 593 594 powx360 power 0.010001 500000 -> 5.17176082E-999979 Inexact Rounded 595 powx361 power 0.010000001 500000 -> 1.0512711E-1000000 Underflow Subnormal Inexact Rounded 596 powx362 power 0.010000001 500001 -> 1.05127E-1000002 Underflow Subnormal Inexact Rounded 597 powx363 power 0.0100000009 500000 -> 1.0460279E-1000000 Underflow Subnormal Inexact Rounded 598 powx364 power 0.0100000001 500000 -> 1.0050125E-1000000 Underflow Subnormal Inexact Rounded 599 powx365 power 0.01 500000 -> 1E-1000000 Subnormal 600 powx366 power 0.0099999999 500000 -> 9.950125E-1000001 Underflow Subnormal Inexact Rounded 601 powx367 power 0.0099999998 500000 -> 9.900498E-1000001 Underflow Subnormal Inexact Rounded 602 powx368 power 0.0099999997 500000 -> 9.851119E-1000001 Underflow Subnormal Inexact Rounded 603 powx369 power 0.0099999996 500000 -> 9.801987E-1000001 Underflow Subnormal Inexact Rounded 604 powx370 power 0.009 500000 -> 0E-1000007 Underflow Subnormal Inexact Rounded Clamped 605 606 -- 1/subnormal -> overflow 607 powx371 power 1e-1 -500000 -> 1E+500000 608 powx372 power 1e-2 -999999 -> Infinity Overflow Inexact Rounded 609 powx373 power 1e-2 -500000 -> Infinity Overflow Inexact Rounded 610 powx374 power 1e-2 -500001 -> Infinity Overflow Inexact Rounded 611 powx375 power 1e-2 -500002 -> Infinity Overflow Inexact Rounded 612 powx376 power 1e-2 -500003 -> Infinity Overflow Inexact Rounded 613 powx377 power 1e-2 -500004 -> Infinity Overflow Inexact Rounded 614 615 powx381 power 0.010001 -500000 -> 1.93357743E+999978 Inexact Rounded 616 powx382 power 0.010000001 -500000 -> 9.51229427E+999999 Inexact Rounded 617 powx383 power 0.010000001 -500001 -> Infinity Overflow Inexact Rounded 618 powx384 power 0.0100000009 -500000 -> 9.55997484E+999999 Inexact Rounded 619 powx385 power 0.0100000001 -500000 -> 9.95012479E+999999 Inexact Rounded 620 powx386 power 0.01 -500000 -> Infinity Overflow Inexact Rounded 621 powx387 power 0.009999 -500000 -> Infinity Overflow Inexact Rounded 622 623 -- negative power giving subnormal 624 powx388 power 100.000001 -500000 -> 9.950125E-1000001 Underflow Subnormal Inexact Rounded 625 626 627 -- test some 'false integer' boundaries 628 precision: 16 629 rounding: half_even 630 maxExponent: 384 631 minExponent: -383 632 powx501 power 100 1E+1 -> 1.000000000000000E+20 Rounded 633 powx502 power 100 1E+2 -> 1.000000000000000E+200 Rounded 634 powx503 power 100 1E+3 -> Infinity Overflow Inexact Rounded 635 powx504 power 100 1E+4 -> Infinity Overflow Inexact Rounded 636 powx505 power 100 1E+5 -> Infinity Overflow Inexact Rounded 637 powx506 power 100 1E+6 -> Infinity Overflow Inexact Rounded 638 powx507 power 100 1E+7 -> Infinity Overflow Inexact Rounded 639 powx508 power 100 1E+8 -> Infinity Overflow Inexact Rounded 640 powx509 power 100 1E+9 -> Infinity Overflow Inexact Rounded 641 powx510 power 100 1E+10 -> Infinity Overflow Inexact Rounded 642 powx511 power 100 1E+11 -> Infinity Overflow Inexact Rounded 643 powx512 power 100 1E+12 -> Infinity Overflow Inexact Rounded 644 powx513 power 100 1E+13 -> Infinity Overflow Inexact Rounded 645 powx514 power 100 1E+14 -> Infinity Overflow Inexact Rounded 646 powx515 power 100 1E+15 -> Infinity Overflow Inexact Rounded 647 powx516 power 100 1E+16 -> Infinity Overflow Inexact Rounded 648 powx517 power 100 1E+17 -> Infinity Overflow Inexact Rounded 649 powx518 power 100 1E+18 -> Infinity Overflow Inexact Rounded 650 powx519 power 100 1E+19 -> Infinity Overflow Inexact Rounded 651 powx520 power 100 1E+20 -> Infinity Overflow Inexact Rounded 652 powx521 power 100 1E+21 -> Infinity Overflow Inexact Rounded 653 powx522 power 100 1E+22 -> Infinity Overflow Inexact Rounded 654 powx523 power 100 1E+23 -> Infinity Overflow Inexact Rounded 655 powx524 power 100 1E+24 -> Infinity Overflow Inexact Rounded 656 powx525 power 100 1E+25 -> Infinity Overflow Inexact Rounded 657 powx526 power 100 1E+26 -> Infinity Overflow Inexact Rounded 658 powx527 power 100 1E+27 -> Infinity Overflow Inexact Rounded 659 powx528 power 100 1E+28 -> Infinity Overflow Inexact Rounded 660 powx529 power 100 1E+29 -> Infinity Overflow Inexact Rounded 661 powx530 power 100 1E+30 -> Infinity Overflow Inexact Rounded 662 powx531 power 100 1E+40 -> Infinity Overflow Inexact Rounded 663 powx532 power 100 1E+50 -> Infinity Overflow Inexact Rounded 664 powx533 power 100 1E+100 -> Infinity Overflow Inexact Rounded 665 powx534 power 100 1E+383 -> Infinity Overflow Inexact Rounded 666 667 -- a check for double-rounded subnormals 668 precision: 5 669 maxexponent: 79 670 minexponent: -79 671 powx750 power 1.2347E-40 2 -> 1.524E-80 Inexact Rounded Subnormal Underflow 672 673 -- Null tests 674 powx900 power 1 # -> NaN Invalid_operation 675 powx901 power # 1 -> NaN Invalid_operation 676 677 ---------------------------------------------------------------------- 678 -- Below here are tests with a precision or context outside of the -- 679 -- decNumber 'mathematical functions' restricted range. These -- 680 -- remain supported in decNumber to minimize breakage, but may be -- 681 -- outside the range of other implementations. -- 682 ---------------------------------------------------------------------- 683 maxexponent: 999999999 684 minexponent: -999999999 685 precision: 9 686 powx1063 power '10' '999999999' -> '1.00000000E+999999999' Rounded 687 powx1064 power '10' '999999998' -> '1.00000000E+999999998' Rounded 688 powx1065 power '10' '999999997' -> '1.00000000E+999999997' Rounded 689 powx1066 power '10' '333333333' -> '1.00000000E+333333333' Rounded 690 -- next two are integer-out-of range 691 powx1183 power '7' '1000000000' -> NaN Invalid_context 692 powx1184 power '7' '1000000001' -> NaN Invalid_context 693 powx1186 power '7' '-1000000001' -> 1.38243630E-845098041 Inexact Rounded 694 powx1187 power '7' '-1000000000' -> 9.67705411E-845098041 Inexact Rounded 695 696 -- out-of-range edge cases 697 powx1118 power '10' '-333333333' -> 1E-333333333 698 powx1119 power '10' '-999999998' -> 1E-999999998 699 powx1120 power '10' '-999999999' -> 1E-999999999 700 powx1181 power '7' '999999998' -> 2.10892313E+845098038 Inexact Rounded 701 powx1182 power '7' '999999999' -> 1.47624619E+845098039 Inexact Rounded 702 powx1189 power '7' '-999999999' -> 6.77393787E-845098040 Inexact Rounded 703 powx1190 power '7' '-999999998' -> 4.74175651E-845098039 Inexact Rounded 704 705 -- A (rare) case where the last digit is not within 0.5 ULP with classic precision 706 precision: 9 707 powx1215 power "-21971575.0E+31454441" "-7" -> "-4.04549502E-220181139" Inexact Rounded 708 precision: 20 709 powx1216 power "-21971575.0E+31454441" "-7" -> "-4.0454950249324891788E-220181139" Inexact Rounded 710 711 -- overflow and underflow tests 712 precision: 9 713 powx1280 power 9 999999999 -> 3.05550054E+954242508 Inexact Rounded 714 powx1281 power 10 999999999 -> 1.00000000E+999999999 Rounded 715 powx1282 power 10.0001 999999999 -> Infinity Overflow Inexact Rounded 716 powx1283 power 10.1 999999999 -> Infinity Overflow Inexact Rounded 717 powx1284 power 11 999999999 -> Infinity Overflow Inexact Rounded 718 powx1285 power 12 999999999 -> Infinity Overflow Inexact Rounded 719 powx1286 power 999 999999999 -> Infinity Overflow Inexact Rounded 720 powx1287 power 999999 999999999 -> Infinity Overflow Inexact Rounded 721 powx1288 power 999999999 999999999 -> Infinity Overflow Inexact Rounded 722 powx1289 power 9.9E999999999 999999999 -> Infinity Overflow Inexact Rounded 723 724 powx1290 power 0.5 999999999 -> 4.33559594E-301029996 Inexact Rounded 725 powx1291 power 0.1 999999999 -> 1E-999999999 -- unrounded 726 powx1292 power 0.09 999999999 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 727 powx1293 power 0.05 999999999 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 728 powx1294 power 0.01 999999999 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 729 powx1295 power 0.0001 999999999 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 730 powx1297 power 0.0000001 999999999 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 731 powx1298 power 0.0000000001 999999999 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 732 powx1299 power 1E-999999999 999999999 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 733 734 powx1310 power -9 999999999 -> -3.05550054E+954242508 Inexact Rounded 735 powx1311 power -10 999999999 -> -1.00000000E+999999999 Rounded 736 powx1312 power -10.0001 999999999 -> -Infinity Overflow Inexact Rounded 737 powx1313 power -10.1 999999999 -> -Infinity Overflow Inexact Rounded 738 powx1314 power -11 999999999 -> -Infinity Overflow Inexact Rounded 739 powx1315 power -12 999999999 -> -Infinity Overflow Inexact Rounded 740 powx1316 power -999 999999999 -> -Infinity Overflow Inexact Rounded 741 powx1317 power -999999 999999999 -> -Infinity Overflow Inexact Rounded 742 powx1318 power -999999999 999999999 -> -Infinity Overflow Inexact Rounded 743 powx1319 power -9.9E999999999 999999999 -> -Infinity Overflow Inexact Rounded 744 745 powx1320 power -0.5 999999999 -> -4.33559594E-301029996 Inexact Rounded 746 powx1321 power -0.1 999999999 -> -1E-999999999 747 powx1322 power -0.09 999999999 -> -0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 748 powx1323 power -0.05 999999999 -> -0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 749 powx1324 power -0.01 999999999 -> -0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 750 powx1325 power -0.0001 999999999 -> -0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 751 powx1327 power -0.0000001 999999999 -> -0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 752 powx1328 power -0.0000000001 999999999 -> -0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 753 powx1329 power -1E-999999999 999999999 -> -0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 754 755 -- note no trim of next result 756 powx1330 power -9 999999998 -> 3.39500060E+954242507 Inexact Rounded 757 powx1331 power -10 999999998 -> 1.00000000E+999999998 Rounded 758 powx1332 power -10.0001 999999998 -> Infinity Overflow Inexact Rounded 759 powx1333 power -10.1 999999998 -> Infinity Overflow Inexact Rounded 760 powx1334 power -11 999999998 -> Infinity Overflow Inexact Rounded 761 powx1335 power -12 999999998 -> Infinity Overflow Inexact Rounded 762 powx1336 power -999 999999998 -> Infinity Overflow Inexact Rounded 763 powx1337 power -999999 999999998 -> Infinity Overflow Inexact Rounded 764 powx1338 power -999999999 999999998 -> Infinity Overflow Inexact Rounded 765 powx1339 power -9.9E999999999 999999998 -> Infinity Overflow Inexact Rounded 766 767 powx1340 power -0.5 999999998 -> 8.67119187E-301029996 Inexact Rounded 768 powx1341 power -0.1 999999998 -> 1E-999999998 -- NB exact unrounded 769 powx1342 power -0.09 999999998 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 770 powx1343 power -0.05 999999998 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 771 powx1344 power -0.01 999999998 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 772 powx1345 power -0.0001 999999998 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 773 powx1347 power -0.0000001 999999998 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 774 powx1348 power -0.0000000001 999999998 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 775 powx1349 power -1E-999999999 999999998 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 776 777 -- some subnormals 778 precision: 9 779 -- [precision is 9, so smallest exponent is -1000000007 780 powx1350 power 1e-1 500000000 -> 1E-500000000 781 powx1351 power 1e-2 999999999 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 782 powx1352 power 1e-2 500000000 -> 1E-1000000000 Subnormal 783 powx1353 power 1e-2 500000001 -> 1E-1000000002 Subnormal 784 powx1354 power 1e-2 500000002 -> 1E-1000000004 Subnormal 785 powx1355 power 1e-2 500000003 -> 1E-1000000006 Subnormal 786 powx1356 power 1e-2 500000004 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 787 788 powx1360 power 0.010001 500000000 -> 4.34941988E-999978287 Inexact Rounded 789 powx1361 power 0.010000001 500000000 -> 5.18469257E-999999979 Inexact Rounded 790 powx1362 power 0.010000001 500000001 -> 5.18469309E-999999981 Inexact Rounded 791 powx1363 power 0.0100000009 500000000 -> 3.49342003E-999999981 Inexact Rounded 792 powx1364 power 0.0100000001 500000000 -> 1.48413155E-999999998 Inexact Rounded 793 powx1365 power 0.01 500000000 -> 1E-1000000000 Subnormal 794 powx1366 power 0.0099999999 500000000 -> 6.7379E-1000000003 Underflow Subnormal Inexact Rounded 795 powx1367 power 0.0099999998 500000000 -> 4.54E-1000000005 Underflow Subnormal Inexact Rounded 796 powx1368 power 0.0099999997 500000000 -> 3E-1000000007 Underflow Subnormal Inexact Rounded 797 powx1369 power 0.0099999996 500000000 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 798 powx1370 power 0.009 500000000 -> 0E-1000000007 Underflow Subnormal Inexact Rounded Clamped 799 800 -- 1/subnormal -> overflow 801 powx1371 power 1e-1 -500000000 -> 1E+500000000 802 powx1372 power 1e-2 -999999999 -> Infinity Overflow Inexact Rounded 803 powx1373 power 1e-2 -500000000 -> Infinity Overflow Inexact Rounded 804 powx1374 power 1e-2 -500000001 -> Infinity Overflow Inexact Rounded 805 powx1375 power 1e-2 -500000002 -> Infinity Overflow Inexact Rounded 806 powx1376 power 1e-2 -500000003 -> Infinity Overflow Inexact Rounded 807 powx1377 power 1e-2 -500000004 -> Infinity Overflow Inexact Rounded 808 809 powx1381 power 0.010001 -500000000 -> 2.29915719E+999978286 Inexact Rounded 810 powx1382 power 0.010000001 -500000000 -> 1.92875467E+999999978 Inexact Rounded 811 powx1383 power 0.010000001 -500000001 -> 1.92875448E+999999980 Inexact Rounded 812 powx1384 power 0.0100000009 -500000000 -> 2.86252438E+999999980 Inexact Rounded 813 powx1385 power 0.0100000001 -500000000 -> 6.73794717E+999999997 Inexact Rounded 814 powx1386 power 0.01 -500000000 -> Infinity Overflow Inexact Rounded 815 powx1387 power 0.009999 -500000000 -> Infinity Overflow Inexact Rounded 816 817 -- negative power giving subnormal 818 powx1388 power 100.000001 -500000000 -> 6.7379E-1000000003 Underflow Subnormal Inexact Rounded 819 820 ---------------------------------------------------------------------- 821 -- Below here are the tests with a non-integer rhs, including the -- 822 -- tests that previously caused Invalid operation. An integer-only -- 823 -- (on rhs) implementation should handle all the tests above as -- 824 -- shown, and would flag most of the following tests as Invalid. -- 825 ---------------------------------------------------------------------- 826 precision: 16 827 rounding: half_even 828 maxExponent: 384 829 minExponent: -383 830 831 powx2000 power 7 '10000000000' -> Infinity Overflow Inexact Rounded 832 powx2001 power 2 '2.000001' -> 4.000002772589683 Inexact Rounded 833 powx2002 power 2 '2.00000000' -> 4 834 powx2003 power 2 '2.000000001' -> 4.000000002772589 Inexact Rounded 835 powx2004 power 2 '2.0000000001' -> 4.000000000277259 Inexact Rounded 836 powx2005 power 2 '2.00000000001' -> 4.000000000027726 Inexact Rounded 837 powx2006 power 2 '2.000000000001' -> 4.000000000002773 Inexact Rounded 838 powx2007 power 2 '2.0000000000001' -> 4.000000000000277 Inexact Rounded 839 powx2008 power 2 '2.00000000000001' -> 4.000000000000028 Inexact Rounded 840 powx2009 power 2 '2.000000000000001' -> 4.000000000000003 Inexact Rounded 841 powx2010 power 2 '2.0000000000000001' -> 4.000000000000000 Inexact Rounded 842 -- 1 234567890123456 843 844 powx2011 power 1 1234 -> 1 845 precision: 4 846 powx2012 power 1 1234 -> 1 847 precision: 3 848 powx2013 power 1 1234 -> 1 849 powx2014 power 1 12.34e+2 -> 1 850 powx2015 power 1 12.3 -> 1.00 Inexact Rounded 851 powx2016 power 1 12.0 -> 1 852 powx2017 power 1 1.01 -> 1.00 Inexact Rounded 853 powx2018 power 2 1.00 -> 2 854 powx2019 power 2 2.00 -> 4 855 precision: 9 856 powx2030 power 1 1.0001 -> 1.00000000 Inexact Rounded 857 powx2031 power 1 1.0000001 -> 1.00000000 Inexact Rounded 858 powx2032 power 1 1.0000000001 -> 1.00000000 Inexact Rounded 859 powx2033 power 1 1.0000000000001 -> 1.00000000 Inexact Rounded 860 precision: 5 861 powx2034 power 1 1.0001 -> 1.0000 Inexact Rounded 862 powx2035 power 1 1.0000001 -> 1.0000 Inexact Rounded 863 powx2036 power 1 1.0000000001 -> 1.0000 Inexact Rounded 864 powx2037 power 1 1.0000000000001 -> 1.0000 Inexact Rounded 865 powx2038 power 1 1.0000000000001 -> 1.0000 Inexact Rounded 866 867 rounding: ceiling 868 precision: 3 869 powx2039 power 1 1.01 -> 1.00 Inexact Rounded 870 powx2040 power 1 12.3 -> 1.00 Inexact Rounded 871 rounding: half_even 872 873 -- 1 ** any integer, including big ones, should be exact 874 powx2041 power 1 1000000000 -> 1 875 powx2042 power 1 9999999999 -> 1 876 powx2043 power 1 12345678000 -> 1 877 powx2044 power 1 1234567800 -> 1 878 powx2045 power 1 1234567890 -> 1 879 powx2046 power 1 11234567891 -> 1 880 powx2047 power 1 12345678901 -> 1 881 powx2048 power 1 1234567896 -> 1 882 powx2049 power 1 -1234567896 -> 1 883 powx2051 power 1 1000000000 -> 1 884 powx2052 power 1 -1000000000 -> 1 885 powx2053 power 1 12345678000 -> 1 886 powx2054 power 1 -1234567896 -> 1 887 powx2055 power 1 1000000000 -> 1 888 powx2056 power 1 4300000000 -> 1 889 powx2057 power 1 -1000000000 -> 1 890 -- negatives ... but not out of range for decNumber 891 powx2061 power -1 100000 -> 1 892 powx2062 power -1 999999 -> -1 893 powx2063 power -1 1278000 -> 1 894 powx2064 power -1 127803 -> -1 895 powx2065 power -1 127890 -> 1 896 powx2066 power -1 1167891 -> -1 897 powx2067 power -1 1278901 -> -1 898 powx2068 power -1 127896 -> 1 899 powx2069 power -1 -167897 -> -1 900 powx2071 power -1 100000 -> 1 901 powx2072 power -1 -100001 -> -1 902 powx2073 power -1 1278000 -> 1 903 powx2074 power -1 -167896 -> 1 904 powx2075 power -1 100000 -> 1 905 powx2076 power -1 -100009 -> -1 906 907 -- The above were derived from the earlier version of power.decTest; 908 -- now start new tests for power(x,y) for non-integer y 909 precision: 9 910 911 -- tests from specification 912 powx2081 power 2 3 -> '8' 913 powx2082 power -2 3 -> '-8' 914 powx2083 power 2 -3 -> '0.125' 915 powx2084 power 1.7 '8' -> '69.7575744' Inexact Rounded 916 powx2085 power 10 0.301029996 -> 2.00000000 Inexact Rounded 917 powx2086 power Infinity '-1' -> '0' 918 powx2087 power Infinity '0' -> '1' 919 powx2088 power Infinity '1' -> 'Infinity' 920 powx2089 power -Infinity '-1' -> '-0' 921 powx2090 power -Infinity '0' -> '1' 922 powx2091 power -Infinity '1' -> '-Infinity' 923 powx2092 power -Infinity '2' -> 'Infinity' 924 powx2093 power 0 0 -> 'NaN' Invalid_operation 925 926 precision: 16 927 rounding: half_even 928 maxExponent: 384 929 minExponent: -383 930 931 -- basics 932 powx2100 power 1E-7 1E-7 -> 0.9999983881917339 Inexact Rounded 933 powx2101 power 0.003 1E-7 -> 0.9999994190858697 Inexact Rounded 934 powx2102 power 0.7 1E-7 -> 0.9999999643325062 Inexact Rounded 935 powx2103 power 1.2 1E-7 -> 1.000000018232156 Inexact Rounded 936 powx2104 power 71 1E-7 -> 1.000000426268079 Inexact Rounded 937 powx2105 power 9E+9 1E-7 -> 1.000002292051668 Inexact Rounded 938 939 powx2110 power 1E-7 0.003 -> 0.9527961640236519 Inexact Rounded 940 powx2111 power 0.003 0.003 -> 0.9827235503366797 Inexact Rounded 941 powx2112 power 0.7 0.003 -> 0.9989305474406207 Inexact Rounded 942 powx2113 power 1.2 0.003 -> 1.000547114282834 Inexact Rounded 943 powx2114 power 71 0.003 -> 1.012870156273545 Inexact Rounded 944 powx2115 power 9E+9 0.003 -> 1.071180671278787 Inexact Rounded 945 946 powx2120 power 1E-7 0.7 -> 0.00001258925411794167 Inexact Rounded 947 powx2121 power 0.003 0.7 -> 0.01713897630281030 Inexact Rounded 948 powx2122 power 0.7 0.7 -> 0.7790559126704491 Inexact Rounded 949 powx2123 power 1.2 0.7 -> 1.136126977198889 Inexact Rounded 950 powx2124 power 71 0.7 -> 19.76427300093870 Inexact Rounded 951 powx2125 power 9E+9 0.7 -> 9289016.976853710 Inexact Rounded 952 953 powx2130 power 1E-7 1.2 -> 3.981071705534973E-9 Inexact Rounded 954 powx2131 power 0.003 1.2 -> 0.0009387403933595694 Inexact Rounded 955 powx2132 power 0.7 1.2 -> 0.6518049405663864 Inexact Rounded 956 powx2133 power 1.2 1.2 -> 1.244564747203978 Inexact Rounded 957 powx2134 power 71 1.2 -> 166.5367244638552 Inexact Rounded 958 powx2135 power 9E+9 1.2 -> 881233526124.8791 Inexact Rounded 959 960 powx2140 power 1E-7 71 -> 0E-398 Inexact Rounded Underflow Subnormal Clamped 961 powx2141 power 0.003 71 -> 7.509466514979725E-180 Inexact Rounded 962 powx2142 power 0.7 71 -> 1.004525211269079E-11 Inexact Rounded 963 powx2143 power 1.2 71 -> 418666.7483186515 Inexact Rounded 964 powx2144 power 71 71 -> 2.750063734834616E+131 Inexact Rounded 965 powx2145 power 9E+9 71 -> Infinity Inexact Rounded Overflow 966 967 powx2150 power 1E-7 9E+9 -> 0E-398 Inexact Rounded Underflow Subnormal Clamped 968 powx2151 power 0.003 9E+9 -> 0E-398 Inexact Rounded Underflow Subnormal Clamped 969 powx2152 power 0.7 9E+9 -> 0E-398 Inexact Rounded Underflow Subnormal Clamped 970 powx2153 power 1.2 9E+9 -> Infinity Inexact Rounded Overflow 971 powx2154 power 71 9E+9 -> Infinity Inexact Rounded Overflow 972 powx2155 power 9E+9 9E+9 -> Infinity Inexact Rounded Overflow 973 974 -- number line milestones with lhs<1 and lhs>1 975 976 -- Overflow boundary (Nmax) 977 powx2202 power 71 207.966651583983200 -> Infinity Inexact Rounded Overflow 978 powx2201 power 71 207.966651583983199 -> 9.999999999999994E+384 Inexact Rounded 979 powx2204 power 0.003 -152.603449817093577 -> Infinity Inexact Rounded Overflow 980 powx2203 power 0.003 -152.603449817093576 -> 9.999999999999994E+384 Inexact Rounded 981 982 -- Nmin boundary 983 powx2211 power 71 -206.886305341988480 -> 1.000000000000005E-383 Inexact Rounded 984 powx2212 power 71 -206.886305341988481 -> 1.000000000000001E-383 Inexact Rounded 985 powx2213 power 71 -206.886305341988482 -> 9.99999999999997E-384 Inexact Rounded Underflow Subnormal 986 powx2214 power 71 -206.886305341988483 -> 9.99999999999992E-384 Inexact Rounded Underflow Subnormal 987 -- 9.999999999999924565357019820 988 989 powx2215 power 0.003 151.810704623238543 -> 1.000000000000009E-383 Inexact Rounded 990 powx2216 power 0.003 151.810704623238544 -> 1.000000000000003E-383 Inexact Rounded 991 powx2217 power 0.003 151.810704623238545 -> 9.99999999999997E-384 Inexact Rounded Underflow Subnormal 992 powx2218 power 0.003 151.810704623238546 -> 9.99999999999991E-384 Inexact Rounded Underflow Subnormal 993 994 -- Ntiny boundary, these edge cases determined using half_up rounding 995 rounding: half_up 996 powx2221 power 71 -215.151510469220498 -> 1E-398 Inexact Rounded Underflow Subnormal 997 powx2222 power 71 -215.151510469220499 -> 1E-398 Inexact Rounded Underflow Subnormal 998 powx2223 power 71 -215.151510469220500 -> 0E-398 Inexact Rounded Underflow Subnormal Clamped 999 powx2224 power 71 -215.151510469220501 -> 0E-398 Inexact Rounded Underflow Subnormal Clamped 1000 1001 powx2225 power 0.003 157.875613618285691 -> 1E-398 Inexact Rounded Underflow Subnormal 1002 powx2226 power 0.003 157.875613618285692 -> 1E-398 Inexact Rounded Underflow Subnormal 1003 powx2227 power 0.003 157.875613618285693 -> 0E-398 Inexact Rounded Underflow Subnormal Clamped 1004 powx2228 power 0.003 220 -> 0E-398 Inexact Rounded Underflow Subnormal Clamped 1005 rounding: half_even 1006 1007 -- power(10, y) are important ... 1008 1009 -- Integer powers are exact, unless over/underflow 1010 powx2301 power 10 385 -> Infinity Overflow Inexact Rounded 1011 powx2302 power 10 384 -> 1.000000000000000E+384 Rounded 1012 powx2303 power 10 17 -> 1.000000000000000E+17 Rounded 1013 powx2304 power 10 16 -> 1.000000000000000E+16 Rounded 1014 powx2305 power 10 15 -> 1000000000000000 1015 powx2306 power 10 10 -> 10000000000 1016 powx2307 power 10 5 -> 100000 1017 powx2308 power 10 1 -> 10 1018 powx2309 power 10 0 -> 1 1019 powx2310 power 10 -1 -> 0.1 1020 powx2311 power 10 -5 -> 0.00001 1021 powx2312 power 10 -6 -> 0.000001 1022 powx2313 power 10 -7 -> 1E-7 1023 powx2314 power 10 -8 -> 1E-8 1024 powx2315 power 10 -9 -> 1E-9 1025 powx2316 power 10 -10 -> 1E-10 1026 powx2317 power 10 -383 -> 1E-383 1027 powx2318 power 10 -384 -> 1E-384 Subnormal 1028 powx2319 power 10 -385 -> 1E-385 Subnormal 1029 powx2320 power 10 -397 -> 1E-397 Subnormal 1030 powx2321 power 10 -398 -> 1E-398 Subnormal 1031 powx2322 power 10 -399 -> 0E-398 Subnormal Underflow Inexact Rounded Clamped 1032 powx2323 power 10 -400 -> 0E-398 Subnormal Underflow Inexact Rounded Clamped 1033 1034 -- Independent sanity check: 1961 Godfrey & Siddons four-figure logs 1035 powx2351 power 10 0.0000 -> 1 1036 powx2352 power 10 0.3010 -> 1.999861869632744 Inexact Rounded 1037 powx2353 power 10 0.4771 -> 2.999853181190793 Inexact Rounded 1038 powx2354 power 10 0.6021 -> 4.000368510461250 Inexact Rounded 1039 powx2355 power 10 0.6990 -> 5.000345349769785 Inexact Rounded 1040 powx2356 power 10 0.7782 -> 6.000673538641164 Inexact Rounded 1041 powx2357 power 10 0.8451 -> 7.000031591308969 Inexact Rounded 1042 powx2358 power 10 0.9031 -> 8.000184448550990 Inexact Rounded 1043 powx2359 power 10 0.9542 -> 8.999119108700520 Inexact Rounded 1044 powx2360 power 10 0.9956 -> 9.899197750805841 Inexact Rounded 1045 powx2361 power 10 0.9996 -> 9.990793899844618 Inexact Rounded 1046 precision: 4 1047 powx2371 power 10 0.0000 -> 1 1048 powx2372 power 10 0.3010 -> 2.000 Inexact Rounded 1049 powx2373 power 10 0.4771 -> 3.000 Inexact Rounded 1050 powx2374 power 10 0.6021 -> 4.000 Inexact Rounded 1051 powx2375 power 10 0.6990 -> 5.000 Inexact Rounded 1052 powx2376 power 10 0.7782 -> 6.001 Inexact Rounded 1053 powx2377 power 10 0.8451 -> 7.000 Inexact Rounded 1054 powx2378 power 10 0.9031 -> 8.000 Inexact Rounded 1055 powx2379 power 10 0.9542 -> 8.999 Inexact Rounded 1056 powx2380 power 10 0.9956 -> 9.899 Inexact Rounded 1057 powx2381 power 10 0.9996 -> 9.991 Inexact Rounded 1058 1059 -- 10**x ~=2 (inverse of the test in log10.decTest) 1060 precision: 50 1061 powx2401 power 10 0.30102999566398119521373889472449302676818988146211 -> 2.0000000000000000000000000000000000000000000000000 Inexact Rounded 1062 precision: 49 1063 powx2402 power 10 0.3010299956639811952137388947244930267681898814621 -> 2.000000000000000000000000000000000000000000000000 Inexact Rounded 1064 precision: 48 1065 powx2403 power 10 0.301029995663981195213738894724493026768189881462 -> 2.00000000000000000000000000000000000000000000000 Inexact Rounded 1066 precision: 47 1067 powx2404 power 10 0.30102999566398119521373889472449302676818988146 -> 2.0000000000000000000000000000000000000000000000 Inexact Rounded 1068 precision: 46 1069 powx2405 power 10 0.3010299956639811952137388947244930267681898815 -> 2.000000000000000000000000000000000000000000000 Inexact Rounded 1070 precision: 45 1071 powx2406 power 10 0.301029995663981195213738894724493026768189881 -> 2.00000000000000000000000000000000000000000000 Inexact Rounded 1072 precision: 44 1073 powx2407 power 10 0.30102999566398119521373889472449302676818988 -> 2.0000000000000000000000000000000000000000000 Inexact Rounded 1074 precision: 43 1075 powx2408 power 10 0.3010299956639811952137388947244930267681899 -> 2.000000000000000000000000000000000000000000 Inexact Rounded 1076 precision: 42 1077 powx2409 power 10 0.301029995663981195213738894724493026768190 -> 2.00000000000000000000000000000000000000000 Inexact Rounded 1078 precision: 41 1079 powx2410 power 10 0.30102999566398119521373889472449302676819 -> 2.0000000000000000000000000000000000000000 Inexact Rounded 1080 precision: 40 1081 powx2411 power 10 0.3010299956639811952137388947244930267682 -> 2.000000000000000000000000000000000000000 Inexact Rounded 1082 precision: 39 1083 powx2412 power 10 0.301029995663981195213738894724493026768 -> 2.00000000000000000000000000000000000000 Inexact Rounded 1084 precision: 38 1085 powx2413 power 10 0.30102999566398119521373889472449302677 -> 2.0000000000000000000000000000000000000 Inexact Rounded 1086 precision: 37 1087 powx2414 power 10 0.3010299956639811952137388947244930268 -> 2.000000000000000000000000000000000000 Inexact Rounded 1088 precision: 36 1089 powx2415 power 10 0.301029995663981195213738894724493027 -> 2.00000000000000000000000000000000000 Inexact Rounded 1090 precision: 35 1091 powx2416 power 10 0.30102999566398119521373889472449303 -> 2.0000000000000000000000000000000000 Inexact Rounded 1092 precision: 34 1093 powx2417 power 10 0.3010299956639811952137388947244930 -> 2.000000000000000000000000000000000 Inexact Rounded 1094 precision: 33 1095 powx2418 power 10 0.301029995663981195213738894724493 -> 2.00000000000000000000000000000000 Inexact Rounded 1096 precision: 32 1097 powx2419 power 10 0.30102999566398119521373889472449 -> 2.0000000000000000000000000000000 Inexact Rounded 1098 precision: 31 1099 powx2420 power 10 0.3010299956639811952137388947245 -> 2.000000000000000000000000000000 Inexact Rounded 1100 precision: 30 1101 powx2421 power 10 0.301029995663981195213738894725 -> 2.00000000000000000000000000000 Inexact Rounded 1102 precision: 29 1103 powx2422 power 10 0.30102999566398119521373889472 -> 2.0000000000000000000000000000 Inexact Rounded 1104 precision: 28 1105 powx2423 power 10 0.3010299956639811952137388947 -> 2.000000000000000000000000000 Inexact Rounded 1106 precision: 27 1107 powx2424 power 10 0.301029995663981195213738895 -> 2.00000000000000000000000000 Inexact Rounded 1108 precision: 26 1109 powx2425 power 10 0.30102999566398119521373889 -> 2.0000000000000000000000000 Inexact Rounded 1110 precision: 25 1111 powx2426 power 10 0.3010299956639811952137389 -> 2.000000000000000000000000 Inexact Rounded 1112 precision: 24 1113 powx2427 power 10 0.301029995663981195213739 -> 2.00000000000000000000000 Inexact Rounded 1114 precision: 23 1115 powx2428 power 10 0.30102999566398119521374 -> 2.0000000000000000000000 Inexact Rounded 1116 precision: 22 1117 powx2429 power 10 0.3010299956639811952137 -> 2.000000000000000000000 Inexact Rounded 1118 precision: 21 1119 powx2430 power 10 0.301029995663981195214 -> 2.00000000000000000000 Inexact Rounded 1120 precision: 20 1121 powx2431 power 10 0.30102999566398119521 -> 2.0000000000000000000 Inexact Rounded 1122 precision: 19 1123 powx2432 power 10 0.3010299956639811952 -> 2.000000000000000000 Inexact Rounded 1124 precision: 18 1125 powx2433 power 10 0.301029995663981195 -> 2.00000000000000000 Inexact Rounded 1126 precision: 17 1127 powx2434 power 10 0.30102999566398120 -> 2.0000000000000000 Inexact Rounded 1128 precision: 16 1129 powx2435 power 10 0.3010299956639812 -> 2.000000000000000 Inexact Rounded 1130 precision: 15 1131 powx2436 power 10 0.301029995663981 -> 2.00000000000000 Inexact Rounded 1132 precision: 14 1133 powx2437 power 10 0.30102999566398 -> 2.0000000000000 Inexact Rounded 1134 precision: 13 1135 powx2438 power 10 0.3010299956640 -> 2.000000000000 Inexact Rounded 1136 precision: 12 1137 powx2439 power 10 0.301029995664 -> 2.00000000000 Inexact Rounded 1138 precision: 11 1139 powx2440 power 10 0.30102999566 -> 2.0000000000 Inexact Rounded 1140 precision: 10 1141 powx2441 power 10 0.3010299957 -> 2.000000000 Inexact Rounded 1142 precision: 9 1143 powx2442 power 10 0.301029996 -> 2.00000000 Inexact Rounded 1144 precision: 8 1145 powx2443 power 10 0.30103000 -> 2.0000000 Inexact Rounded 1146 precision: 7 1147 powx2444 power 10 0.3010300 -> 2.000000 Inexact Rounded 1148 precision: 6 1149 powx2445 power 10 0.301030 -> 2.00000 Inexact Rounded 1150 precision: 5 1151 powx2446 power 10 0.30103 -> 2.0000 Inexact Rounded 1152 precision: 4 1153 powx2447 power 10 0.3010 -> 2.000 Inexact Rounded 1154 precision: 3 1155 powx2448 power 10 0.301 -> 2.00 Inexact Rounded 1156 precision: 2 1157 powx2449 power 10 0.30 -> 2.0 Inexact Rounded 1158 precision: 1 1159 powx2450 power 10 0.3 -> 2 Inexact Rounded 1160 1161 maxExponent: 384 1162 minExponent: -383 1163 precision: 16 1164 rounding: half_even 1165 1166 -- Close-to-e tests 1167 precision: 34 1168 powx2500 power 10 0.4342944819032518276511289189166048 -> 2.718281828459045235360287471352661 Inexact Rounded 1169 powx2501 power 10 0.4342944819032518276511289189166049 -> 2.718281828459045235360287471352661 Inexact Rounded 1170 powx2502 power 10 0.4342944819032518276511289189166050 -> 2.718281828459045235360287471352662 Inexact Rounded 1171 powx2503 power 10 0.4342944819032518276511289189166051 -> 2.718281828459045235360287471352663 Inexact Rounded 1172 powx2504 power 10 0.4342944819032518276511289189166052 -> 2.718281828459045235360287471352663 Inexact Rounded 1173 1174 -- e**e, 16->34 1175 powx2505 power 2.718281828459045 2.718281828459045 -> '15.15426224147925705633739513098219' Inexact Rounded 1176 1177 -- Sequence around an integer 1178 powx2512 power 10 2.9999999999999999999999999999999997 -> 999.9999999999999999999999999999993 Inexact Rounded 1179 powx2513 power 10 2.9999999999999999999999999999999998 -> 999.9999999999999999999999999999995 Inexact Rounded 1180 powx2514 power 10 2.9999999999999999999999999999999999 -> 999.9999999999999999999999999999998 Inexact Rounded 1181 powx2515 power 10 3.0000000000000000000000000000000000 -> 1000 1182 powx2516 power 10 3.0000000000000000000000000000000001 -> 1000.000000000000000000000000000000 Inexact Rounded 1183 powx2517 power 10 3.0000000000000000000000000000000002 -> 1000.000000000000000000000000000000 Inexact Rounded 1184 powx2518 power 10 3.0000000000000000000000000000000003 -> 1000.000000000000000000000000000001 Inexact Rounded 1185 1186 -- randomly generated tests 1187 maxExponent: 384 1188 minExponent: -383 1189 1190 -- P=34, within 0-999 -- positive arg2 1191 Precision: 34 1192 powx3201 power 5.301557744131969249145904611290735 369.3175647984435534243813466380579 -> 3.427165676345688240023113326603960E+267 Inexact Rounded 1193 powx3202 power 0.0000000000506875655819165973738225 21.93514102704466434121826965196878 -> 1.498169860033487321566659495340789E-226 Inexact Rounded 1194 powx3203 power 97.88877680721519917858007810494043 5.159898445242793470476673109899554 -> 18705942904.43290467281449559427982 Inexact Rounded 1195 powx3204 power 7.380441015594399747973924380493799 17.93614173904818313507525109033288 -> 3715757985820076.273336082702577274 Inexact Rounded 1196 powx3205 power 2.045623627647350918819219169855040 1082.999652407430697958175966996254 -> 4.208806435006704867447150904279854E+336 Inexact Rounded 1197 powx3206 power 0.0000000762582873112118926142955423 20.30534237055073996975203864170432 -> 2.967574278677013090697130349198877E-145 Inexact Rounded 1198 powx3207 power 0.0000000000194091470907814855660535 14.71164213947722238856835440242911 -> 2.564391397469554735037158345963280E-158 Inexact Rounded 1199 powx3208 power 0.0000000000509434185382818596853504 20.97051498204188277347203735421595 -> 1.420157372748083000927138678417272E-216 Inexact Rounded 1200 powx3209 power 0.0005389217212073307301395750745119 43.96798225485747315858678755538971 -> 1.957850185781292007977898626137240E-144 Inexact Rounded 1201 powx3210 power 498.5690105989136050444077447411198 128.1038813807243375878831104745803 -> 3.882212970903893127009102293596268E+345 Inexact Rounded 1202 powx3211 power 0.0000000935428918637303954281938975 5.736933454863278597460091596496099 -> 4.733219644540496152403967823635195E-41 Inexact Rounded 1203 powx3212 power 8.581586784734161309180363110126352 252.0229459968869784643374981477208 -> 1.907464842458674622356177850049873E+235 Inexact Rounded 1204 powx3213 power 294.1005302951621709143320795278305 155.5466374141708615975111014663722 -> 9.251717033292072959166737280729728E+383 Inexact Rounded 1205 powx3214 power 0.0000000041253343654396865855722090 19.00170974760425576247662125110472 -> 4.779566288553864405790921353593512E-160 Inexact Rounded 1206 powx3215 power 0.0000000000046912257352141395184092 24.66089523148729269098773236636878 -> 4.205126874048597849476723538057527E-280 Inexact Rounded 1207 powx3216 power 0.0000000000036796674296520639450494 22.09713956900694689234335912523078 -> 2.173081843837539818472071316420405E-253 Inexact Rounded 1208 powx3217 power 9.659887100303037657934372148567685 277.3765665424320875993026404492216 -> 1.614974043145519382749740616665041E+273 Inexact Rounded 1209 powx3218 power 0.0000083231310642229204398943076403 29.33123211782131466471359128190372 -> 1.013330439786660210757226597785328E-149 Inexact Rounded 1210 powx3219 power 0.0938084859086450954956863725653664 262.6091918199905272837286784975012 -> 1.262802485286301066967555821509344E-270 Inexact Rounded 1211 powx3220 power 8.194926977580900145696305910223304 184.3705133945546202012995485297248 -> 2.696353910907824016690021495828584E+168 Inexact Rounded 1212 powx3221 power 72.39594594653085161522285114566120 168.7721909489321402152033939836725 -> 7.379858293630460043361584410795031E+313 Inexact Rounded 1213 powx3222 power 0.0000000000003436856010144185445537 26.34329868961274988994452526178983 -> 4.585379573595865689605567720192768E-329 Inexact Rounded 1214 powx3223 power 20.18365633762226550254542489492623 127.2099705237021350103678072707790 -> 1.020919629336979353690271762206060E+166 Inexact Rounded 1215 powx3224 power 0.0000000553723990761530290129268131 8.157597566134754638015199501162405 -> 6.349030513396147480954474615067145E-60 Inexact Rounded 1216 powx3225 power 0.0001028742674265840656614682618035 93.99842317306603797965470281716482 -> 1.455871110222736531854990397769940E-375 Inexact Rounded 1217 powx3226 power 95.90195152775543876489746343266050 143.5992850002211509777720799352475 -> 3.881540015848530405189834366588567E+284 Inexact Rounded 1218 powx3227 power 0.0000000000041783747057233878360333 12.14591167764993506821334760954430 -> 6.190998557456885985124592807383163E-139 Inexact Rounded 1219 powx3228 power 0.5572830497086740798434917090018768 1001.921811263919522230330241349166 -> 3.871145158537170450093833881625838E-255 Inexact Rounded 1220 powx3229 power 516.4754759779093954790813881333232 29.23812463126309057800793645336343 -> 2.110986192408878294012450052929185E+79 Inexact Rounded 1221 powx3230 power 0.0000835892099464584776847299020706 27.64279992884843877453592659341588 -> 1.891535098905506689512376224943293E-113 Inexact Rounded 1222 powx3231 power 72.45836577748571838139900165184955 166.2562890735032545091688015160084 -> 1.784091549041561516923092542939141E+309 Inexact Rounded 1223 powx3232 power 305.1823317643335924007629563009032 83.01065159508472884219290136319623 -> 1.757493136164395229602456782779110E+206 Inexact Rounded 1224 powx3233 power 7.108527102951713603542835791733786 145.7057852766236365450463428821948 -> 1.285934774113104362663619896550528E+124 Inexact Rounded 1225 powx3234 power 6.471393503175464828149365697049824 64.11741937262455725284754171995720 -> 9.978990355881803195280027533011699E+51 Inexact Rounded 1226 powx3235 power 39.72898094138459885662380866268385 239.9677288017447400786672779735168 -> 5.422218208517098335832848487375086E+383 Inexact Rounded 1227 powx3236 power 0.0002865592332736973000183287329933 90.34733869590583787065642532641096 -> 8.293733126976212033209243257136796E-321 Inexact Rounded 1228 powx3237 power 0.0000011343384394864811195077357936 1.926568285528399656789140809399396 -> 3.516055639378350146874261077470142E-12 Inexact Rounded 1229 powx3238 power 0.0000000035321610295065299384889224 7.583861778824284092434085265265582 -> 7.970899823817369764381976286536230E-65 Inexact Rounded 1230 powx3239 power 657.5028301569352677543770758346683 90.55778453811965116200206020172758 -> 1.522530898581564200655160665723268E+255 Inexact Rounded 1231 powx3240 power 8.484756398325748879450577520251447 389.7468292476262478578280531222417 -> 8.595142803587368093392510310811218E+361 Inexact Rounded 1232 1233 -- P=16, within 0-99 -- positive arg2 1234 Precision: 16 1235 powx3101 power 0.0000215524639223 48.37532522355252 -> 1.804663257287277E-226 Inexact Rounded 1236 powx3102 power 00.80705856227999 2706.777535121391 -> 1.029625065876157E-252 Inexact Rounded 1237 powx3103 power 3.445441676383689 428.5185892455830 -> 1.657401683096454E+230 Inexact Rounded 1238 powx3104 power 0.0040158689495826 159.5725558816240 -> 4.255743665762492E-383 Inexact Rounded 1239 powx3105 power 0.0000841553281215 38.32504413453944 -> 6.738653902512052E-157 Inexact Rounded 1240 powx3106 power 0.7322610252571353 502.1254457674118 -> 1.109978126985943E-68 Inexact Rounded 1241 powx3107 power 10.75052532144880 67.34180604734781 -> 2.873015019470189E+69 Inexact Rounded 1242 powx3108 power 26.20425952945617 104.6002671186488 -> 2.301859355777030E+148 Inexact Rounded 1243 powx3109 power 0.0000055737473850 31.16285859005424 -> 1.883348470100446E-164 Inexact Rounded 1244 powx3110 power 61.06096011360700 10.93608439088726 -> 3.382686473028249E+19 Inexact Rounded 1245 powx3111 power 9.340880853257137 179.9094938131726 -> 3.819299795937696E+174 Inexact Rounded 1246 powx3112 power 0.0000050767371756 72.03346394186741 -> 4.216236691569869E-382 Inexact Rounded 1247 powx3113 power 6.838478807860596 47.49665590602285 -> 4.547621630099203E+39 Inexact Rounded 1248 powx3114 power 0.1299324346439081 397.7440523576938 -> 3.065047705553981E-353 Inexact Rounded 1249 powx3115 power 0.0003418047034264 20.00516791512018 -> 4.546189665380487E-70 Inexact Rounded 1250 powx3116 power 0.0001276899611715 78.12968287355703 -> 5.960217405063995E-305 Inexact Rounded 1251 powx3117 power 25.93160588180509 252.6245071004620 -> 1.472171597589146E+357 Inexact Rounded 1252 powx3118 power 35.47516857763178 86.14723037360925 -> 3.324299908481125E+133 Inexact Rounded 1253 powx3119 power 0.0000048171086721 43.31965603038666 -> 4.572331516616228E-231 Inexact Rounded 1254 powx3120 power 17.97652681097851 144.4684576550292 -> 1.842509906097860E+181 Inexact Rounded 1255 powx3121 power 3.622765141518729 305.1948680344950 -> 4.132320967578704E+170 Inexact Rounded 1256 powx3122 power 0.0080959002453519 143.9899444945627 -> 6.474627812947047E-302 Inexact Rounded 1257 powx3123 power 9.841699927276571 299.2466668837188 -> 1.489097656208736E+297 Inexact Rounded 1258 powx3124 power 0.0786659206232355 347.4750796962570 -> 2.05764809646925E-384 Inexact Rounded Underflow Subnormal 1259 powx3125 power 0.0000084459792645 52.47348690745487 -> 6.076251876516942E-267 Inexact Rounded 1260 powx3126 power 27.86589909967504 191.7296537102283 -> 1.157064112989386E+277 Inexact Rounded 1261 powx3127 power 0.0000419907937234 58.44957702730767 -> 1.496950672075162E-256 Inexact Rounded 1262 powx3128 power 0.0000664977739382 80.06749213261876 -> 3.488517620107875E-335 Inexact Rounded 1263 powx3129 power 58.49554484886656 125.8480768373499 -> 2.449089862146640E+222 Inexact Rounded 1264 powx3130 power 15.02820060024449 212.3527988973338 -> 8.307913932682067E+249 Inexact Rounded 1265 powx3131 power 0.0002650089942992 30.92173123678761 -> 2.517827664836147E-111 Inexact Rounded 1266 powx3132 power 0.0007342977426578 69.49168880741123 -> 1.600168665674440E-218 Inexact Rounded 1267 powx3133 power 0.0063816068650629 150.1400094183812 -> 2.705057295799001E-330 Inexact Rounded 1268 powx3134 power 9.912921122728791 297.8274013633411 -> 4.967624993438900E+296 Inexact Rounded 1269 powx3135 power 1.988603563989245 768.4862967922182 -> 2.692842474899596E+229 Inexact Rounded 1270 powx3136 power 8.418014519517691 164.2431359980725 -> 9.106211585888836E+151 Inexact Rounded 1271 powx3137 power 6.068823604450686 120.2955212365837 -> 1.599431918105982E+94 Inexact Rounded 1272 powx3138 power 56.90062738303850 54.90468294683645 -> 2.312839177902428E+96 Inexact Rounded 1273 powx3139 power 5.710905139750871 73.44608752962156 -> 3.775876053709929E+55 Inexact Rounded 1274 powx3140 power 0.0000017446761203 1.223981492228899 -> 8.952936595465635E-8 Inexact Rounded 1275 1276 -- P=7, within 0-9 -- positive arg2 1277 Precision: 7 1278 powx3001 power 8.738689 55.96523 -> 4.878180E+52 Inexact Rounded 1279 powx3002 power 0.0404763 147.4965 -> 3.689722E-206 Inexact Rounded 1280 powx3003 power 0.0604232 76.69778 -> 3.319183E-94 Inexact Rounded 1281 powx3004 power 0.0058855 107.5018 -> 1.768875E-240 Inexact Rounded 1282 powx3005 power 2.058302 1173.050 -> 5.778899E+367 Inexact Rounded 1283 powx3006 power 0.0056998 85.70157 -> 4.716783E-193 Inexact Rounded 1284 powx3007 power 0.8169297 3693.537 -> 4.475962E-325 Inexact Rounded 1285 powx3008 power 0.2810153 659.9568 -> 1.533177E-364 Inexact Rounded 1286 powx3009 power 4.617478 15.68308 -> 2.629748E+10 Inexact Rounded 1287 powx3010 power 0.0296418 244.2302 -> 6.207949E-374 Inexact Rounded 1288 powx3011 power 0.0036456 127.9987 -> 8.120891E-313 Inexact Rounded 1289 powx3012 power 0.5012813 577.5418 -> 6.088802E-174 Inexact Rounded 1290 powx3013 power 0.0033275 119.9800 -> 5.055049E-298 Inexact Rounded 1291 powx3014 power 0.0037652 111.7092 -> 1.560351E-271 Inexact Rounded 1292 powx3015 power 0.6463252 239.0568 -> 4.864564E-46 Inexact Rounded 1293 powx3016 power 4.784378 475.0521 -> 8.964460E+322 Inexact Rounded 1294 powx3017 power 4.610305 563.1791 -> 6.290298E+373 Inexact Rounded 1295 powx3018 power 0.0175167 80.52208 -> 3.623472E-142 Inexact Rounded 1296 powx3019 power 5.238307 356.7944 -> 4.011461E+256 Inexact Rounded 1297 powx3020 power 0.0003527 96.26347 -> 4.377932E-333 Inexact Rounded 1298 powx3021 power 0.0015155 136.0516 -> 2.57113E-384 Inexact Rounded Underflow Subnormal 1299 powx3022 power 5.753573 273.2340 -> 4.373184E+207 Inexact Rounded 1300 powx3023 power 7.778665 332.7917 -> 3.060640E+296 Inexact Rounded 1301 powx3024 power 1.432479 2046.064 -> 2.325829E+319 Inexact Rounded 1302 powx3025 power 5.610516 136.4563 -> 1.607502E+102 Inexact Rounded 1303 powx3026 power 0.0050697 137.4513 -> 3.522315E-316 Inexact Rounded 1304 powx3027 power 5.678737 85.16253 -> 1.713909E+64 Inexact Rounded 1305 powx3028 power 0.0816167 236.1973 -> 9.228802E-258 Inexact Rounded 1306 powx3029 power 0.2602805 562.0157 -> 2.944556E-329 Inexact Rounded 1307 powx3030 power 0.0080936 24.25367 -> 1.839755E-51 Inexact Rounded 1308 powx3031 power 4.092016 82.94603 -> 5.724948E+50 Inexact Rounded 1309 powx3032 power 0.0078255 7.204184 -> 6.675342E-16 Inexact Rounded 1310 powx3033 power 0.9917693 29846.44 -> 7.430177E-108 Inexact Rounded 1311 powx3034 power 1.610380 301.2467 -> 2.170142E+62 Inexact Rounded 1312 powx3035 power 0.0588236 212.1097 -> 1.023196E-261 Inexact Rounded 1313 powx3036 power 2.498069 531.4647 -> 2.054561E+211 Inexact Rounded 1314 powx3037 power 9.964342 326.5438 -> 1.089452E+326 Inexact Rounded 1315 powx3038 power 0.0820626 268.8718 -> 1.107350E-292 Inexact Rounded 1316 powx3039 power 6.176486 360.7779 -> 1.914449E+285 Inexact Rounded 1317 powx3040 power 4.206363 16.17288 -> 1.231314E+10 Inexact Rounded 1318 1319 -- P=34, within 0-999 -- negative arg2 1320 Precision: 34 1321 powx3701 power 376.0915270000109486633402827007902 -35.69822349904102131649243701958463 -> 1.165722831225506457828653413200143E-92 Inexact Rounded 1322 powx3702 power 0.0000000503747440074613191665845314 -9.520308341497979093021813571450575 -> 3.000432478861883953977971226770410E+69 Inexact Rounded 1323 powx3703 power 290.6858731495339778337953407938308 -118.5459048597789693292455673428367 -> 9.357969047113989238392527565200302E-293 Inexact Rounded 1324 powx3704 power 4.598864607620052062908700928454182 -299.8323667698931125720218537483753 -> 2.069641269855413539579128114448478E-199 Inexact Rounded 1325 powx3705 power 2.556952676986830645708349254938903 -425.1755373251941383147998924703593 -> 4.428799777833598654260883861514638E-174 Inexact Rounded 1326 powx3706 power 0.0000005656198763404221986640610118 -32.83361380678301321230028730075315 -> 1.340270622401829145968477601029251E+205 Inexact Rounded 1327 powx3707 power 012.4841978642452960750801410372125 -214.3734291828712962809866663321921 -> 9.319857751170603140459057535971202E-236 Inexact Rounded 1328 powx3708 power 0.0000000056041586148066919174315551 -37.21129049213858341528033343116533 -> 1.118345010652454313186702341873169E+307 Inexact Rounded 1329 powx3709 power 0.0694569218941833767199998804202152 -8.697509072368973932501239815677732 -> 11862866995.51026489032838174290271 Inexact Rounded 1330 powx3710 power 6.380984024259450398729243522354144 -451.0635696889193561457985486366827 -> 8.800353109387322474809325670314330E-364 Inexact Rounded 1331 powx3711 power 786.0264840756809048288007204917801 -43.09935384678762773057342161718540 -> 1.616324183365644133979585419925934E-125 Inexact Rounded 1332 powx3712 power 96.07836427113204744101287948445130 -185.1414572546330024388914720271876 -> 8.586320815218383004023264980018610E-368 Inexact Rounded 1333 powx3713 power 0.0000000002332189796855870659792406 -5.779561613164628076880609893753327 -> 4.678450775876385793618570483345066E+55 Inexact Rounded 1334 powx3714 power 0.7254146672024602242369943237968857 -2115.512891397828615710130092245691 -> 8.539080958041689288202111403102495E+294 Inexact Rounded 1335 powx3715 power 0.0017380543649702864796144008592137 -6.307668017761022788220578633538713 -> 256309141459075651.2275798017695017 Inexact Rounded 1336 powx3716 power 05.29498758952276908267649116142379 -287.3233896734103442991981056134167 -> 1.039130027847489364009368608104291E-208 Inexact Rounded 1337 powx3717 power 15.64403593865932622003462779104178 -110.5296633358063267478609032002475 -> 9.750540276026524527375125980296142E-133 Inexact Rounded 1338 powx3718 power 89.69639006761571087634945077373508 -181.3209914139357665609268339422627 -> 8.335034232277762924539395632025281E-355 Inexact Rounded 1339 powx3719 power 6.974087483731006359914914110135058 -174.6815625746710345173615508179842 -> 4.553072265122011176641590109568031E-148 Inexact Rounded 1340 powx3720 power 0.0034393024010554821130553772681993 -93.60931598413919272595497100497364 -> 4.067468855817145539589988349449394E+230 Inexact Rounded 1341 powx3721 power 63.32834072300379155053737260965633 -168.3926799435088324825751446957616 -> 4.207907835462640471617519501741094E-304 Inexact Rounded 1342 powx3722 power 00.00216088174206276369011255907785 -70.12279562855442784757874508991013 -> 8.000657143378187029609343435067057E+186 Inexact Rounded 1343 powx3723 power 934.5957982703545893572134393004375 -102.2287735565878252484031426026726 -> 2.073813769209257617246544424827240E-304 Inexact Rounded 1344 powx3724 power 107.9116792558793921873995885441177 -44.11941092260869786313838181499158 -> 2.005476533631183268912552168759595E-90 Inexact Rounded 1345 powx3725 power 0.0000000000188049827381428191769262 -19.32118917192242027966847501724073 -> 1.713174297100918857053338286389034E+207 Inexact Rounded 1346 powx3726 power 614.9820907366248142166636259027728 -4.069913257030791586645250035698123 -> 4.462432572576935752713876293746717E-12 Inexact Rounded 1347 powx3727 power 752.0655175769182096165651274049422 -22.59292060348797472013598378334370 -> 1.039881526694635205040192531504131E-65 Inexact Rounded 1348 powx3728 power 72.20446632047659449616175456059013 -175.4705356401853924020842356605072 -> 7.529540175791582421966947814549028E-327 Inexact Rounded 1349 powx3729 power 518.8346486600403405764055847937416 -65.87320268592761588756963215588232 -> 1.420189426992170936958891180073151E-179 Inexact Rounded 1350 powx3730 power 3.457164372003960576453458502270716 -440.3201118177861273814529713443698 -> 6.176418595751201287186292664257369E-238 Inexact Rounded 1351 powx3731 power 7.908352793344189720739467675503991 -298.6646112894719680394152664740255 -> 5.935857120229147638104675057695125E-269 Inexact Rounded 1352 powx3732 power 0.0000004297399403788595027926075086 -22.66504617185071293588817501468339 -> 2.012270405520600820469665145636204E+144 Inexact Rounded 1353 powx3733 power 0.0000008592124097322966354868716443 -9.913109586558030204789520190180906 -> 1.354958763843310237046818832755215E+60 Inexact Rounded 1354 powx3734 power 161.4806080561258105880907470989925 -70.72907837434814261716311990271578 -> 6.632555003698945544941329872901929E-157 Inexact Rounded 1355 powx3735 power 0.0000000090669568624173832705631918 -36.53759624613665940127058439106640 -> 7.161808401023414735428130112941559E+293 Inexact Rounded 1356 powx3736 power 0.0000000000029440295978365709342752 -1.297354238738921988884421117731562 -> 911731060579291.7661267358872917380 Inexact Rounded 1357 powx3737 power 21.37477220144832172175460425143692 -76.95949933640539226475686997477889 -> 4.481741242418091914011962399912885E-103 Inexact Rounded 1358 powx3738 power 0.0000000000186657798201636342150903 -20.18296240350678245567049161730909 -> 3.483954007114900406906338526575672E+216 Inexact Rounded 1359 powx3739 power 0.0006522464792960191985996959126792 -80.03762491483514679886504099194414 -> 9.266548513614215557228467517053035E+254 Inexact Rounded 1360 powx3740 power 0.0000000032851343694200568966168055 -21.53462116926375512242403160008026 -> 4.873201679668455240861376213601189E+182 Inexact Rounded 1361 1362 -- P=16, within 0-99 -- negative arg2 1363 Precision: 16 1364 powx3601 power 0.0000151338748474 -40.84655618364688 -> 7.628470824137755E+196 Inexact Rounded 1365 powx3602 power 0.1542771848654862 -435.8830009466800 -> 6.389817177800744E+353 Inexact Rounded 1366 powx3603 power 48.28477749367364 -218.5929209902050 -> 8.531049532576154E-369 Inexact Rounded 1367 powx3604 power 7.960775891584911 -12.78113732182505 -> 3.053270889769488E-12 Inexact Rounded 1368 powx3605 power 0.9430340651863058 -9010.470056913748 -> 3.313374654923807E+229 Inexact Rounded 1369 powx3606 power 0.0000202661501602 -65.57915207383306 -> 5.997379176536464E+307 Inexact Rounded 1370 powx3607 power 04.33007440798390 -232.0476834666588 -> 2.007827183010456E-148 Inexact Rounded 1371 powx3608 power 0.0000141944643914 -11.32407921958717 -> 7.902934485074846E+54 Inexact Rounded 1372 powx3609 power 0.0000021977758261 -53.53706138253307 -> 8.195631772317815E+302 Inexact Rounded 1373 powx3610 power 39.51297655474188 -19.40370976012326 -> 1.040699608072659E-31 Inexact Rounded 1374 powx3611 power 38.71210232488775 -66.58341618227921 -> 1.886855066146495E-106 Inexact Rounded 1375 powx3612 power 0.0000804235229062 -6.715207948992859 -> 3.134757864389333E+27 Inexact Rounded 1376 powx3613 power 0.0000073547092399 -11.27725685719934 -> 7.781428390953695E+57 Inexact Rounded 1377 powx3614 power 52.72181272599316 -186.1422311607435 -> 2.916601998744177E-321 Inexact Rounded 1378 powx3615 power 0.0969519963083306 -280.8220862151369 -> 3.955906885970987E+284 Inexact Rounded 1379 powx3616 power 94.07263302150081 -148.2031146071230 -> 3.361958990752490E-293 Inexact Rounded 1380 powx3617 power 85.80286965053704 -90.21453695813759 -> 3.715602429645798E-175 Inexact Rounded 1381 powx3618 power 03.52699858152259 -492.0414362539196 -> 4.507309220081092E-270 Inexact Rounded 1382 powx3619 power 0.0508278086396068 -181.0871731572167 -> 2.034428013017949E+234 Inexact Rounded 1383 powx3620 power 0.395576740303172 -915.5524507432392 -> 5.706585187437578E+368 Inexact Rounded 1384 powx3621 power 38.06105826789202 -49.75913753435335 -> 2.273188991431738E-79 Inexact Rounded 1385 powx3622 power 0.0003656748910646 -73.28988491310354 -> 7.768936940568763E+251 Inexact Rounded 1386 powx3623 power 0.0000006373551809 -51.30825234200690 -> 7.697618167701985E+317 Inexact Rounded 1387 powx3624 power 82.41729920673856 -35.73319631625699 -> 3.424042354585529E-69 Inexact Rounded 1388 powx3625 power 0.7845821453127670 -971.4982028897663 -> 2.283415527661089E+102 Inexact Rounded 1389 powx3626 power 4.840983673433497 -182.3730452370515 -> 1.220591407927770E-125 Inexact Rounded 1390 powx3627 power 0.0000006137592139 -2.122139474431484 -> 15231217034839.29 Inexact Rounded 1391 powx3628 power 0.0003657962862984 -35.97993782448099 -> 4.512701319250839E+123 Inexact Rounded 1392 powx3629 power 40.93693004443150 -165.1362408792997 -> 6.044276411057239E-267 Inexact Rounded 1393 powx3630 power 0.2941552583028898 -17.41046264945892 -> 1787833103.503346 Inexact Rounded 1394 powx3631 power 63.99335135369977 -69.92417205168579 -> 5.099359804872509E-127 Inexact Rounded 1395 powx3632 power 0.0000657924467388 -89.14497293588313 -> 6.145878266688521E+372 Inexact Rounded 1396 powx3633 power 11.35071250339147 -323.3705865614542 -> 6.863626248766775E-342 Inexact Rounded 1397 powx3634 power 23.88024718470895 -277.7117513329510 -> 2.006441422612815E-383 Inexact Rounded 1398 powx3635 power 0.0000009111939914 -58.51782946929182 -> 2.954352883996773E+353 Inexact Rounded 1399 powx3636 power 0.0000878179048782 -75.81060420238669 -> 3.306878455207585E+307 Inexact Rounded 1400 powx3637 power 07.39190564273779 -287.5047307244636 -> 1.692080354659805E-250 Inexact Rounded 1401 powx3638 power 0.0000298310819799 -1.844740377759355 -> 222874718.7238888 Inexact Rounded 1402 powx3639 power 0.0000006412929384 -28.24850078229290 -> 8.737164230666529E+174 Inexact Rounded 1403 powx3640 power 0.0000010202965998 -47.17573701956498 -> 4.392845306049341E+282 Inexact Rounded 1404 1405 -- P=7, within 0-9 -- negative arg2 1406 Precision: 7 1407 powx3501 power 0.326324 -71.96509 -> 1.000673E+35 Inexact Rounded 1408 powx3502 power 0.0017635 -0.7186967 -> 95.28419 Inexact Rounded 1409 powx3503 power 8.564155 -253.0899 -> 8.850512E-237 Inexact Rounded 1410 powx3504 power 8.987272 -2.155789 -> 0.008793859 Inexact Rounded 1411 powx3505 power 9.604856 -139.9630 -> 3.073492E-138 Inexact Rounded 1412 powx3506 power 0.8472919 -2539.085 -> 5.372686E+182 Inexact Rounded 1413 powx3507 power 5.312329 -60.32965 -> 1.753121E-44 Inexact Rounded 1414 powx3508 power 0.0338294 -100.5440 -> 7.423939E+147 Inexact Rounded 1415 powx3509 power 0.0017777 -130.8583 -> 7.565629E+359 Inexact Rounded 1416 powx3510 power 8.016154 -405.5689 -> 2.395977E-367 Inexact Rounded 1417 powx3511 power 5.016570 -327.8906 -> 2.203784E-230 Inexact Rounded 1418 powx3512 power 0.8161743 -744.5276 -> 4.786899E+65 Inexact Rounded 1419 powx3513 power 0.0666343 -164.7320 -> 5.951240E+193 Inexact Rounded 1420 powx3514 power 0.0803966 -202.2666 -> 2.715512E+221 Inexact Rounded 1421 powx3515 power 0.0014752 -12.55547 -> 3.518905E+35 Inexact Rounded 1422 powx3516 power 9.737565 -14.69615 -> 2.975672E-15 Inexact Rounded 1423 powx3517 power 0.6634172 -152.7308 -> 1.654458E+27 Inexact Rounded 1424 powx3518 power 0.0009337 -33.32939 -> 9.575039E+100 Inexact Rounded 1425 powx3519 power 8.679922 -224.4194 -> 2.392446E-211 Inexact Rounded 1426 powx3520 power 7.390494 -161.9483 -> 2.088375E-141 Inexact Rounded 1427 powx3521 power 0.4631489 -417.1673 -> 2.821106E+139 Inexact Rounded 1428 powx3522 power 0.0095471 -7.677458 -> 3.231855E+15 Inexact Rounded 1429 powx3523 power 6.566339 -176.1867 -> 9.965633E-145 Inexact Rounded 1430 powx3524 power 2.696128 -26.15501 -> 5.419731E-12 Inexact Rounded 1431 powx3525 power 0.4464366 -852.1893 -> 2.957725E+298 Inexact Rounded 1432 powx3526 power 0.4772006 -921.4111 -> 1.118105E+296 Inexact Rounded 1433 powx3527 power 8.923696 -359.2211 -> 3.501573E-342 Inexact Rounded 1434 powx3528 power 0.0018008 -66.91252 -> 4.402718E+183 Inexact Rounded 1435 powx3529 power 0.0811964 -92.83278 -> 1.701111E+101 Inexact Rounded 1436 powx3530 power 0.0711219 -58.94347 -> 4.644148E+67 Inexact Rounded 1437 powx3531 power 7.958121 -50.66123 -> 2.311161E-46 Inexact Rounded 1438 powx3532 power 6.106466 -81.83610 -> 4.943285E-65 Inexact Rounded 1439 powx3533 power 4.557634 -129.5268 -> 4.737917E-86 Inexact Rounded 1440 powx3534 power 0.0027348 -9.180135 -> 3.383524E+23 Inexact Rounded 1441 powx3535 power 0.0083924 -46.24016 -> 9.996212E+95 Inexact Rounded 1442 powx3536 power 2.138523 -47.25897 -> 2.507009E-16 Inexact Rounded 1443 powx3537 power 1.626728 -1573.830 -> 2.668117E-333 Inexact Rounded 1444 powx3538 power 0.082615 -164.5842 -> 1.717882E+178 Inexact Rounded 1445 powx3539 power 7.636003 -363.6763 -> 8.366174E-322 Inexact Rounded 1446 powx3540 power 0.0021481 -138.0065 -> 1.562505E+368 Inexact Rounded 1447 1448 1449 -- Invalid operations due to restrictions 1450 -- [next two probably skipped by most test harnesses] 1451 precision: 100000000 1452 powx4001 power 1 1.1 -> NaN Invalid_context 1453 precision: 99999999 1454 powx4002 power 1 1.1 -> NaN Invalid_context 1455 1456 precision: 9 1457 maxExponent: 1000000 1458 minExponent: -999999 1459 powx4003 power 1 1.1 -> NaN Invalid_context 1460 maxExponent: 999999 1461 minExponent: -999999 1462 powx4004 power 1 1.1 -> 1.00000000 Inexact Rounded 1463 maxExponent: 999999 1464 minExponent: -1000000 1465 powx4005 power 1 1.1 -> NaN Invalid_context 1466 maxExponent: 999999 1467 minExponent: -999998 1468 powx4006 power 1 1.1 -> 1.00000000 Inexact Rounded 1469 1470 -- operand range violations 1471 powx4007 power 1 1.1E+999999 -> 1 1472 powx4008 power 1 1.1E+1000000 -> NaN Invalid_operation 1473 powx4009 power 1.1E+999999 1.1 -> Infinity Overflow Inexact Rounded 1474 powx4010 power 1.1E+1000000 1.1 -> NaN Invalid_operation 1475 powx4011 power 1 1.1E-1999997 -> 1.00000000 Inexact Rounded 1476 powx4012 power 1 1.1E-1999998 -> NaN Invalid_operation 1477 powx4013 power 1.1E-1999997 1.1 -> 0E-1000006 Underflow Inexact Rounded Clamped Subnormal 1478 powx4014 power 1.1E-1999998 1.1 -> NaN Invalid_operation 1479 1480 -- rounding modes -- power is sensitive 1481 precision: 7 1482 maxExponent: 99 1483 minExponent: -99 1484 1485 -- 0.7 ** 3.3 => 0.30819354053418943822 1486 -- 0.7 ** 3.4 => 0.29739477638272533854 1487 -- -1.2 ** 17 => -22.18611106740436992 1488 -- -1.3 ** 17 => -86.50415919381337933 1489 -- 0.5 ** 11 => 0.00048828125 1490 -- 3.15 ** 3 => 31.255875 1491 1492 rounding: up 1493 powx4100 power 0.7 3.3 -> 0.3081936 Inexact Rounded 1494 powx4101 power 0.7 3.4 -> 0.2973948 Inexact Rounded 1495 powx4102 power -1.2 17 -> -22.18612 Inexact Rounded 1496 powx4103 power -1.3 17 -> -86.50416 Inexact Rounded 1497 powx4104 power 17 81.27115 -> 9.999974E+99 Inexact Rounded 1498 powx4105 power 17 81.27116 -> Infinity Overflow Inexact Rounded 1499 1500 rounding: down 1501 powx4120 power 0.7 3.3 -> 0.3081935 Inexact Rounded 1502 powx4121 power 0.7 3.4 -> 0.2973947 Inexact Rounded 1503 powx4122 power -1.2 17 -> -22.18611 Inexact Rounded 1504 powx4123 power -1.3 17 -> -86.50415 Inexact Rounded 1505 powx4124 power 17 81.27115 -> 9.999973E+99 Inexact Rounded 1506 powx4125 power 17 81.27116 -> 9.999999E+99 Overflow Inexact Rounded 1507 1508 rounding: floor 1509 powx4140 power 0.7 3.3 -> 0.3081935 Inexact Rounded 1510 powx4141 power 0.7 3.4 -> 0.2973947 Inexact Rounded 1511 powx4142 power -1.2 17 -> -22.18612 Inexact Rounded 1512 powx4143 power -1.3 17 -> -86.50416 Inexact Rounded 1513 powx4144 power 17 81.27115 -> 9.999973E+99 Inexact Rounded 1514 powx4145 power 17 81.27116 -> 9.999999E+99 Overflow Inexact Rounded 1515 1516 rounding: ceiling 1517 powx4160 power 0.7 3.3 -> 0.3081936 Inexact Rounded 1518 powx4161 power 0.7 3.4 -> 0.2973948 Inexact Rounded 1519 powx4162 power -1.2 17 -> -22.18611 Inexact Rounded 1520 powx4163 power -1.3 17 -> -86.50415 Inexact Rounded 1521 powx4164 power 17 81.27115 -> 9.999974E+99 Inexact Rounded 1522 powx4165 power 17 81.27116 -> Infinity Overflow Inexact Rounded 1523 1524 rounding: half_up 1525 powx4180 power 0.7 3.3 -> 0.3081935 Inexact Rounded 1526 powx4181 power 0.7 3.4 -> 0.2973948 Inexact Rounded 1527 powx4182 power -1.2 17 -> -22.18611 Inexact Rounded 1528 powx4183 power -1.3 17 -> -86.50416 Inexact Rounded 1529 powx4184 power 0.5 11 -> 0.0004882813 Inexact Rounded 1530 powx4185 power 3.15 3 -> 31.25588 Inexact Rounded 1531 powx4186 power 17 81.27115 -> 9.999974E+99 Inexact Rounded 1532 powx4187 power 17 81.27116 -> Infinity Overflow Inexact Rounded 1533 1534 rounding: half_even 1535 powx4200 power 0.7 3.3 -> 0.3081935 Inexact Rounded 1536 powx4201 power 0.7 3.4 -> 0.2973948 Inexact Rounded 1537 powx4202 power -1.2 17 -> -22.18611 Inexact Rounded 1538 powx4203 power -1.3 17 -> -86.50416 Inexact Rounded 1539 powx4204 power 0.5 11 -> 0.0004882812 Inexact Rounded 1540 powx4205 power 3.15 3 -> 31.25588 Inexact Rounded 1541 powx4206 power 17 81.27115 -> 9.999974E+99 Inexact Rounded 1542 powx4207 power 17 81.27116 -> Infinity Overflow Inexact Rounded 1543 1544 rounding: half_down 1545 powx4220 power 0.7 3.3 -> 0.3081935 Inexact Rounded 1546 powx4221 power 0.7 3.4 -> 0.2973948 Inexact Rounded 1547 powx4222 power -1.2 17 -> -22.18611 Inexact Rounded 1548 powx4223 power -1.3 17 -> -86.50416 Inexact Rounded 1549 powx4224 power 0.5 11 -> 0.0004882812 Inexact Rounded 1550 powx4225 power 3.15 3 -> 31.25587 Inexact Rounded 1551 powx4226 power -3.15 3 -> -31.25587 Inexact Rounded 1552 powx4227 power 17 81.27115 -> 9.999974E+99 Inexact Rounded 1553 powx4228 power 17 81.27116 -> Infinity Overflow Inexact Rounded 1554 1555 1556 -- more rounding tests as per Ilan Nehama's suggestions & analysis 1557 -- these are likely to show > 0.5 ulp error for very small powers 1558 precision: 7 1559 maxExponent: 96 1560 minExponent: -95 1561 1562 -- For x=nextfp(1)=1.00..001 (where the number of 0s is precision-2) 1563 -- power(x,y)=x when the rounding is up (e.g., toward_pos_inf or 1564 -- ceil) for any y in (0,1]. 1565 rounding: ceiling 1566 powx4301 power 1.000001 0 -> 1 1567 -- The next test should be skipped for decNumber 1568 powx4302 power 1.000001 1e-101 -> 1.000001 Inexact Rounded 1569 -- The next test should be skipped for decNumber 1570 powx4303 power 1.000001 1e-95 -> 1.000001 Inexact Rounded 1571 powx4304 power 1.000001 1e-10 -> 1.000001 Inexact Rounded 1572 powx4305 power 1.000001 0.1 -> 1.000001 Inexact Rounded 1573 powx4306 power 1.000001 0.1234567 -> 1.000001 Inexact Rounded 1574 powx4307 power 1.000001 0.7 -> 1.000001 Inexact Rounded 1575 powx4308 power 1.000001 0.9999999 -> 1.000001 Inexact Rounded 1576 powx4309 power 1.000001 1.000000 -> 1.000001 1577 -- power(x,y)=1 when the rounding is down (e.g. toward_zero or 1578 -- floor) for any y in [0,1). 1579 rounding: floor 1580 powx4321 power 1.000001 0 -> 1 1581 powx4322 power 1.000001 1e-101 -> 1.000000 Inexact Rounded 1582 powx4323 power 1.000001 1e-95 -> 1.000000 Inexact Rounded 1583 powx4324 power 1.000001 1e-10 -> 1.000000 Inexact Rounded 1584 powx4325 power 1.000001 0.1 -> 1.000000 Inexact Rounded 1585 powx4326 power 1.000001 0.1234567 -> 1.000000 Inexact Rounded 1586 powx4327 power 1.000001 0.7 -> 1.000000 Inexact Rounded 1587 powx4328 power 1.000001 0.9999999 -> 1.000000 Inexact Rounded 1588 powx4329 power 1.000001 1.000000 -> 1.000001 1589 1590 -- For x=prevfp(1)=0.99..99 (where the number of 9s is precision) 1591 -- power(x,y)=x when the rounding is down for any y in (0,1]. 1592 rounding: floor 1593 powx4341 power 0.9999999 0 -> 1 1594 -- The next test should be skipped for decNumber 1595 powx4342 power 0.9999999 1e-101 -> 0.9999999 Inexact Rounded 1596 -- The next test should be skipped for decNumber 1597 powx4343 power 0.9999999 1e-95 -> 0.9999999 Inexact Rounded 1598 powx4344 power 0.9999999 1e-10 -> 0.9999999 Inexact Rounded 1599 powx4345 power 0.9999999 0.1 -> 0.9999999 Inexact Rounded 1600 powx4346 power 0.9999999 0.1234567 -> 0.9999999 Inexact Rounded 1601 powx4347 power 0.9999999 0.7 -> 0.9999999 Inexact Rounded 1602 powx4348 power 0.9999999 0.9999999 -> 0.9999999 Inexact Rounded 1603 powx4349 power 0.9999999 1.000000 -> 0.9999999 1604 -- power(x,y)=1 when the rounding is up for any y in (0,1]. 1605 rounding: ceiling 1606 powx4361 power 0.9999999 0 -> 1 1607 powx4362 power 0.9999999 1e-101 -> 1.000000 Inexact Rounded 1608 powx4363 power 0.9999999 1e-95 -> 1.000000 Inexact Rounded 1609 powx4364 power 0.9999999 1e-10 -> 1.000000 Inexact Rounded 1610 powx4365 power 0.9999999 0.1 -> 1.000000 Inexact Rounded 1611 powx4366 power 0.9999999 0.1234567 -> 1.000000 Inexact Rounded 1612 powx4367 power 0.9999999 0.7 -> 1.000000 Inexact Rounded 1613 powx4368 power 0.9999999 0.9999999 -> 1.000000 Inexact Rounded 1614 powx4369 power 0.9999999 1.000000 -> 0.9999999 1615 1616 -- For x=nextfp(0) 1617 -- power(x,y)=0 when the rounding is down for any y larger than 1. 1618 rounding: floor 1619 powx4382 power 1e-101 0 -> 1 1620 powx4383 power 1e-101 0.9999999 -> 1E-101 Underflow Subnormal Inexact Rounded 1621 powx4384 power 1e-101 1.000000 -> 1E-101 Subnormal 1622 powx4385 power 1e-101 1.000001 -> 0E-101 Underflow Subnormal Inexact Rounded Clamped 1623 powx4386 power 1e-101 2.000000 -> 0E-101 Underflow Subnormal Inexact Rounded Clamped