[Python-checkins] python/nondist/sandbox/decimal/tests quantize.decTest,NONE,1.1 abs.decTest,1.2,1.3 add.decTest,1.2,1.3 base.decTest,1.2,1.3 clamp.decTest,1.2,1.3 compare.decTest,1.2,1.3 decimal64.decTest,1.2,1.3 divide.decTest,1.2,1.3 divideint.decTest,1.2,1.3 inexact.decTest,1.2,1.3 integer.decTest,1.2,1.3 max.decTest,1.2,1.3 min.decTest,1.2,1.3 minus.decTest,1.2,1.3 multiply.decTest,1.2,1.3 normalize.decTest,1.2,1.3 plus.decTest,1.2,1.3 power.decTest,1.2,1.3 randomBound32.decTest,1.2,1.3 randoms.decTest,1.2,1.3 remainder.decTest,1.2,1.3 remainderNear.decTest,1.2,1.3 rescale.decTest,1.2,1.3 rounding.decTest,1.2,1.3 squareroot.decTest,1.2,1.3 subtract.decTest,1.2,1.3 testall.decTest,1.2,1.3 trim.decTest,1.2,1.3
eprice@users.sourceforge.net
eprice@users.sourceforge.net
Wed, 02 Jul 2003 16:51:19 -0700
Update of /cvsroot/python/python/nondist/sandbox/decimal/tests
In directory sc8-pr-cvs1:/tmp/cvs-serv1247
Modified Files:
abs.decTest add.decTest base.decTest clamp.decTest
compare.decTest decimal64.decTest divide.decTest
divideint.decTest inexact.decTest integer.decTest max.decTest
min.decTest minus.decTest multiply.decTest normalize.decTest
plus.decTest power.decTest randomBound32.decTest
randoms.decTest remainder.decTest remainderNear.decTest
rescale.decTest rounding.decTest squareroot.decTest
subtract.decTest testall.decTest trim.decTest
Added Files:
quantize.decTest
Log Message:
Newest version of the test cases, including quantize.
--- NEW FILE: quantize.decTest ---
------------------------------------------------------------------------
-- quantize.decTest -- decimal quantize operation --
-- Copyright (c) IBM Corporation, 1981, 2003. All rights reserved. --
------------------------------------------------------------------------
-- Please see the document "General Decimal Arithmetic Testcases" --
-- at http://www2.hursley.ibm.com/decimal for the description of --
-- these testcases. --
-- --
-- These testcases are experimental ('beta' versions), and they --
-- may contain errors. They are offered on an as-is basis. In --
-- particular, achieving the same results as the tests here is not --
-- a guarantee that an implementation complies with any Standard --
-- or specification. The tests are not exhaustive. --
-- --
-- Please send comments, suggestions, and corrections to the author: --
-- Mike Cowlishaw, IBM Fellow --
-- IBM UK, PO Box 31, Birmingham Road, Warwick CV34 5JL, UK --
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
version: 2.26
-- Most of the tests here assume a "regular pattern", where the
-- sign and coefficient are +1.
extended: 1
precision: 9
rounding: half_up
maxExponent: 999
minexponent: -999
-- sanity checks
quax001 quantize 0 1e0 -> 0
quax002 quantize 1 1e0 -> 1
quax003 quantize 0.1 1e+2 -> 0E+2 Inexact Rounded
quax005 quantize 0.1 1e+1 -> 0E+1 Inexact Rounded
quax006 quantize 0.1 1e0 -> 0 Inexact Rounded
quax007 quantize 0.1 1e-1 -> 0.1
quax008 quantize 0.1 1e-2 -> 0.10
quax009 quantize 0.1 1e-3 -> 0.100
quax010 quantize 0.9 1e+2 -> 0E+2 Inexact Rounded
quax011 quantize 0.9 1e+1 -> 0E+1 Inexact Rounded
quax012 quantize 0.9 1e+0 -> 1 Inexact Rounded
quax013 quantize 0.9 1e-1 -> 0.9
quax014 quantize 0.9 1e-2 -> 0.90
quax015 quantize 0.9 1e-3 -> 0.900
-- negatives
quax021 quantize -0 1e0 -> -0
quax022 quantize -1 1e0 -> -1
quax023 quantize -0.1 1e+2 -> -0E+2 Inexact Rounded
quax025 quantize -0.1 1e+1 -> -0E+1 Inexact Rounded
quax026 quantize -0.1 1e0 -> -0 Inexact Rounded
quax027 quantize -0.1 1e-1 -> -0.1
quax028 quantize -0.1 1e-2 -> -0.10
quax029 quantize -0.1 1e-3 -> -0.100
quax030 quantize -0.9 1e+2 -> -0E+2 Inexact Rounded
quax031 quantize -0.9 1e+1 -> -0E+1 Inexact Rounded
quax032 quantize -0.9 1e+0 -> -1 Inexact Rounded
quax033 quantize -0.9 1e-1 -> -0.9
quax034 quantize -0.9 1e-2 -> -0.90
quax035 quantize -0.9 1e-3 -> -0.900
quax036 quantize -0.5 1e+2 -> -0E+2 Inexact Rounded
quax037 quantize -0.5 1e+1 -> -0E+1 Inexact Rounded
quax038 quantize -0.5 1e+0 -> -1 Inexact Rounded
quax039 quantize -0.5 1e-1 -> -0.5
quax040 quantize -0.5 1e-2 -> -0.50
quax041 quantize -0.5 1e-3 -> -0.500
quax042 quantize -0.9 1e+2 -> -0E+2 Inexact Rounded
quax043 quantize -0.9 1e+1 -> -0E+1 Inexact Rounded
quax044 quantize -0.9 1e+0 -> -1 Inexact Rounded
quax045 quantize -0.9 1e-1 -> -0.9
quax046 quantize -0.9 1e-2 -> -0.90
quax047 quantize -0.9 1e-3 -> -0.900
-- examples from Specification
quax060 quantize 2.17 0.001 -> 2.170
quax061 quantize 2.17 0.01 -> 2.17
quax062 quantize 2.17 0.1 -> 2.2 Inexact Rounded
quax063 quantize 2.17 1e+0 -> 2 Inexact Rounded
quax064 quantize 2.17 1e+1 -> 0E+1 Inexact Rounded
quax065 quantize 2 Inf -> NaN Invalid_operation
quax066 quantize -0.1 1 -> -0 Inexact Rounded
quax067 quantize -0 1e+5 -> -0E+5
quax068 quantize +35236450.6 1e-2 -> NaN Invalid_operation
quax069 quantize -35236450.6 1e-2 -> NaN Invalid_operation
quax070 quantize 217 1e-1 -> 217.0
quax071 quantize 217 1e+0 -> 217
quax072 quantize 217 1e+1 -> 2.2E+2 Inexact Rounded
quax073 quantize 217 1e+2 -> 2E+2 Inexact Rounded
-- general tests ..
quax089 quantize 12 1e+4 -> 0E+4 Inexact Rounded
quax090 quantize 12 1e+3 -> 0E+3 Inexact Rounded
quax091 quantize 12 1e+2 -> 0E+2 Inexact Rounded
quax092 quantize 12 1e+1 -> 1E+1 Inexact Rounded
quax093 quantize 1.2345 1e-2 -> 1.23 Inexact Rounded
quax094 quantize 1.2355 1e-2 -> 1.24 Inexact Rounded
quax095 quantize 1.2345 1e-6 -> 1.234500
quax096 quantize 9.9999 1e-2 -> 10.00 Inexact Rounded
quax097 quantize 0.0001 1e-2 -> 0.00 Inexact Rounded
quax098 quantize 0.001 1e-2 -> 0.00 Inexact Rounded
quax099 quantize 0.009 1e-2 -> 0.01 Inexact Rounded
quax100 quantize 92 1e+2 -> 1E+2 Inexact Rounded
quax101 quantize -1 1e0 -> -1
quax102 quantize -1 1e-1 -> -1.0
quax103 quantize -1 1e-2 -> -1.00
quax104 quantize 0 1e0 -> 0
quax105 quantize 0 1e-1 -> 0.0
quax106 quantize 0 1e-2 -> 0.00
quax107 quantize 0.00 1e0 -> 0
quax108 quantize 0 1e+1 -> 0E+1
quax109 quantize 0 1e+2 -> 0E+2
quax110 quantize +1 1e0 -> 1
quax111 quantize +1 1e-1 -> 1.0
quax112 quantize +1 1e-2 -> 1.00
quax120 quantize 1.04 1e-3 -> 1.040
quax121 quantize 1.04 1e-2 -> 1.04
quax122 quantize 1.04 1e-1 -> 1.0 Inexact Rounded
quax123 quantize 1.04 1e0 -> 1 Inexact Rounded
quax124 quantize 1.05 1e-3 -> 1.050
quax125 quantize 1.05 1e-2 -> 1.05
quax126 quantize 1.05 1e-1 -> 1.1 Inexact Rounded
quax127 quantize 1.05 1e0 -> 1 Inexact Rounded
quax128 quantize 1.05 1e-3 -> 1.050
quax129 quantize 1.05 1e-2 -> 1.05
quax130 quantize 1.05 1e-1 -> 1.1 Inexact Rounded
quax131 quantize 1.05 1e0 -> 1 Inexact Rounded
quax132 quantize 1.06 1e-3 -> 1.060
quax133 quantize 1.06 1e-2 -> 1.06
quax134 quantize 1.06 1e-1 -> 1.1 Inexact Rounded
quax135 quantize 1.06 1e0 -> 1 Inexact Rounded
quax140 quantize -10 1e-2 -> -10.00
quax141 quantize +1 1e-2 -> 1.00
quax142 quantize +10 1e-2 -> 10.00
quax143 quantize 1E+10 1e-2 -> NaN Invalid_operation
quax144 quantize 1E-10 1e-2 -> 0.00 Inexact Rounded
quax145 quantize 1E-3 1e-2 -> 0.00 Inexact Rounded
quax146 quantize 1E-2 1e-2 -> 0.01
quax147 quantize 1E-1 1e-2 -> 0.10
quax148 quantize 0E-10 1e-2 -> 0.00
quax150 quantize 1.0600 1e-5 -> 1.06000
quax151 quantize 1.0600 1e-4 -> 1.0600
quax152 quantize 1.0600 1e-3 -> 1.060 Rounded
quax153 quantize 1.0600 1e-2 -> 1.06 Rounded
quax154 quantize 1.0600 1e-1 -> 1.1 Inexact Rounded
quax155 quantize 1.0600 1e0 -> 1 Inexact Rounded
-- base tests with non-1 coefficients
quax161 quantize 0 -9e0 -> 0
quax162 quantize 1 -7e0 -> 1
quax163 quantize 0.1 -1e+2 -> 0E+2 Inexact Rounded
quax165 quantize 0.1 0e+1 -> 0E+1 Inexact Rounded
quax166 quantize 0.1 2e0 -> 0 Inexact Rounded
quax167 quantize 0.1 3e-1 -> 0.1
quax168 quantize 0.1 44e-2 -> 0.10
quax169 quantize 0.1 555e-3 -> 0.100
quax170 quantize 0.9 6666e+2 -> 0E+2 Inexact Rounded
quax171 quantize 0.9 -777e+1 -> 0E+1 Inexact Rounded
quax172 quantize 0.9 -88e+0 -> 1 Inexact Rounded
quax173 quantize 0.9 -9e-1 -> 0.9
quax174 quantize 0.9 0e-2 -> 0.90
quax175 quantize 0.9 1.1e-3 -> 0.9000
-- negatives
quax181 quantize -0 1.1e0 -> -0.0
quax182 quantize -1 -1e0 -> -1
quax183 quantize -0.1 11e+2 -> -0E+2 Inexact Rounded
quax185 quantize -0.1 111e+1 -> -0E+1 Inexact Rounded
quax186 quantize -0.1 71e0 -> -0 Inexact Rounded
quax187 quantize -0.1 -91e-1 -> -0.1
quax188 quantize -0.1 -.1e-2 -> -0.100
quax189 quantize -0.1 -1e-3 -> -0.100
quax190 quantize -0.9 0e+2 -> -0E+2 Inexact Rounded
quax191 quantize -0.9 -0e+1 -> -0E+1 Inexact Rounded
quax192 quantize -0.9 -10e+0 -> -1 Inexact Rounded
quax193 quantize -0.9 100e-1 -> -0.9
quax194 quantize -0.9 999e-2 -> -0.90
-- +ve exponents ..
quax201 quantize -1 1e+0 -> -1
quax202 quantize -1 1e+1 -> -0E+1 Inexact Rounded
quax203 quantize -1 1e+2 -> -0E+2 Inexact Rounded
quax204 quantize 0 1e+0 -> 0
quax205 quantize 0 1e+1 -> 0E+1
quax206 quantize 0 1e+2 -> 0E+2
quax207 quantize +1 1e+0 -> 1
quax208 quantize +1 1e+1 -> 0E+1 Inexact Rounded
quax209 quantize +1 1e+2 -> 0E+2 Inexact Rounded
quax220 quantize 1.04 1e+3 -> 0E+3 Inexact Rounded
quax221 quantize 1.04 1e+2 -> 0E+2 Inexact Rounded
quax222 quantize 1.04 1e+1 -> 0E+1 Inexact Rounded
quax223 quantize 1.04 1e+0 -> 1 Inexact Rounded
quax224 quantize 1.05 1e+3 -> 0E+3 Inexact Rounded
quax225 quantize 1.05 1e+2 -> 0E+2 Inexact Rounded
quax226 quantize 1.05 1e+1 -> 0E+1 Inexact Rounded
quax227 quantize 1.05 1e+0 -> 1 Inexact Rounded
quax228 quantize 1.05 1e+3 -> 0E+3 Inexact Rounded
quax229 quantize 1.05 1e+2 -> 0E+2 Inexact Rounded
quax230 quantize 1.05 1e+1 -> 0E+1 Inexact Rounded
quax231 quantize 1.05 1e+0 -> 1 Inexact Rounded
quax232 quantize 1.06 1e+3 -> 0E+3 Inexact Rounded
quax233 quantize 1.06 1e+2 -> 0E+2 Inexact Rounded
quax234 quantize 1.06 1e+1 -> 0E+1 Inexact Rounded
quax235 quantize 1.06 1e+0 -> 1 Inexact Rounded
quax240 quantize -10 1e+1 -> -1E+1 Rounded
quax241 quantize +1 1e+1 -> 0E+1 Inexact Rounded
quax242 quantize +10 1e+1 -> 1E+1 Rounded
quax243 quantize 1E+1 1e+1 -> 1E+1 -- underneath this is E+1
quax244 quantize 1E+2 1e+1 -> 1.0E+2 -- underneath this is E+1
quax245 quantize 1E+3 1e+1 -> 1.00E+3 -- underneath this is E+1
quax246 quantize 1E+4 1e+1 -> 1.000E+4 -- underneath this is E+1
quax247 quantize 1E+5 1e+1 -> 1.0000E+5 -- underneath this is E+1
quax248 quantize 1E+6 1e+1 -> 1.00000E+6 -- underneath this is E+1
quax249 quantize 1E+7 1e+1 -> 1.000000E+7 -- underneath this is E+1
quax250 quantize 1E+8 1e+1 -> 1.0000000E+8 -- underneath this is E+1
quax251 quantize 1E+9 1e+1 -> 1.00000000E+9 -- underneath this is E+1
-- next one tries to add 9 zeros
quax252 quantize 1E+10 1e+1 -> NaN Invalid_operation
quax253 quantize 1E-10 1e+1 -> 0E+1 Inexact Rounded
quax254 quantize 1E-2 1e+1 -> 0E+1 Inexact Rounded
quax255 quantize 0E-10 1e+1 -> 0E+1
quax256 quantize -0E-10 1e+1 -> -0E+1
quax257 quantize -0E-1 1e+1 -> -0E+1
quax258 quantize -0 1e+1 -> -0E+1
quax259 quantize -0E+1 1e+1 -> -0E+1
quax260 quantize -10 1e+2 -> -0E+2 Inexact Rounded
quax261 quantize +1 1e+2 -> 0E+2 Inexact Rounded
quax262 quantize +10 1e+2 -> 0E+2 Inexact Rounded
quax263 quantize 1E+1 1e+2 -> 0E+2 Inexact Rounded
quax264 quantize 1E+2 1e+2 -> 1E+2
quax265 quantize 1E+3 1e+2 -> 1.0E+3
quax266 quantize 1E+4 1e+2 -> 1.00E+4
quax267 quantize 1E+5 1e+2 -> 1.000E+5
quax268 quantize 1E+6 1e+2 -> 1.0000E+6
quax269 quantize 1E+7 1e+2 -> 1.00000E+7
quax270 quantize 1E+8 1e+2 -> 1.000000E+8
quax271 quantize 1E+9 1e+2 -> 1.0000000E+9
quax272 quantize 1E+10 1e+2 -> 1.00000000E+10
quax273 quantize 1E-10 1e+2 -> 0E+2 Inexact Rounded
quax274 quantize 1E-2 1e+2 -> 0E+2 Inexact Rounded
quax275 quantize 0E-10 1e+2 -> 0E+2
quax280 quantize -10 1e+3 -> -0E+3 Inexact Rounded
quax281 quantize +1 1e+3 -> 0E+3 Inexact Rounded
quax282 quantize +10 1e+3 -> 0E+3 Inexact Rounded
quax283 quantize 1E+1 1e+3 -> 0E+3 Inexact Rounded
quax284 quantize 1E+2 1e+3 -> 0E+3 Inexact Rounded
quax285 quantize 1E+3 1e+3 -> 1E+3
quax286 quantize 1E+4 1e+3 -> 1.0E+4
quax287 quantize 1E+5 1e+3 -> 1.00E+5
quax288 quantize 1E+6 1e+3 -> 1.000E+6
quax289 quantize 1E+7 1e+3 -> 1.0000E+7
quax290 quantize 1E+8 1e+3 -> 1.00000E+8
quax291 quantize 1E+9 1e+3 -> 1.000000E+9
quax292 quantize 1E+10 1e+3 -> 1.0000000E+10
quax293 quantize 1E-10 1e+3 -> 0E+3 Inexact Rounded
quax294 quantize 1E-2 1e+3 -> 0E+3 Inexact Rounded
quax295 quantize 0E-10 1e+3 -> 0E+3
-- round up from below [sign wrong in JIT compiler once]
quax300 quantize 0.0078 1e-5 -> 0.00780
quax301 quantize 0.0078 1e-4 -> 0.0078
quax302 quantize 0.0078 1e-3 -> 0.008 Inexact Rounded
quax303 quantize 0.0078 1e-2 -> 0.01 Inexact Rounded
quax304 quantize 0.0078 1e-1 -> 0.0 Inexact Rounded
quax305 quantize 0.0078 1e0 -> 0 Inexact Rounded
quax306 quantize 0.0078 1e+1 -> 0E+1 Inexact Rounded
quax307 quantize 0.0078 1e+2 -> 0E+2 Inexact Rounded
quax310 quantize -0.0078 1e-5 -> -0.00780
quax311 quantize -0.0078 1e-4 -> -0.0078
quax312 quantize -0.0078 1e-3 -> -0.008 Inexact Rounded
quax313 quantize -0.0078 1e-2 -> -0.01 Inexact Rounded
quax314 quantize -0.0078 1e-1 -> -0.0 Inexact Rounded
quax315 quantize -0.0078 1e0 -> -0 Inexact Rounded
quax316 quantize -0.0078 1e+1 -> -0E+1 Inexact Rounded
quax317 quantize -0.0078 1e+2 -> -0E+2 Inexact Rounded
quax320 quantize 0.078 1e-5 -> 0.07800
quax321 quantize 0.078 1e-4 -> 0.0780
quax322 quantize 0.078 1e-3 -> 0.078
quax323 quantize 0.078 1e-2 -> 0.08 Inexact Rounded
quax324 quantize 0.078 1e-1 -> 0.1 Inexact Rounded
quax325 quantize 0.078 1e0 -> 0 Inexact Rounded
quax326 quantize 0.078 1e+1 -> 0E+1 Inexact Rounded
quax327 quantize 0.078 1e+2 -> 0E+2 Inexact Rounded
quax330 quantize -0.078 1e-5 -> -0.07800
quax331 quantize -0.078 1e-4 -> -0.0780
quax332 quantize -0.078 1e-3 -> -0.078
quax333 quantize -0.078 1e-2 -> -0.08 Inexact Rounded
quax334 quantize -0.078 1e-1 -> -0.1 Inexact Rounded
quax335 quantize -0.078 1e0 -> -0 Inexact Rounded
quax336 quantize -0.078 1e+1 -> -0E+1 Inexact Rounded
quax337 quantize -0.078 1e+2 -> -0E+2 Inexact Rounded
quax340 quantize 0.78 1e-5 -> 0.78000
quax341 quantize 0.78 1e-4 -> 0.7800
quax342 quantize 0.78 1e-3 -> 0.780
quax343 quantize 0.78 1e-2 -> 0.78
quax344 quantize 0.78 1e-1 -> 0.8 Inexact Rounded
quax345 quantize 0.78 1e0 -> 1 Inexact Rounded
quax346 quantize 0.78 1e+1 -> 0E+1 Inexact Rounded
quax347 quantize 0.78 1e+2 -> 0E+2 Inexact Rounded
quax350 quantize -0.78 1e-5 -> -0.78000
quax351 quantize -0.78 1e-4 -> -0.7800
quax352 quantize -0.78 1e-3 -> -0.780
quax353 quantize -0.78 1e-2 -> -0.78
quax354 quantize -0.78 1e-1 -> -0.8 Inexact Rounded
quax355 quantize -0.78 1e0 -> -1 Inexact Rounded
quax356 quantize -0.78 1e+1 -> -0E+1 Inexact Rounded
quax357 quantize -0.78 1e+2 -> -0E+2 Inexact Rounded
quax360 quantize 7.8 1e-5 -> 7.80000
quax361 quantize 7.8 1e-4 -> 7.8000
quax362 quantize 7.8 1e-3 -> 7.800
quax363 quantize 7.8 1e-2 -> 7.80
quax364 quantize 7.8 1e-1 -> 7.8
quax365 quantize 7.8 1e0 -> 8 Inexact Rounded
quax366 quantize 7.8 1e+1 -> 1E+1 Inexact Rounded
quax367 quantize 7.8 1e+2 -> 0E+2 Inexact Rounded
quax368 quantize 7.8 1e+3 -> 0E+3 Inexact Rounded
quax370 quantize -7.8 1e-5 -> -7.80000
quax371 quantize -7.8 1e-4 -> -7.8000
quax372 quantize -7.8 1e-3 -> -7.800
quax373 quantize -7.8 1e-2 -> -7.80
quax374 quantize -7.8 1e-1 -> -7.8
quax375 quantize -7.8 1e0 -> -8 Inexact Rounded
quax376 quantize -7.8 1e+1 -> -1E+1 Inexact Rounded
quax377 quantize -7.8 1e+2 -> -0E+2 Inexact Rounded
quax378 quantize -7.8 1e+3 -> -0E+3 Inexact Rounded
-- some individuals
precision: 9
quax380 quantize 352364.506 1e-2 -> 352364.51 Inexact Rounded
quax381 quantize 3523645.06 1e-2 -> 3523645.06
quax382 quantize 35236450.6 1e-2 -> NaN Invalid_operation
quax383 quantize 352364506 1e-2 -> NaN Invalid_operation
quax384 quantize -352364.506 1e-2 -> -352364.51 Inexact Rounded
quax385 quantize -3523645.06 1e-2 -> -3523645.06
quax386 quantize -35236450.6 1e-2 -> NaN Invalid_operation
quax387 quantize -352364506 1e-2 -> NaN Invalid_operation
rounding: down
quax389 quantize 35236450.6 1e-2 -> NaN Invalid_operation
-- ? should that one instead have been:
-- quax389 quantize 35236450.6 1e-2 -> NaN Invalid_operation
rounding: half_up
-- and a few more from e-mail discussions
precision: 7
quax391 quantize 12.34567 1e-3 -> 12.346 Inexact Rounded
quax392 quantize 123.4567 1e-3 -> 123.457 Inexact Rounded
quax393 quantize 1234.567 1e-3 -> 1234.567
quax394 quantize 12345.67 1e-3 -> NaN Invalid_operation
quax395 quantize 123456.7 1e-3 -> NaN Invalid_operation
quax396 quantize 1234567. 1e-3 -> NaN Invalid_operation
-- some 9999 round-up cases
precision: 9
quax400 quantize 9.999 1e-5 -> 9.99900
quax401 quantize 9.999 1e-4 -> 9.9990
quax402 quantize 9.999 1e-3 -> 9.999
quax403 quantize 9.999 1e-2 -> 10.00 Inexact Rounded
quax404 quantize 9.999 1e-1 -> 10.0 Inexact Rounded
quax405 quantize 9.999 1e0 -> 10 Inexact Rounded
quax406 quantize 9.999 1e1 -> 1E+1 Inexact Rounded
quax407 quantize 9.999 1e2 -> 0E+2 Inexact Rounded
quax410 quantize 0.999 1e-5 -> 0.99900
quax411 quantize 0.999 1e-4 -> 0.9990
quax412 quantize 0.999 1e-3 -> 0.999
quax413 quantize 0.999 1e-2 -> 1.00 Inexact Rounded
quax414 quantize 0.999 1e-1 -> 1.0 Inexact Rounded
quax415 quantize 0.999 1e0 -> 1 Inexact Rounded
quax416 quantize 0.999 1e1 -> 0E+1 Inexact Rounded
quax420 quantize 0.0999 1e-5 -> 0.09990
quax421 quantize 0.0999 1e-4 -> 0.0999
quax422 quantize 0.0999 1e-3 -> 0.100 Inexact Rounded
quax423 quantize 0.0999 1e-2 -> 0.10 Inexact Rounded
quax424 quantize 0.0999 1e-1 -> 0.1 Inexact Rounded
quax425 quantize 0.0999 1e0 -> 0 Inexact Rounded
quax426 quantize 0.0999 1e1 -> 0E+1 Inexact Rounded
quax430 quantize 0.00999 1e-5 -> 0.00999
quax431 quantize 0.00999 1e-4 -> 0.0100 Inexact Rounded
quax432 quantize 0.00999 1e-3 -> 0.010 Inexact Rounded
quax433 quantize 0.00999 1e-2 -> 0.01 Inexact Rounded
quax434 quantize 0.00999 1e-1 -> 0.0 Inexact Rounded
quax435 quantize 0.00999 1e0 -> 0 Inexact Rounded
quax436 quantize 0.00999 1e1 -> 0E+1 Inexact Rounded
quax440 quantize 0.000999 1e-5 -> 0.00100 Inexact Rounded
quax441 quantize 0.000999 1e-4 -> 0.0010 Inexact Rounded
quax442 quantize 0.000999 1e-3 -> 0.001 Inexact Rounded
quax443 quantize 0.000999 1e-2 -> 0.00 Inexact Rounded
quax444 quantize 0.000999 1e-1 -> 0.0 Inexact Rounded
quax445 quantize 0.000999 1e0 -> 0 Inexact Rounded
quax446 quantize 0.000999 1e1 -> 0E+1 Inexact Rounded
precision: 8
quax449 quantize 9.999E-15 1e-23 -> NaN Invalid_operation
quax450 quantize 9.999E-15 1e-22 -> 9.9990000E-15
quax451 quantize 9.999E-15 1e-21 -> 9.999000E-15
quax452 quantize 9.999E-15 1e-20 -> 9.99900E-15
quax453 quantize 9.999E-15 1e-19 -> 9.9990E-15
quax454 quantize 9.999E-15 1e-18 -> 9.999E-15
quax455 quantize 9.999E-15 1e-17 -> 1.000E-14 Inexact Rounded
quax456 quantize 9.999E-15 1e-16 -> 1.00E-14 Inexact Rounded
quax457 quantize 9.999E-15 1e-15 -> 1.0E-14 Inexact Rounded
quax458 quantize 9.999E-15 1e-14 -> 1E-14 Inexact Rounded
quax459 quantize 9.999E-15 1e-13 -> 0E-13 Inexact Rounded
quax460 quantize 9.999E-15 1e-12 -> 0E-12 Inexact Rounded
quax461 quantize 9.999E-15 1e-11 -> 0E-11 Inexact Rounded
quax462 quantize 9.999E-15 1e-10 -> 0E-10 Inexact Rounded
quax463 quantize 9.999E-15 1e-9 -> 0E-9 Inexact Rounded
quax464 quantize 9.999E-15 1e-8 -> 0E-8 Inexact Rounded
quax465 quantize 9.999E-15 1e-7 -> 0E-7 Inexact Rounded
quax466 quantize 9.999E-15 1e-6 -> 0.000000 Inexact Rounded
quax467 quantize 9.999E-15 1e-5 -> 0.00000 Inexact Rounded
quax468 quantize 9.999E-15 1e-4 -> 0.0000 Inexact Rounded
quax469 quantize 9.999E-15 1e-3 -> 0.000 Inexact Rounded
quax470 quantize 9.999E-15 1e-2 -> 0.00 Inexact Rounded
quax471 quantize 9.999E-15 1e-1 -> 0.0 Inexact Rounded
quax472 quantize 9.999E-15 1e0 -> 0 Inexact Rounded
quax473 quantize 9.999E-15 1e1 -> 0E+1 Inexact Rounded
-- long operand checks [rhs checks removed]
maxexponent: 999
minexponent: -999
precision: 9
quax481 quantize 12345678000 1e+3 -> 1.2345678E+10 Rounded
quax482 quantize 1234567800 1e+1 -> 1.23456780E+9 Rounded
quax483 quantize 1234567890 1e+1 -> 1.23456789E+9 Rounded
quax484 quantize 1234567891 1e+1 -> 1.23456789E+9 Inexact Rounded
quax485 quantize 12345678901 1e+2 -> 1.23456789E+10 Inexact Rounded
quax486 quantize 1234567896 1e+1 -> 1.23456790E+9 Inexact Rounded
-- a potential double-round
quax487 quantize 1234.987643 1e-4 -> 1234.9876 Inexact Rounded
quax488 quantize 1234.987647 1e-4 -> 1234.9876 Inexact Rounded
precision: 15
quax491 quantize 12345678000 1e+3 -> 1.2345678E+10 Rounded
quax492 quantize 1234567800 1e+1 -> 1.23456780E+9 Rounded
quax493 quantize 1234567890 1e+1 -> 1.23456789E+9 Rounded
quax494 quantize 1234567891 1e+1 -> 1.23456789E+9 Inexact Rounded
quax495 quantize 12345678901 1e+2 -> 1.23456789E+10 Inexact Rounded
quax496 quantize 1234567896 1e+1 -> 1.23456790E+9 Inexact Rounded
quax497 quantize 1234.987643 1e-4 -> 1234.9876 Inexact Rounded
quax498 quantize 1234.987647 1e-4 -> 1234.9876 Inexact Rounded
-- Zeros
quax500 quantize 0 1e1 -> 0E+1
quax501 quantize 0 1e0 -> 0
quax502 quantize 0 1e-1 -> 0.0
quax503 quantize 0.0 1e-1 -> 0.0
quax504 quantize 0.0 1e0 -> 0
quax505 quantize 0.0 1e+1 -> 0E+1
quax506 quantize 0E+1 1e-1 -> 0.0
quax507 quantize 0E+1 1e0 -> 0
quax508 quantize 0E+1 1e+1 -> 0E+1
quax509 quantize -0 1e1 -> -0E+1
quax510 quantize -0 1e0 -> -0
quax511 quantize -0 1e-1 -> -0.0
quax512 quantize -0.0 1e-1 -> -0.0
quax513 quantize -0.0 1e0 -> -0
quax514 quantize -0.0 1e+1 -> -0E+1
quax515 quantize -0E+1 1e-1 -> -0.0
quax516 quantize -0E+1 1e0 -> -0
quax517 quantize -0E+1 1e+1 -> -0E+1
-- Suspicious RHS values
maxexponent: 999999999
minexponent: -999999999
precision: 15
quax520 quantize 1.234 1e999999000 -> 0E+999999000 Inexact Rounded
quax521 quantize 123.456 1e999999000 -> 0E+999999000 Inexact Rounded
quax522 quantize 1.234 1e999999999 -> 0E+999999999 Inexact Rounded
quax523 quantize 123.456 1e999999999 -> 0E+999999999 Inexact Rounded
quax524 quantize 123.456 1e1000000000 -> NaN Invalid_operation
quax525 quantize 123.456 1e12345678903 -> NaN Invalid_operation
-- next four are "won't fit" overflows
quax526 quantize 1.234 1e-999999000 -> NaN Invalid_operation
quax527 quantize 123.456 1e-999999000 -> NaN Invalid_operation
quax528 quantize 1.234 1e-999999999 -> NaN Invalid_operation
quax529 quantize 123.456 1e-999999999 -> NaN Invalid_operation
quax530 quantize 123.456 1e-1000000014 -> NaN Invalid_operation
quax531 quantize 123.456 1e-12345678903 -> NaN Invalid_operation
maxexponent: 999
minexponent: -999
precision: 15
quax532 quantize 1.234E+999 1e999 -> 1E+999 Inexact Rounded
quax533 quantize 1.234E+998 1e999 -> 0E+999 Inexact Rounded
quax534 quantize 1.234 1e999 -> 0E+999 Inexact Rounded
quax535 quantize 1.234 1e1000 -> NaN Invalid_operation
quax536 quantize 1.234 1e5000 -> NaN Invalid_operation
quax537 quantize 0 1e-999 -> 0E-999
-- next two are "won't fit" overflows
quax538 quantize 1.234 1e-999 -> NaN Invalid_operation
quax539 quantize 1.234 1e-1000 -> NaN Invalid_operation
quax540 quantize 1.234 1e-5000 -> NaN Invalid_operation
-- [more below]
-- check bounds (lhs maybe out of range for destination, etc.)
precision: 7
quax541 quantize 1E+999 1e+999 -> 1E+999
quax542 quantize 1E+1000 1e+999 -> NaN Invalid_operation
quax543 quantize 1E+999 1e+1000 -> NaN Invalid_operation
quax544 quantize 1E-999 1e-999 -> 1E-999
quax545 quantize 1E-1000 1e-999 -> 0E-999 Inexact Rounded
quax546 quantize 1E-999 1e-1000 -> 1.0E-999
quax547 quantize 1E-1005 1e-999 -> 0E-999 Inexact Rounded
quax548 quantize 1E-1006 1e-999 -> 0E-999 Inexact Rounded
quax549 quantize 1E-1007 1e-999 -> 0E-999 Inexact Rounded
quax550 quantize 1E-998 1e-1005 -> NaN Invalid_operation -- won't fit
quax551 quantize 1E-999 1e-1005 -> 1.000000E-999
quax552 quantize 1E-1000 1e-1005 -> 1.00000E-1000 Subnormal
quax553 quantize 1E-999 1e-1006 -> NaN Invalid_operation
quax554 quantize 1E-999 1e-1007 -> NaN Invalid_operation
-- related subnormal rounding
quax555 quantize 1.666666E-999 1e-1005 -> 1.666666E-999
quax556 quantize 1.666666E-1000 1e-1005 -> 1.66667E-1000 Underflow Subnormal Inexact Rounded
quax557 quantize 1.666666E-1001 1e-1005 -> 1.6667E-1001 Underflow Subnormal Inexact Rounded
quax558 quantize 1.666666E-1002 1e-1005 -> 1.667E-1002 Underflow Subnormal Inexact Rounded
quax559 quantize 1.666666E-1003 1e-1005 -> 1.67E-1003 Underflow Subnormal Inexact Rounded
quax560 quantize 1.666666E-1004 1e-1005 -> 1.7E-1004 Underflow Subnormal Inexact Rounded
quax561 quantize 1.666666E-1005 1e-1005 -> 2E-1005 Underflow Subnormal Inexact Rounded
quax562 quantize 1.666666E-1006 1e-1005 -> 0E-1005 Inexact Rounded
quax563 quantize 1.666666E-1007 1e-1005 -> 0E-1005 Inexact Rounded
-- Specials
quax580 quantize Inf -Inf -> NaN Invalid_operation
quax581 quantize Inf 1e-1000 -> NaN Invalid_operation
quax582 quantize Inf 1e-1 -> NaN Invalid_operation
quax583 quantize Inf 1e0 -> NaN Invalid_operation
quax584 quantize Inf 1e1 -> NaN Invalid_operation
quax585 quantize Inf 1e1000 -> NaN Invalid_operation
quax586 quantize Inf Inf -> NaN Invalid_operation
quax587 quantize -1000 Inf -> NaN Invalid_operation
quax588 quantize -Inf Inf -> NaN Invalid_operation
quax589 quantize -1 Inf -> NaN Invalid_operation
quax590 quantize 0 Inf -> NaN Invalid_operation
quax591 quantize 1 Inf -> NaN Invalid_operation
quax592 quantize 1000 Inf -> NaN Invalid_operation
quax593 quantize Inf Inf -> NaN Invalid_operation
quax594 quantize Inf 1e-0 -> NaN Invalid_operation
quax595 quantize -0 Inf -> NaN Invalid_operation
quax600 quantize -Inf -Inf -> NaN Invalid_operation
quax601 quantize -Inf 1e-1000 -> NaN Invalid_operation
quax602 quantize -Inf 1e-1 -> NaN Invalid_operation
quax603 quantize -Inf 1e0 -> NaN Invalid_operation
quax604 quantize -Inf 1e1 -> NaN Invalid_operation
quax605 quantize -Inf 1e1000 -> NaN Invalid_operation
quax606 quantize -Inf Inf -> NaN Invalid_operation
quax607 quantize -1000 Inf -> NaN Invalid_operation
quax608 quantize -Inf -Inf -> NaN Invalid_operation
quax609 quantize -1 -Inf -> NaN Invalid_operation
quax610 quantize 0 -Inf -> NaN Invalid_operation
quax611 quantize 1 -Inf -> NaN Invalid_operation
quax612 quantize 1000 -Inf -> NaN Invalid_operation
quax613 quantize Inf -Inf -> NaN Invalid_operation
quax614 quantize -Inf 1e-0 -> NaN Invalid_operation
quax615 quantize -0 -Inf -> NaN Invalid_operation
quax621 quantize NaN -Inf -> NaN Invalid_operation
quax622 quantize NaN 1e-1000 -> NaN
quax623 quantize NaN 1e-1 -> NaN
quax624 quantize NaN 1e0 -> NaN
quax625 quantize NaN 1e1 -> NaN
quax626 quantize NaN 1e1000 -> NaN
quax627 quantize NaN Inf -> NaN Invalid_operation
quax628 quantize NaN NaN -> NaN
quax629 quantize -Inf NaN -> NaN Invalid_operation
quax630 quantize -1000 NaN -> NaN
quax631 quantize -1 NaN -> NaN
quax632 quantize 0 NaN -> NaN
quax633 quantize 1 NaN -> NaN
quax634 quantize 1000 NaN -> NaN
quax635 quantize Inf NaN -> NaN Invalid_operation
quax636 quantize NaN 1e-0 -> NaN
quax637 quantize -0 NaN -> NaN
quax641 quantize sNaN -Inf -> NaN Invalid_operation
quax642 quantize sNaN 1e-1000 -> NaN Invalid_operation
quax643 quantize sNaN 1e-1 -> NaN Invalid_operation
quax644 quantize sNaN 1e0 -> NaN Invalid_operation
quax645 quantize sNaN 1e1 -> NaN Invalid_operation
quax646 quantize sNaN 1e1000 -> NaN Invalid_operation
quax647 quantize sNaN NaN -> NaN Invalid_operation
quax648 quantize sNaN sNaN -> NaN Invalid_operation
quax649 quantize NaN sNaN -> NaN Invalid_operation
quax650 quantize -Inf sNaN -> NaN Invalid_operation
quax651 quantize -1000 sNaN -> NaN Invalid_operation
quax652 quantize -1 sNaN -> NaN Invalid_operation
quax653 quantize 0 sNaN -> NaN Invalid_operation
quax654 quantize 1 sNaN -> NaN Invalid_operation
quax655 quantize 1000 sNaN -> NaN Invalid_operation
quax656 quantize Inf sNaN -> NaN Invalid_operation
quax657 quantize NaN sNaN -> NaN Invalid_operation
quax658 quantize sNaN 1e-0 -> NaN Invalid_operation
quax659 quantize -0 sNaN -> NaN Invalid_operation
-- subnormals and underflow
precision: 4
maxexponent: 999
minexponent: -999
quax710 quantize 1.00E-999 1e-999 -> 1E-999 Rounded
quax711 quantize 0.1E-999 2e-1000 -> 1E-1000 Subnormal
quax712 quantize 0.10E-999 3e-1000 -> 1E-1000 Subnormal Rounded
quax713 quantize 0.100E-999 4e-1000 -> 1E-1000 Subnormal Rounded
quax714 quantize 0.01E-999 5e-1001 -> 1E-1001 Subnormal
-- next is rounded to Emin
quax715 quantize 0.999E-999 1e-999 -> 1E-999 Inexact Rounded
quax716 quantize 0.099E-999 10e-1000 -> 1E-1000 Inexact Rounded Subnormal Underflow
quax717 quantize 0.009E-999 1e-1001 -> 1E-1001 Inexact Rounded Subnormal Underflow
quax718 quantize 0.001E-999 1e-1001 -> 0E-1001 Inexact Rounded
quax719 quantize 0.0009E-999 1e-1001 -> 0E-1001 Inexact Rounded
quax720 quantize 0.0001E-999 1e-1001 -> 0E-1001 Inexact Rounded
quax730 quantize -1.00E-999 1e-999 -> -1E-999 Rounded
quax731 quantize -0.1E-999 1e-999 -> -0E-999 Rounded Inexact
quax732 quantize -0.10E-999 1e-999 -> -0E-999 Rounded Inexact
quax733 quantize -0.100E-999 1e-999 -> -0E-999 Rounded Inexact
quax734 quantize -0.01E-999 1e-999 -> -0E-999 Inexact Rounded
-- next is rounded to Emin
quax735 quantize -0.999E-999 90e-999 -> -1E-999 Inexact Rounded
quax736 quantize -0.099E-999 -1e-999 -> -0E-999 Inexact Rounded
quax737 quantize -0.009E-999 -1e-999 -> -0E-999 Inexact Rounded
quax738 quantize -0.001E-999 -0e-999 -> -0E-999 Inexact Rounded
quax739 quantize -0.0001E-999 0e-999 -> -0E-999 Inexact Rounded
quax740 quantize -1.00E-999 1e-1000 -> -1.0E-999 Rounded
quax741 quantize -0.1E-999 1e-1000 -> -1E-1000 Subnormal
quax742 quantize -0.10E-999 1e-1000 -> -1E-1000 Subnormal Rounded
quax743 quantize -0.100E-999 1e-1000 -> -1E-1000 Subnormal Rounded
quax744 quantize -0.01E-999 1e-1000 -> -0E-1000 Inexact Rounded
-- next is rounded to Emin
quax745 quantize -0.999E-999 1e-1000 -> -1.0E-999 Inexact Rounded
quax746 quantize -0.099E-999 1e-1000 -> -1E-1000 Inexact Rounded Subnormal Underflow
quax747 quantize -0.009E-999 1e-1000 -> -0E-1000 Inexact Rounded
quax748 quantize -0.001E-999 1e-1000 -> -0E-1000 Inexact Rounded
quax749 quantize -0.0001E-999 1e-1000 -> -0E-1000 Inexact Rounded
quax750 quantize -1.00E-999 1e-1001 -> -1.00E-999
quax751 quantize -0.1E-999 1e-1001 -> -1.0E-1000 Subnormal
quax752 quantize -0.10E-999 1e-1001 -> -1.0E-1000 Subnormal
quax753 quantize -0.100E-999 1e-1001 -> -1.0E-1000 Subnormal Rounded
quax754 quantize -0.01E-999 1e-1001 -> -1E-1001 Subnormal
-- next is rounded to Emin
quax755 quantize -0.999E-999 1e-1001 -> -1.00E-999 Inexact Rounded
quax756 quantize -0.099E-999 1e-1001 -> -1.0E-1000 Inexact Rounded Subnormal Underflow
quax757 quantize -0.009E-999 1e-1001 -> -1E-1001 Inexact Rounded Subnormal Underflow
quax758 quantize -0.001E-999 1e-1001 -> -0E-1001 Inexact Rounded
quax759 quantize -0.0001E-999 1e-1001 -> -0E-1001 Inexact Rounded
quax760 quantize -1.00E-999 1e-1002 -> -1.000E-999
quax761 quantize -0.1E-999 1e-1002 -> -1.00E-1000 Subnormal
quax762 quantize -0.10E-999 1e-1002 -> -1.00E-1000 Subnormal
quax763 quantize -0.100E-999 1e-1002 -> -1.00E-1000 Subnormal
quax764 quantize -0.01E-999 1e-1002 -> -1.0E-1001 Subnormal
quax765 quantize -0.999E-999 1e-1002 -> -9.99E-1000 Subnormal
quax766 quantize -0.099E-999 1e-1002 -> -9.9E-1001 Subnormal
quax767 quantize -0.009E-999 1e-1002 -> -9E-1002 Subnormal
quax768 quantize -0.001E-999 1e-1002 -> -1E-1002 Subnormal
quax769 quantize -0.0001E-999 1e-1002 -> -0E-1002 Inexact Rounded
-- rhs must be no less than Etiny
quax770 quantize -1.00E-999 1e-1003 -> NaN Invalid_operation
quax771 quantize -0.1E-999 1e-1003 -> NaN Invalid_operation
quax772 quantize -0.10E-999 1e-1003 -> NaN Invalid_operation
quax773 quantize -0.100E-999 1e-1003 -> NaN Invalid_operation
quax774 quantize -0.01E-999 1e-1003 -> NaN Invalid_operation
quax775 quantize -0.999E-999 1e-1003 -> NaN Invalid_operation
quax776 quantize -0.099E-999 1e-1003 -> NaN Invalid_operation
quax777 quantize -0.009E-999 1e-1003 -> NaN Invalid_operation
quax778 quantize -0.001E-999 1e-1003 -> NaN Invalid_operation
quax779 quantize -0.0001E-999 1e-1003 -> NaN Invalid_operation
quax780 quantize -0.0001E-999 1e-1004 -> NaN Invalid_operation
precision: 9
maxExponent: 999999999
minexponent: -999999999
-- some extremes derived from Rescale testcases
quax801 quantize 0 1e1000000000 -> NaN Invalid_operation
quax802 quantize 0 1e-1000000000 -> 0E-1000000000
quax803 quantize 0 1e2000000000 -> NaN Invalid_operation
quax804 quantize 0 1e-2000000000 -> NaN Invalid_operation
quax805 quantize 0 1e3000000000 -> NaN Invalid_operation
quax806 quantize 0 1e-3000000000 -> NaN Invalid_operation
quax807 quantize 0 1e4000000000 -> NaN Invalid_operation
quax808 quantize 0 1e-4000000000 -> NaN Invalid_operation
quax809 quantize 0 1e5000000000 -> NaN Invalid_operation
quax810 quantize 0 1e-5000000000 -> NaN Invalid_operation
quax811 quantize 0 1e6000000000 -> NaN Invalid_operation
quax812 quantize 0 1e-6000000000 -> NaN Invalid_operation
quax813 quantize 0 1e7000000000 -> NaN Invalid_operation
quax814 quantize 0 1e-7000000000 -> NaN Invalid_operation
quax815 quantize 0 1e8000000000 -> NaN Invalid_operation
quax816 quantize 0 1e-8000000000 -> NaN Invalid_operation
quax817 quantize 0 1e9000000000 -> NaN Invalid_operation
quax818 quantize 0 1e-9000000000 -> NaN Invalid_operation
quax819 quantize 0 1e9999999999 -> NaN Invalid_operation
quax820 quantize 0 1e-9999999999 -> NaN Invalid_operation
quax821 quantize 0 1e10000000000 -> NaN Invalid_operation
quax822 quantize 0 1e-10000000000 -> NaN Invalid_operation
quax843 quantize 0 1e999999999 -> 0E+999999999
quax844 quantize 0 1e1000000000 -> NaN Invalid_operation
quax845 quantize 0 1e-999999999 -> 0E-999999999
quax846 quantize 0 1e-1000000000 -> 0E-1000000000
quax847 quantize 0 1e-1000000001 -> 0E-1000000001
quax848 quantize 0 1e-1000000002 -> 0E-1000000002
quax849 quantize 0 1e-1000000003 -> 0E-1000000003
quax850 quantize 0 1e-1000000004 -> 0E-1000000004
quax851 quantize 0 1e-1000000005 -> 0E-1000000005
quax852 quantize 0 1e-1000000006 -> 0E-1000000006
quax853 quantize 0 1e-1000000007 -> 0E-1000000007
quax854 quantize 0 1e-1000000008 -> NaN Invalid_operation
quax861 quantize 1 1e+2147483649 -> NaN Invalid_operation
quax862 quantize 1 1e+2147483648 -> NaN Invalid_operation
quax863 quantize 1 1e+2147483647 -> NaN Invalid_operation
quax864 quantize 1 1e-2147483647 -> NaN Invalid_operation
quax865 quantize 1 1e-2147483648 -> NaN Invalid_operation
quax866 quantize 1 1e-2147483649 -> NaN Invalid_operation
-- Null tests
quax900 quantize 10 # -> NaN Invalid_operation
quax901 quantize # 1e10 -> NaN Invalid_operation
Index: abs.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/abs.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** abs.decTest 27 May 2003 22:46:40 -0000 1.2
--- abs.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- This set of tests primarily tests the existence of the operator.
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- This set of tests primarily tests the existence of the operator.
Index: add.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/add.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** add.decTest 27 May 2003 22:46:40 -0000 1.2
--- add.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
precision: 9
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
precision: 9
Index: base.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/base.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** base.decTest 27 May 2003 22:46:40 -0000 1.2
--- base.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- This file tests base conversions from string to a decimal number
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- This file tests base conversions from string to a decimal number
***************
*** 1204,1212 ****
basx1012 toSci 1e-000000000001000000007 -> 1E-1000000007 Subnormal
-- check for double-rounded subnormals
precision: 5
maxexponent: 79
minexponent: -79
! basx1021 toSci 1.52444E-80 -> 1.524E-80 Inexact Rounded Subnormal Underflow
! basx1022 toSci 1.52445E-80 -> 1.524E-80 Inexact Rounded Subnormal Underflow
! basx1023 toSci 1.52446E-80 -> 1.524E-80 Inexact Rounded Subnormal Underflow
--- 1204,1231 ----
basx1012 toSci 1e-000000000001000000007 -> 1E-1000000007 Subnormal
+ -- Edge cases for int32 exponents...
+ basx1021 tosci 1e+2147483649 -> Infinity Overflow Inexact Rounded
+ basx1022 tosci 1e+2147483648 -> Infinity Overflow Inexact Rounded
+ basx1023 tosci 1e+2147483647 -> Infinity Overflow Inexact Rounded
+ basx1024 tosci 1e-2147483647 -> 0E-1000000014 Underflow Subnormal Inexact Rounded
+ basx1025 tosci 1e-2147483648 -> 0E-1000000014 Underflow Subnormal Inexact Rounded
+ basx1026 tosci 1e-2147483649 -> 0E-1000000014 Underflow Subnormal Inexact Rounded
+ -- same unbalanced
+ precision: 7
+ maxExponent: 96
+ minexponent: -95
+ basx1031 tosci 1e+2147483649 -> Infinity Overflow Inexact Rounded
+ basx1032 tosci 1e+2147483648 -> Infinity Overflow Inexact Rounded
+ basx1033 tosci 1e+2147483647 -> Infinity Overflow Inexact Rounded
+ basx1034 tosci 1e-2147483647 -> 0E-101 Underflow Subnormal Inexact Rounded
+ basx1035 tosci 1e-2147483648 -> 0E-101 Underflow Subnormal Inexact Rounded
+ basx1036 tosci 1e-2147483649 -> 0E-101 Underflow Subnormal Inexact Rounded
+
-- check for double-rounded subnormals
precision: 5
maxexponent: 79
minexponent: -79
! basx1041 toSci 1.52444E-80 -> 1.524E-80 Inexact Rounded Subnormal Underflow
! basx1042 toSci 1.52445E-80 -> 1.524E-80 Inexact Rounded Subnormal Underflow
! basx1043 toSci 1.52446E-80 -> 1.524E-80 Inexact Rounded Subnormal Underflow
!
Index: clamp.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/clamp.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** clamp.decTest 27 May 2003 22:46:40 -0000 1.2
--- clamp.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- This set of tests uses the same limits as the 8-byte concrete
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- This set of tests uses the same limits as the 8-byte concrete
Index: compare.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/compare.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** compare.decTest 27 May 2003 22:46:40 -0000 1.2
--- compare.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- Note that we cannot assume add/subtract tests cover paths adequately,
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- Note that we cannot assume add/subtract tests cover paths adequately,
Index: decimal64.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/decimal64.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** decimal64.decTest 27 May 2003 22:46:40 -0000 1.2
--- decimal64.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- This set of tests is for the eight-byte concrete representation.
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- This set of tests is for the eight-byte concrete representation.
Index: divide.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/divide.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** divide.decTest 27 May 2003 22:46:40 -0000 1.2
--- divide.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
Index: divideint.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/divideint.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** divideint.decTest 27 May 2003 22:46:40 -0000 1.2
--- divideint.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
Index: inexact.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/inexact.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** inexact.decTest 27 May 2003 22:46:40 -0000 1.2
--- inexact.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
Index: integer.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/integer.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** integer.decTest 27 May 2003 22:46:40 -0000 1.2
--- integer.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- This set of tests tests the extended specification 'round-to-integer'
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- This set of tests tests the extended specification 'round-to-integer'
Index: max.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/max.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** max.decTest 27 May 2003 22:46:40 -0000 1.2
--- max.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- we assume that base comparison is tested in compare.decTest, so
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- we assume that base comparison is tested in compare.decTest, so
Index: min.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/min.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** min.decTest 27 May 2003 22:46:40 -0000 1.2
--- min.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- we assume that base comparison is tested in compare.decTest, so
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- we assume that base comparison is tested in compare.decTest, so
Index: minus.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/minus.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** minus.decTest 27 May 2003 22:46:40 -0000 1.2
--- minus.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- This set of tests primarily tests the existence of the operator.
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- This set of tests primarily tests the existence of the operator.
Index: multiply.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/multiply.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** multiply.decTest 27 May 2003 22:46:40 -0000 1.2
--- multiply.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
Index: normalize.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/normalize.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** normalize.decTest 27 May 2003 22:46:40 -0000 1.2
--- normalize.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
Index: plus.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/plus.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** plus.decTest 27 May 2003 22:46:40 -0000 1.2
--- plus.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- This set of tests primarily tests the existence of the operator.
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- This set of tests primarily tests the existence of the operator.
Index: power.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/power.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** power.decTest 27 May 2003 22:46:40 -0000 1.2
--- power.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- This set of testcases tests raising numbers to an integer power only.
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- This set of testcases tests raising numbers to an integer power only.
Index: randomBound32.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/randomBound32.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** randomBound32.decTest 27 May 2003 22:46:40 -0000 1.2
--- randomBound32.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- These testcases test calculations at precisions 31, 32, and 33, to
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- These testcases test calculations at precisions 31, 32, and 33, to
Index: randoms.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/randoms.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** randoms.decTest 27 May 2003 22:46:40 -0000 1.2
--- randoms.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
Index: remainder.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/remainder.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** remainder.decTest 27 May 2003 22:46:40 -0000 1.2
--- remainder.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
Index: remainderNear.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/remainderNear.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** remainderNear.decTest 27 May 2003 22:46:40 -0000 1.2
--- remainderNear.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
Index: rescale.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/rescale.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** rescale.decTest 27 May 2003 22:46:40 -0000 1.2
--- rescale.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,24 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
!
! -- [obsolete] Quantize.decTest has the improved version
extended: 1
***************
*** 26,30 ****
minexponent: -999
! -- sanity checks (as base, above)
resx001 rescale 0 0 -> 0
--- 28,32 ----
minexponent: -999
! -- sanity checks
resx001 rescale 0 0 -> 0
***************
*** 450,507 ****
minexponent: -999999999
precision: 15
! resx521 rescale 1.234 999999E+3 -> 0E+999999000 Inexact Rounded
! resx522 rescale 123.456 999999E+3 -> 0E+999999000 Inexact Rounded
! resx523 rescale 1.234 999999999 -> 0E+999999999 Inexact Rounded
! resx524 rescale 123.456 999999999 -> 0E+999999999 Inexact Rounded
! resx525 rescale 123.456 1000000000 -> NaN Invalid_operation
! resx526 rescale 123.456 12345678903 -> NaN Invalid_operation
-- next four are "won't fit" overflows
! resx527 rescale 1.234 -999999E+3 -> NaN Invalid_operation
! resx528 rescale 123.456 -999999E+3 -> NaN Invalid_operation
! resx529 rescale 1.234 -999999999 -> NaN Invalid_operation
! resx530 rescale 123.456 -999999999 -> NaN Invalid_operation
! resx531 rescale 123.456 -1000000014 -> NaN Invalid_operation
! resx532 rescale 123.456 -12345678903 -> NaN Invalid_operation
maxexponent: 999
minexponent: -999
precision: 15
! resx540 rescale 1.234E+999 999 -> 1E+999 Inexact Rounded
! resx541 rescale 1.234E+998 999 -> 0E+999 Inexact Rounded
! resx542 rescale 1.234 999 -> 0E+999 Inexact Rounded
! resx543 rescale 1.234 1000 -> NaN Invalid_operation
! resx544 rescale 1.234 5000 -> NaN Invalid_operation
!
! resx545 rescale 0 -999 -> 0E-999
-- next two are "won't fit" overflows
! resx546 rescale 1.234 -999 -> NaN Invalid_operation
! resx547 rescale 1.234 -1000 -> NaN Invalid_operation
! resx548 rescale 1.234 -5000 -> NaN Invalid_operation
-- [more below]
-- fractional RHS, some good and some bad
precision: 9
! resx549 rescale 222 +2.0 -> 2E+2 Inexact Rounded
! resx550 rescale 222 +2.00000000 -> 2E+2 Inexact Rounded
! resx551 rescale 222 +2.00100000000 -> NaN Invalid_operation
! resx552 rescale 222 +2.000001 -> NaN Invalid_operation
! resx553 rescale 222 +2.000000001 -> NaN Invalid_operation
! resx554 rescale 222 +2.0000000001 -> NaN Invalid_operation
! resx555 rescale 222 +2.00000000001 -> NaN Invalid_operation
! resx556 rescale 222 +2.99999999999 -> NaN Invalid_operation
! resx557 rescale 222 -2.00000000 -> 222.00
! resx558 rescale 222 -2.00100000000 -> NaN Invalid_operation
! resx559 rescale 222 -2.0000001000 -> NaN Invalid_operation
! resx560 rescale 222 -2.00000000001 -> NaN Invalid_operation
! resx561 rescale 222 -2.99999999999 -> NaN Invalid_operation
!
-- Specials
resx580 rescale Inf -Inf -> NaN Invalid_operation
! resx581 rescale Inf -1000 -> NaN Invalid_operation
! resx582 rescale Inf -1 -> NaN Invalid_operation
! resx583 rescale Inf 0 -> NaN Invalid_operation
! resx584 rescale Inf 1 -> NaN Invalid_operation
! resx585 rescale Inf 1000 -> NaN Invalid_operation
resx586 rescale Inf Inf -> NaN Invalid_operation
resx587 rescale -1000 Inf -> NaN Invalid_operation
--- 452,534 ----
minexponent: -999999999
precision: 15
! resx520 rescale 1.234 999999E+3 -> 0E+999999000 Inexact Rounded
! resx521 rescale 123.456 999999E+3 -> 0E+999999000 Inexact Rounded
! resx522 rescale 1.234 999999999 -> 0E+999999999 Inexact Rounded
! resx523 rescale 123.456 999999999 -> 0E+999999999 Inexact Rounded
! resx524 rescale 123.456 1000000000 -> NaN Invalid_operation
! resx525 rescale 123.456 12345678903 -> NaN Invalid_operation
-- next four are "won't fit" overflows
! resx526 rescale 1.234 -999999E+3 -> NaN Invalid_operation
! resx527 rescale 123.456 -999999E+3 -> NaN Invalid_operation
! resx528 rescale 1.234 -999999999 -> NaN Invalid_operation
! resx529 rescale 123.456 -999999999 -> NaN Invalid_operation
! resx530 rescale 123.456 -1000000014 -> NaN Invalid_operation
! resx531 rescale 123.456 -12345678903 -> NaN Invalid_operation
maxexponent: 999
minexponent: -999
precision: 15
! resx532 rescale 1.234E+999 999 -> 1E+999 Inexact Rounded
! resx533 rescale 1.234E+998 999 -> 0E+999 Inexact Rounded
! resx534 rescale 1.234 999 -> 0E+999 Inexact Rounded
! resx535 rescale 1.234 1000 -> NaN Invalid_operation
! resx536 rescale 1.234 5000 -> NaN Invalid_operation
! resx537 rescale 0 -999 -> 0E-999
-- next two are "won't fit" overflows
! resx538 rescale 1.234 -999 -> NaN Invalid_operation
! resx539 rescale 1.234 -1000 -> NaN Invalid_operation
! resx540 rescale 1.234 -5000 -> NaN Invalid_operation
-- [more below]
+ -- check bounds (lhs maybe out of range for destination, etc.)
+ precision: 7
+ resx541 rescale 1E+999 +999 -> 1E+999
+ resx542 rescale 1E+1000 +999 -> NaN Invalid_operation
+ resx543 rescale 1E+999 +1000 -> NaN Invalid_operation
+ resx544 rescale 1E-999 -999 -> 1E-999
+ resx545 rescale 1E-1000 -999 -> 0E-999 Inexact Rounded
+ resx546 rescale 1E-999 -1000 -> 1.0E-999
+ resx547 rescale 1E-1005 -999 -> 0E-999 Inexact Rounded
+ resx548 rescale 1E-1006 -999 -> 0E-999 Inexact Rounded
+ resx549 rescale 1E-1007 -999 -> 0E-999 Inexact Rounded
+ resx550 rescale 1E-998 -1005 -> NaN Invalid_operation -- won't fit
+ resx551 rescale 1E-999 -1005 -> 1.000000E-999
+ resx552 rescale 1E-1000 -1005 -> 1.00000E-1000 Subnormal
+ resx553 rescale 1E-999 -1006 -> NaN Invalid_operation
+ resx554 rescale 1E-999 -1007 -> NaN Invalid_operation
+ -- related subnormal rounding
+ resx555 rescale 1.666666E-999 -1005 -> 1.666666E-999
+ resx556 rescale 1.666666E-1000 -1005 -> 1.66667E-1000 Underflow Subnormal Inexact Rounded
+ resx557 rescale 1.666666E-1001 -1005 -> 1.6667E-1001 Underflow Subnormal Inexact Rounded
+ resx558 rescale 1.666666E-1002 -1005 -> 1.667E-1002 Underflow Subnormal Inexact Rounded
+ resx559 rescale 1.666666E-1003 -1005 -> 1.67E-1003 Underflow Subnormal Inexact Rounded
+ resx560 rescale 1.666666E-1004 -1005 -> 1.7E-1004 Underflow Subnormal Inexact Rounded
+ resx561 rescale 1.666666E-1005 -1005 -> 2E-1005 Underflow Subnormal Inexact Rounded
+ resx562 rescale 1.666666E-1006 -1005 -> 0E-1005 Inexact Rounded
+ resx563 rescale 1.666666E-1007 -1005 -> 0E-1005 Inexact Rounded
+
-- fractional RHS, some good and some bad
precision: 9
! resx564 rescale 222 +2.0 -> 2E+2 Inexact Rounded
! resx565 rescale 222 +2.00000000 -> 2E+2 Inexact Rounded
! resx566 rescale 222 +2.00100000000 -> NaN Invalid_operation
! resx567 rescale 222 +2.000001 -> NaN Invalid_operation
! resx568 rescale 222 +2.000000001 -> NaN Invalid_operation
! resx569 rescale 222 +2.0000000001 -> NaN Invalid_operation
! resx570 rescale 222 +2.00000000001 -> NaN Invalid_operation
! resx571 rescale 222 +2.99999999999 -> NaN Invalid_operation
! resx572 rescale 222 -2.00000000 -> 222.00
! resx573 rescale 222 -2.00100000000 -> NaN Invalid_operation
! resx574 rescale 222 -2.0000001000 -> NaN Invalid_operation
! resx575 rescale 222 -2.00000000001 -> NaN Invalid_operation
! resx576 rescale 222 -2.99999999999 -> NaN Invalid_operation
-- Specials
resx580 rescale Inf -Inf -> NaN Invalid_operation
! resx581 rescale Inf -1000 -> NaN Invalid_operation
! resx582 rescale Inf -1 -> NaN Invalid_operation
! resx583 rescale Inf 0 -> NaN Invalid_operation
! resx584 rescale Inf 1 -> NaN Invalid_operation
! resx585 rescale Inf 1000 -> NaN Invalid_operation
resx586 rescale Inf Inf -> NaN Invalid_operation
resx587 rescale -1000 Inf -> NaN Invalid_operation
***************
*** 512,516 ****
resx592 rescale 1000 Inf -> NaN Invalid_operation
resx593 rescale Inf Inf -> NaN Invalid_operation
! resx594 rescale Inf -0 -> NaN Invalid_operation
resx595 rescale -0 Inf -> NaN Invalid_operation
--- 539,543 ----
resx592 rescale 1000 Inf -> NaN Invalid_operation
resx593 rescale Inf Inf -> NaN Invalid_operation
! resx594 rescale Inf -0 -> NaN Invalid_operation
resx595 rescale -0 Inf -> NaN Invalid_operation
Index: rounding.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/rounding.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** rounding.decTest 27 May 2003 22:46:40 -0000 1.2
--- rounding.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- These tests require that implementations take account of residues in
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- These tests require that implementations take account of residues in
Index: squareroot.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/squareroot.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** squareroot.decTest 27 May 2003 22:46:40 -0000 1.2
--- squareroot.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
***************
*** 27,55 ****
-- basics
! sqtx001 squareroot 1 -> 1
! sqtx002 squareroot -1 -> NaN Invalid_operation
! sqtx003 squareroot 1.00 -> 1.0
! sqtx004 squareroot -1.00 -> NaN Invalid_operation
! sqtx005 squareroot 0 -> 0
! sqtx006 squareroot 00.0 -> 0
! sqtx007 squareroot 0.00 -> 0.0
! sqtx008 squareroot 00.00 -> 0.0
! sqtx009 squareroot 00 -> 0
! sqtx010 squareroot -2 -> NaN Invalid_operation
! sqtx011 squareroot 2 -> 1.41421356 Inexact Rounded
! sqtx012 squareroot -2.00 -> NaN Invalid_operation
! sqtx013 squareroot 2.00 -> 1.41421356 Inexact Rounded
! sqtx014 squareroot -0 -> -0
! sqtx015 squareroot -0.00 -> -0.0
! sqtx016 squareroot -00.0 -> -0
! sqtx017 squareroot -0E+9 -> -0E+4
! sqtx018 squareroot -0E+10 -> -0E+5
! sqtx019 squareroot -0E+11 -> -0E+5
! sqtx020 squareroot -0E+12 -> -0E+6
! sqtx021 squareroot -00 -> -0
! sqtx022 squareroot 0E+5 -> 0E+2
! sqtx023 squareroot 4.0 -> 2
! sqtx024 squareroot 4.00 -> 2.0
sqtx030 squareroot +0.1 -> 0.316227766 Inexact Rounded
--- 27,59 ----
-- basics
! sqtx001 squareroot 1 -> 1
! sqtx002 squareroot -1 -> NaN Invalid_operation
! sqtx003 squareroot 1.00 -> 1.0
! sqtx004 squareroot -1.00 -> NaN Invalid_operation
! sqtx005 squareroot 0 -> 0
! sqtx006 squareroot 00.0 -> 0.0
! sqtx007 squareroot 0.00 -> 0.0
! sqtx008 squareroot 00.00 -> 0.0
! sqtx009 squareroot 00.000 -> 0.00
! sqtx010 squareroot 00.0000 -> 0.00
! sqtx011 squareroot 00 -> 0
! sqtx012 squareroot -2 -> NaN Invalid_operation
! sqtx013 squareroot 2 -> 1.41421356 Inexact Rounded
! sqtx014 squareroot -2.00 -> NaN Invalid_operation
! sqtx015 squareroot 2.00 -> 1.41421356 Inexact Rounded
! sqtx016 squareroot -0 -> -0
! sqtx017 squareroot -0.0 -> -0.0
! sqtx018 squareroot -00.00 -> -0.0
! sqtx019 squareroot -00.000 -> -0.00
! sqtx020 squareroot -0.0000 -> -0.00
! sqtx021 squareroot -0E+9 -> -0E+4
! sqtx022 squareroot -0E+10 -> -0E+5
! sqtx023 squareroot -0E+11 -> -0E+5
! sqtx024 squareroot -0E+12 -> -0E+6
! sqtx025 squareroot -00 -> -0
! sqtx026 squareroot 0E+5 -> 0E+2
! sqtx027 squareroot 4.0 -> 2.0
! sqtx028 squareroot 4.00 -> 2.0
sqtx030 squareroot +0.1 -> 0.316227766 Inexact Rounded
***************
*** 81,96 ****
sqtx056 squareroot -9.990 -> NaN Invalid_operation
! sqtx060 squareroot 10.0 -> 3.16227766 Inexact Rounded
! sqtx061 squareroot 10.00 -> 3.16227766 Inexact Rounded
! sqtx062 squareroot 100.0 -> 10
! sqtx063 squareroot 100.00 -> 10.0
! sqtx064 squareroot 1.1000E+3 -> 33.1662479 Inexact Rounded
! sqtx065 squareroot 1.10000E+3 -> 33.1662479 Inexact Rounded
! sqtx066 squareroot -10.0 -> NaN Invalid_operation
! sqtx067 squareroot -10.00 -> NaN Invalid_operation
! sqtx068 squareroot -100.0 -> NaN Invalid_operation
! sqtx069 squareroot -100.00 -> NaN Invalid_operation
! sqtx070 squareroot -1.1000E+3 -> NaN Invalid_operation
! sqtx071 squareroot -1.10000E+3 -> NaN Invalid_operation
-- famous squares
--- 85,106 ----
sqtx056 squareroot -9.990 -> NaN Invalid_operation
! sqtx060 squareroot 1 -> 1
! sqtx061 squareroot 1.0 -> 1.0
! sqtx062 squareroot 1.00 -> 1.0
! sqtx063 squareroot 10.0 -> 3.16227766 Inexact Rounded
! sqtx064 squareroot 10.0 -> 3.16227766 Inexact Rounded
! sqtx065 squareroot 10.0 -> 3.16227766 Inexact Rounded
! sqtx066 squareroot 10.00 -> 3.16227766 Inexact Rounded
! sqtx067 squareroot 100 -> 10
! sqtx068 squareroot 100.0 -> 10.0
! sqtx069 squareroot 100.00 -> 10.0
! sqtx070 squareroot 1.1000E+3 -> 33.1662479 Inexact Rounded
! sqtx071 squareroot 1.10000E+3 -> 33.1662479 Inexact Rounded
! sqtx072 squareroot -10.0 -> NaN Invalid_operation
! sqtx073 squareroot -10.00 -> NaN Invalid_operation
! sqtx074 squareroot -100.0 -> NaN Invalid_operation
! sqtx075 squareroot -100.00 -> NaN Invalid_operation
! sqtx076 squareroot -1.1000E+3 -> NaN Invalid_operation
! sqtx077 squareroot -1.10000E+3 -> NaN Invalid_operation
-- famous squares
***************
*** 284,291 ****
sqtx2272 squareroot 9E+3 -> 95 Inexact Rounded
sqtx2273 squareroot 0.10 -> 0.32 Inexact Rounded
! sqtx2274 squareroot 0.010 -> 0.1
sqtx2275 squareroot 10.0E-1 -> 1.0
sqtx2276 squareroot 10.00E-2 -> 0.32 Inexact Rounded
! sqtx2277 squareroot 10E-3 -> 0.1
sqtx2278 squareroot 10E+1 -> 10
sqtx2279 squareroot 10E+2 -> 32 Inexact Rounded
--- 294,301 ----
sqtx2272 squareroot 9E+3 -> 95 Inexact Rounded
sqtx2273 squareroot 0.10 -> 0.32 Inexact Rounded
! sqtx2274 squareroot 0.010 -> 0.10
sqtx2275 squareroot 10.0E-1 -> 1.0
sqtx2276 squareroot 10.00E-2 -> 0.32 Inexact Rounded
! sqtx2277 squareroot 10E-3 -> 0.10
sqtx2278 squareroot 10E+1 -> 10
sqtx2279 squareroot 10E+2 -> 32 Inexact Rounded
***************
*** 524,531 ****
sqtx2512 squareroot 39E+3 -> 2.0E+2 Inexact Rounded
sqtx2513 squareroot 0.40 -> 0.63 Inexact Rounded
! sqtx2514 squareroot 0.040 -> 0.2
sqtx2515 squareroot 40.0E-1 -> 2.0
sqtx2516 squareroot 40.00E-2 -> 0.63 Inexact Rounded
! sqtx2517 squareroot 40E-3 -> 0.2
sqtx2518 squareroot 40E+1 -> 20
sqtx2519 squareroot 40E+2 -> 63 Inexact Rounded
--- 534,541 ----
sqtx2512 squareroot 39E+3 -> 2.0E+2 Inexact Rounded
sqtx2513 squareroot 0.40 -> 0.63 Inexact Rounded
! sqtx2514 squareroot 0.040 -> 0.20
sqtx2515 squareroot 40.0E-1 -> 2.0
sqtx2516 squareroot 40.00E-2 -> 0.63 Inexact Rounded
! sqtx2517 squareroot 40E-3 -> 0.20
sqtx2518 squareroot 40E+1 -> 20
sqtx2519 squareroot 40E+2 -> 63 Inexact Rounded
***************
*** 924,931 ****
sqtx2912 squareroot 89E+3 -> 3.0E+2 Inexact Rounded
sqtx2913 squareroot 0.90 -> 0.95 Inexact Rounded
! sqtx2914 squareroot 0.090 -> 0.3
sqtx2915 squareroot 90.0E-1 -> 3.0
sqtx2916 squareroot 90.00E-2 -> 0.95 Inexact Rounded
! sqtx2917 squareroot 90E-3 -> 0.3
sqtx2918 squareroot 90E+1 -> 30
sqtx2919 squareroot 90E+2 -> 95 Inexact Rounded
--- 934,941 ----
sqtx2912 squareroot 89E+3 -> 3.0E+2 Inexact Rounded
sqtx2913 squareroot 0.90 -> 0.95 Inexact Rounded
! sqtx2914 squareroot 0.090 -> 0.30
sqtx2915 squareroot 90.0E-1 -> 3.0
sqtx2916 squareroot 90.00E-2 -> 0.95 Inexact Rounded
! sqtx2917 squareroot 90E-3 -> 0.30
sqtx2918 squareroot 90E+1 -> 30
sqtx2919 squareroot 90E+2 -> 95 Inexact Rounded
***************
*** 2910,2914 ****
precision: 9 -- Etiny=-17
sqtx800 squareroot 1E-17 -> 3.16227766E-9 Inexact Rounded
! sqtx801 squareroot 10E-17 -> 1E-8
precision: 10 -- Etiny=-18
sqtx802 squareroot 10E-18 -> 3.162277660E-9 Inexact Rounded
--- 2920,2924 ----
precision: 9 -- Etiny=-17
sqtx800 squareroot 1E-17 -> 3.16227766E-9 Inexact Rounded
! sqtx801 squareroot 10E-17 -> 1.0E-8
precision: 10 -- Etiny=-18
sqtx802 squareroot 10E-18 -> 3.162277660E-9 Inexact Rounded
***************
*** 2917,2921 ****
precision: 11 -- Etiny=-19
sqtx804 squareroot 1E-19 -> 3.162277660E-10 Underflow Subnormal Inexact Rounded
! sqtx805 squareroot 10E-19 -> 1E-9
precision: 12 -- Etiny=-20
sqtx806 squareroot 10E-20 -> 3.1622776602E-10 Underflow Subnormal Inexact Rounded
--- 2927,2931 ----
precision: 11 -- Etiny=-19
sqtx804 squareroot 1E-19 -> 3.162277660E-10 Underflow Subnormal Inexact Rounded
! sqtx805 squareroot 10E-19 -> 1.0E-9
precision: 12 -- Etiny=-20
sqtx806 squareroot 10E-20 -> 3.1622776602E-10 Underflow Subnormal Inexact Rounded
***************
*** 2924,2928 ****
precision: 13 -- Etiny=-21
sqtx808 squareroot 1E-21 -> 3.1622776602E-11 Underflow Subnormal Inexact Rounded
! sqtx809 squareroot 10E-21 -> 1E-10 Subnormal
precision: 14 -- Etiny=-22
sqtx810 squareroot 1E-21 -> 3.16227766017E-11 Underflow Subnormal Inexact Rounded
--- 2934,2938 ----
precision: 13 -- Etiny=-21
sqtx808 squareroot 1E-21 -> 3.1622776602E-11 Underflow Subnormal Inexact Rounded
! sqtx809 squareroot 10E-21 -> 1.0E-10 Subnormal
precision: 14 -- Etiny=-22
sqtx810 squareroot 1E-21 -> 3.16227766017E-11 Underflow Subnormal Inexact Rounded
Index: subtract.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/subtract.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** subtract.decTest 27 May 2003 22:46:40 -0000 1.2
--- subtract.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1
Index: testall.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/testall.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** testall.decTest 27 May 2003 22:46:40 -0000 1.2
--- testall.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
-- core tests (using Extended: 1) --------------------------------------
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
-- core tests (using Extended: 1) --------------------------------------
***************
*** 37,44 ****
dectest: plus
dectest: power
dectest: randoms
dectest: remainder
dectest: remaindernear
! dectest: rescale
dectest: rounding
dectest: squareroot
--- 37,45 ----
dectest: plus
dectest: power
+ dectest: quantize
dectest: randoms
dectest: remainder
dectest: remaindernear
! dectest: rescale -- [obsolete]
dectest: rounding
dectest: squareroot
Index: trim.decTest
===================================================================
RCS file: /cvsroot/python/python/nondist/sandbox/decimal/tests/trim.decTest,v
retrieving revision 1.2
retrieving revision 1.3
diff -C2 -d -r1.2 -r1.3
*** trim.decTest 27 May 2003 22:46:40 -0000 1.2
--- trim.decTest 2 Jul 2003 23:51:16 -0000 1.3
***************
*** 18,22 ****
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.23
extended: 1
--- 18,22 ----
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
! version: 2.26
extended: 1