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