]> git.proxmox.com Git - mirror_edk2.git/blame - AppPkg/Applications/Python/Python-2.7.2/Lib/test/decimaltestdata/quantize.decTest
EmbeddedPkg: Extend NvVarStoreFormattedLib LIBRARY_CLASS
[mirror_edk2.git] / AppPkg / Applications / Python / Python-2.7.2 / Lib / test / decimaltestdata / quantize.decTest
CommitLineData
4710c53d 1------------------------------------------------------------------------\r
2-- quantize.decTest -- decimal quantize operation --\r
3-- Copyright (c) IBM Corporation, 1981, 2008. All rights reserved. --\r
4------------------------------------------------------------------------\r
5-- Please see the document "General Decimal Arithmetic Testcases" --\r
6-- at http://www2.hursley.ibm.com/decimal for the description of --\r
7-- these testcases. --\r
8-- --\r
9-- These testcases are experimental ('beta' versions), and they --\r
10-- may contain errors. They are offered on an as-is basis. In --\r
11-- particular, achieving the same results as the tests here is not --\r
12-- a guarantee that an implementation complies with any Standard --\r
13-- or specification. The tests are not exhaustive. --\r
14-- --\r
15-- Please send comments, suggestions, and corrections to the author: --\r
16-- Mike Cowlishaw, IBM Fellow --\r
17-- IBM UK, PO Box 31, Birmingham Road, Warwick CV34 5JL, UK --\r
18-- mfc@uk.ibm.com --\r
19------------------------------------------------------------------------\r
20version: 2.59\r
21\r
22-- Most of the tests here assume a "regular pattern", where the\r
23-- sign and coefficient are +1.\r
24-- 2004.03.15 Underflow for quantize is suppressed\r
25-- 2005.06.08 More extensive tests for 'does not fit'\r
26\r
27extended: 1\r
28precision: 9\r
29rounding: half_up\r
30maxExponent: 999\r
31minexponent: -999\r
32\r
33-- sanity checks\r
34quax001 quantize 0 1e0 -> 0\r
35quax002 quantize 1 1e0 -> 1\r
36quax003 quantize 0.1 1e+2 -> 0E+2 Inexact Rounded\r
37quax005 quantize 0.1 1e+1 -> 0E+1 Inexact Rounded\r
38quax006 quantize 0.1 1e0 -> 0 Inexact Rounded\r
39quax007 quantize 0.1 1e-1 -> 0.1\r
40quax008 quantize 0.1 1e-2 -> 0.10\r
41quax009 quantize 0.1 1e-3 -> 0.100\r
42quax010 quantize 0.9 1e+2 -> 0E+2 Inexact Rounded\r
43quax011 quantize 0.9 1e+1 -> 0E+1 Inexact Rounded\r
44quax012 quantize 0.9 1e+0 -> 1 Inexact Rounded\r
45quax013 quantize 0.9 1e-1 -> 0.9\r
46quax014 quantize 0.9 1e-2 -> 0.90\r
47quax015 quantize 0.9 1e-3 -> 0.900\r
48-- negatives\r
49quax021 quantize -0 1e0 -> -0\r
50quax022 quantize -1 1e0 -> -1\r
51quax023 quantize -0.1 1e+2 -> -0E+2 Inexact Rounded\r
52quax025 quantize -0.1 1e+1 -> -0E+1 Inexact Rounded\r
53quax026 quantize -0.1 1e0 -> -0 Inexact Rounded\r
54quax027 quantize -0.1 1e-1 -> -0.1\r
55quax028 quantize -0.1 1e-2 -> -0.10\r
56quax029 quantize -0.1 1e-3 -> -0.100\r
57quax030 quantize -0.9 1e+2 -> -0E+2 Inexact Rounded\r
58quax031 quantize -0.9 1e+1 -> -0E+1 Inexact Rounded\r
59quax032 quantize -0.9 1e+0 -> -1 Inexact Rounded\r
60quax033 quantize -0.9 1e-1 -> -0.9\r
61quax034 quantize -0.9 1e-2 -> -0.90\r
62quax035 quantize -0.9 1e-3 -> -0.900\r
63quax036 quantize -0.5 1e+2 -> -0E+2 Inexact Rounded\r
64quax037 quantize -0.5 1e+1 -> -0E+1 Inexact Rounded\r
65quax038 quantize -0.5 1e+0 -> -1 Inexact Rounded\r
66quax039 quantize -0.5 1e-1 -> -0.5\r
67quax040 quantize -0.5 1e-2 -> -0.50\r
68quax041 quantize -0.5 1e-3 -> -0.500\r
69quax042 quantize -0.9 1e+2 -> -0E+2 Inexact Rounded\r
70quax043 quantize -0.9 1e+1 -> -0E+1 Inexact Rounded\r
71quax044 quantize -0.9 1e+0 -> -1 Inexact Rounded\r
72quax045 quantize -0.9 1e-1 -> -0.9\r
73quax046 quantize -0.9 1e-2 -> -0.90\r
74quax047 quantize -0.9 1e-3 -> -0.900\r
75\r
76-- examples from Specification\r
77quax060 quantize 2.17 0.001 -> 2.170\r
78quax061 quantize 2.17 0.01 -> 2.17\r
79quax062 quantize 2.17 0.1 -> 2.2 Inexact Rounded\r
80quax063 quantize 2.17 1e+0 -> 2 Inexact Rounded\r
81quax064 quantize 2.17 1e+1 -> 0E+1 Inexact Rounded\r
82quax065 quantize -Inf Inf -> -Infinity\r
83quax066 quantize 2 Inf -> NaN Invalid_operation\r
84quax067 quantize -0.1 1 -> -0 Inexact Rounded\r
85quax068 quantize -0 1e+5 -> -0E+5\r
86quax069 quantize +35236450.6 1e-2 -> NaN Invalid_operation\r
87quax070 quantize -35236450.6 1e-2 -> NaN Invalid_operation\r
88quax071 quantize 217 1e-1 -> 217.0\r
89quax072 quantize 217 1e+0 -> 217\r
90quax073 quantize 217 1e+1 -> 2.2E+2 Inexact Rounded\r
91quax074 quantize 217 1e+2 -> 2E+2 Inexact Rounded\r
92\r
93-- general tests ..\r
94quax089 quantize 12 1e+4 -> 0E+4 Inexact Rounded\r
95quax090 quantize 12 1e+3 -> 0E+3 Inexact Rounded\r
96quax091 quantize 12 1e+2 -> 0E+2 Inexact Rounded\r
97quax092 quantize 12 1e+1 -> 1E+1 Inexact Rounded\r
98quax093 quantize 1.2345 1e-2 -> 1.23 Inexact Rounded\r
99quax094 quantize 1.2355 1e-2 -> 1.24 Inexact Rounded\r
100quax095 quantize 1.2345 1e-6 -> 1.234500\r
101quax096 quantize 9.9999 1e-2 -> 10.00 Inexact Rounded\r
102quax097 quantize 0.0001 1e-2 -> 0.00 Inexact Rounded\r
103quax098 quantize 0.001 1e-2 -> 0.00 Inexact Rounded\r
104quax099 quantize 0.009 1e-2 -> 0.01 Inexact Rounded\r
105quax100 quantize 92 1e+2 -> 1E+2 Inexact Rounded\r
106\r
107quax101 quantize -1 1e0 -> -1\r
108quax102 quantize -1 1e-1 -> -1.0\r
109quax103 quantize -1 1e-2 -> -1.00\r
110quax104 quantize 0 1e0 -> 0\r
111quax105 quantize 0 1e-1 -> 0.0\r
112quax106 quantize 0 1e-2 -> 0.00\r
113quax107 quantize 0.00 1e0 -> 0\r
114quax108 quantize 0 1e+1 -> 0E+1\r
115quax109 quantize 0 1e+2 -> 0E+2\r
116quax110 quantize +1 1e0 -> 1\r
117quax111 quantize +1 1e-1 -> 1.0\r
118quax112 quantize +1 1e-2 -> 1.00\r
119\r
120quax120 quantize 1.04 1e-3 -> 1.040\r
121quax121 quantize 1.04 1e-2 -> 1.04\r
122quax122 quantize 1.04 1e-1 -> 1.0 Inexact Rounded\r
123quax123 quantize 1.04 1e0 -> 1 Inexact Rounded\r
124quax124 quantize 1.05 1e-3 -> 1.050\r
125quax125 quantize 1.05 1e-2 -> 1.05\r
126quax126 quantize 1.05 1e-1 -> 1.1 Inexact Rounded\r
127quax131 quantize 1.05 1e0 -> 1 Inexact Rounded\r
128quax132 quantize 1.06 1e-3 -> 1.060\r
129quax133 quantize 1.06 1e-2 -> 1.06\r
130quax134 quantize 1.06 1e-1 -> 1.1 Inexact Rounded\r
131quax135 quantize 1.06 1e0 -> 1 Inexact Rounded\r
132\r
133quax140 quantize -10 1e-2 -> -10.00\r
134quax141 quantize +1 1e-2 -> 1.00\r
135quax142 quantize +10 1e-2 -> 10.00\r
136quax143 quantize 1E+10 1e-2 -> NaN Invalid_operation\r
137quax144 quantize 1E-10 1e-2 -> 0.00 Inexact Rounded\r
138quax145 quantize 1E-3 1e-2 -> 0.00 Inexact Rounded\r
139quax146 quantize 1E-2 1e-2 -> 0.01\r
140quax147 quantize 1E-1 1e-2 -> 0.10\r
141quax148 quantize 0E-10 1e-2 -> 0.00\r
142\r
143quax150 quantize 1.0600 1e-5 -> 1.06000\r
144quax151 quantize 1.0600 1e-4 -> 1.0600\r
145quax152 quantize 1.0600 1e-3 -> 1.060 Rounded\r
146quax153 quantize 1.0600 1e-2 -> 1.06 Rounded\r
147quax154 quantize 1.0600 1e-1 -> 1.1 Inexact Rounded\r
148quax155 quantize 1.0600 1e0 -> 1 Inexact Rounded\r
149\r
150-- base tests with non-1 coefficients\r
151quax161 quantize 0 -9e0 -> 0\r
152quax162 quantize 1 -7e0 -> 1\r
153quax163 quantize 0.1 -1e+2 -> 0E+2 Inexact Rounded\r
154quax165 quantize 0.1 0e+1 -> 0E+1 Inexact Rounded\r
155quax166 quantize 0.1 2e0 -> 0 Inexact Rounded\r
156quax167 quantize 0.1 3e-1 -> 0.1\r
157quax168 quantize 0.1 44e-2 -> 0.10\r
158quax169 quantize 0.1 555e-3 -> 0.100\r
159quax170 quantize 0.9 6666e+2 -> 0E+2 Inexact Rounded\r
160quax171 quantize 0.9 -777e+1 -> 0E+1 Inexact Rounded\r
161quax172 quantize 0.9 -88e+0 -> 1 Inexact Rounded\r
162quax173 quantize 0.9 -9e-1 -> 0.9\r
163quax174 quantize 0.9 0e-2 -> 0.90\r
164quax175 quantize 0.9 1.1e-3 -> 0.9000\r
165-- negatives\r
166quax181 quantize -0 1.1e0 -> -0.0\r
167quax182 quantize -1 -1e0 -> -1\r
168quax183 quantize -0.1 11e+2 -> -0E+2 Inexact Rounded\r
169quax185 quantize -0.1 111e+1 -> -0E+1 Inexact Rounded\r
170quax186 quantize -0.1 71e0 -> -0 Inexact Rounded\r
171quax187 quantize -0.1 -91e-1 -> -0.1\r
172quax188 quantize -0.1 -.1e-2 -> -0.100\r
173quax189 quantize -0.1 -1e-3 -> -0.100\r
174quax190 quantize -0.9 0e+2 -> -0E+2 Inexact Rounded\r
175quax191 quantize -0.9 -0e+1 -> -0E+1 Inexact Rounded\r
176quax192 quantize -0.9 -10e+0 -> -1 Inexact Rounded\r
177quax193 quantize -0.9 100e-1 -> -0.9\r
178quax194 quantize -0.9 999e-2 -> -0.90\r
179\r
180-- +ve exponents ..\r
181quax201 quantize -1 1e+0 -> -1\r
182quax202 quantize -1 1e+1 -> -0E+1 Inexact Rounded\r
183quax203 quantize -1 1e+2 -> -0E+2 Inexact Rounded\r
184quax204 quantize 0 1e+0 -> 0\r
185quax205 quantize 0 1e+1 -> 0E+1\r
186quax206 quantize 0 1e+2 -> 0E+2\r
187quax207 quantize +1 1e+0 -> 1\r
188quax208 quantize +1 1e+1 -> 0E+1 Inexact Rounded\r
189quax209 quantize +1 1e+2 -> 0E+2 Inexact Rounded\r
190\r
191quax220 quantize 1.04 1e+3 -> 0E+3 Inexact Rounded\r
192quax221 quantize 1.04 1e+2 -> 0E+2 Inexact Rounded\r
193quax222 quantize 1.04 1e+1 -> 0E+1 Inexact Rounded\r
194quax223 quantize 1.04 1e+0 -> 1 Inexact Rounded\r
195quax224 quantize 1.05 1e+3 -> 0E+3 Inexact Rounded\r
196quax225 quantize 1.05 1e+2 -> 0E+2 Inexact Rounded\r
197quax226 quantize 1.05 1e+1 -> 0E+1 Inexact Rounded\r
198quax227 quantize 1.05 1e+0 -> 1 Inexact Rounded\r
199quax228 quantize 1.05 1e+3 -> 0E+3 Inexact Rounded\r
200quax229 quantize 1.05 1e+2 -> 0E+2 Inexact Rounded\r
201quax230 quantize 1.05 1e+1 -> 0E+1 Inexact Rounded\r
202quax231 quantize 1.05 1e+0 -> 1 Inexact Rounded\r
203quax232 quantize 1.06 1e+3 -> 0E+3 Inexact Rounded\r
204quax233 quantize 1.06 1e+2 -> 0E+2 Inexact Rounded\r
205quax234 quantize 1.06 1e+1 -> 0E+1 Inexact Rounded\r
206quax235 quantize 1.06 1e+0 -> 1 Inexact Rounded\r
207\r
208quax240 quantize -10 1e+1 -> -1E+1 Rounded\r
209quax241 quantize +1 1e+1 -> 0E+1 Inexact Rounded\r
210quax242 quantize +10 1e+1 -> 1E+1 Rounded\r
211quax243 quantize 1E+1 1e+1 -> 1E+1 -- underneath this is E+1\r
212quax244 quantize 1E+2 1e+1 -> 1.0E+2 -- underneath this is E+1\r
213quax245 quantize 1E+3 1e+1 -> 1.00E+3 -- underneath this is E+1\r
214quax246 quantize 1E+4 1e+1 -> 1.000E+4 -- underneath this is E+1\r
215quax247 quantize 1E+5 1e+1 -> 1.0000E+5 -- underneath this is E+1\r
216quax248 quantize 1E+6 1e+1 -> 1.00000E+6 -- underneath this is E+1\r
217quax249 quantize 1E+7 1e+1 -> 1.000000E+7 -- underneath this is E+1\r
218quax250 quantize 1E+8 1e+1 -> 1.0000000E+8 -- underneath this is E+1\r
219quax251 quantize 1E+9 1e+1 -> 1.00000000E+9 -- underneath this is E+1\r
220-- next one tries to add 9 zeros\r
221quax252 quantize 1E+10 1e+1 -> NaN Invalid_operation\r
222quax253 quantize 1E-10 1e+1 -> 0E+1 Inexact Rounded\r
223quax254 quantize 1E-2 1e+1 -> 0E+1 Inexact Rounded\r
224quax255 quantize 0E-10 1e+1 -> 0E+1\r
225quax256 quantize -0E-10 1e+1 -> -0E+1\r
226quax257 quantize -0E-1 1e+1 -> -0E+1\r
227quax258 quantize -0 1e+1 -> -0E+1\r
228quax259 quantize -0E+1 1e+1 -> -0E+1\r
229\r
230quax260 quantize -10 1e+2 -> -0E+2 Inexact Rounded\r
231quax261 quantize +1 1e+2 -> 0E+2 Inexact Rounded\r
232quax262 quantize +10 1e+2 -> 0E+2 Inexact Rounded\r
233quax263 quantize 1E+1 1e+2 -> 0E+2 Inexact Rounded\r
234quax264 quantize 1E+2 1e+2 -> 1E+2\r
235quax265 quantize 1E+3 1e+2 -> 1.0E+3\r
236quax266 quantize 1E+4 1e+2 -> 1.00E+4\r
237quax267 quantize 1E+5 1e+2 -> 1.000E+5\r
238quax268 quantize 1E+6 1e+2 -> 1.0000E+6\r
239quax269 quantize 1E+7 1e+2 -> 1.00000E+7\r
240quax270 quantize 1E+8 1e+2 -> 1.000000E+8\r
241quax271 quantize 1E+9 1e+2 -> 1.0000000E+9\r
242quax272 quantize 1E+10 1e+2 -> 1.00000000E+10\r
243quax273 quantize 1E-10 1e+2 -> 0E+2 Inexact Rounded\r
244quax274 quantize 1E-2 1e+2 -> 0E+2 Inexact Rounded\r
245quax275 quantize 0E-10 1e+2 -> 0E+2\r
246\r
247quax280 quantize -10 1e+3 -> -0E+3 Inexact Rounded\r
248quax281 quantize +1 1e+3 -> 0E+3 Inexact Rounded\r
249quax282 quantize +10 1e+3 -> 0E+3 Inexact Rounded\r
250quax283 quantize 1E+1 1e+3 -> 0E+3 Inexact Rounded\r
251quax284 quantize 1E+2 1e+3 -> 0E+3 Inexact Rounded\r
252quax285 quantize 1E+3 1e+3 -> 1E+3\r
253quax286 quantize 1E+4 1e+3 -> 1.0E+4\r
254quax287 quantize 1E+5 1e+3 -> 1.00E+5\r
255quax288 quantize 1E+6 1e+3 -> 1.000E+6\r
256quax289 quantize 1E+7 1e+3 -> 1.0000E+7\r
257quax290 quantize 1E+8 1e+3 -> 1.00000E+8\r
258quax291 quantize 1E+9 1e+3 -> 1.000000E+9\r
259quax292 quantize 1E+10 1e+3 -> 1.0000000E+10\r
260quax293 quantize 1E-10 1e+3 -> 0E+3 Inexact Rounded\r
261quax294 quantize 1E-2 1e+3 -> 0E+3 Inexact Rounded\r
262quax295 quantize 0E-10 1e+3 -> 0E+3\r
263\r
264-- round up from below [sign wrong in JIT compiler once]\r
265quax300 quantize 0.0078 1e-5 -> 0.00780\r
266quax301 quantize 0.0078 1e-4 -> 0.0078\r
267quax302 quantize 0.0078 1e-3 -> 0.008 Inexact Rounded\r
268quax303 quantize 0.0078 1e-2 -> 0.01 Inexact Rounded\r
269quax304 quantize 0.0078 1e-1 -> 0.0 Inexact Rounded\r
270quax305 quantize 0.0078 1e0 -> 0 Inexact Rounded\r
271quax306 quantize 0.0078 1e+1 -> 0E+1 Inexact Rounded\r
272quax307 quantize 0.0078 1e+2 -> 0E+2 Inexact Rounded\r
273\r
274quax310 quantize -0.0078 1e-5 -> -0.00780\r
275quax311 quantize -0.0078 1e-4 -> -0.0078\r
276quax312 quantize -0.0078 1e-3 -> -0.008 Inexact Rounded\r
277quax313 quantize -0.0078 1e-2 -> -0.01 Inexact Rounded\r
278quax314 quantize -0.0078 1e-1 -> -0.0 Inexact Rounded\r
279quax315 quantize -0.0078 1e0 -> -0 Inexact Rounded\r
280quax316 quantize -0.0078 1e+1 -> -0E+1 Inexact Rounded\r
281quax317 quantize -0.0078 1e+2 -> -0E+2 Inexact Rounded\r
282\r
283quax320 quantize 0.078 1e-5 -> 0.07800\r
284quax321 quantize 0.078 1e-4 -> 0.0780\r
285quax322 quantize 0.078 1e-3 -> 0.078\r
286quax323 quantize 0.078 1e-2 -> 0.08 Inexact Rounded\r
287quax324 quantize 0.078 1e-1 -> 0.1 Inexact Rounded\r
288quax325 quantize 0.078 1e0 -> 0 Inexact Rounded\r
289quax326 quantize 0.078 1e+1 -> 0E+1 Inexact Rounded\r
290quax327 quantize 0.078 1e+2 -> 0E+2 Inexact Rounded\r
291\r
292quax330 quantize -0.078 1e-5 -> -0.07800\r
293quax331 quantize -0.078 1e-4 -> -0.0780\r
294quax332 quantize -0.078 1e-3 -> -0.078\r
295quax333 quantize -0.078 1e-2 -> -0.08 Inexact Rounded\r
296quax334 quantize -0.078 1e-1 -> -0.1 Inexact Rounded\r
297quax335 quantize -0.078 1e0 -> -0 Inexact Rounded\r
298quax336 quantize -0.078 1e+1 -> -0E+1 Inexact Rounded\r
299quax337 quantize -0.078 1e+2 -> -0E+2 Inexact Rounded\r
300\r
301quax340 quantize 0.78 1e-5 -> 0.78000\r
302quax341 quantize 0.78 1e-4 -> 0.7800\r
303quax342 quantize 0.78 1e-3 -> 0.780\r
304quax343 quantize 0.78 1e-2 -> 0.78\r
305quax344 quantize 0.78 1e-1 -> 0.8 Inexact Rounded\r
306quax345 quantize 0.78 1e0 -> 1 Inexact Rounded\r
307quax346 quantize 0.78 1e+1 -> 0E+1 Inexact Rounded\r
308quax347 quantize 0.78 1e+2 -> 0E+2 Inexact Rounded\r
309\r
310quax350 quantize -0.78 1e-5 -> -0.78000\r
311quax351 quantize -0.78 1e-4 -> -0.7800\r
312quax352 quantize -0.78 1e-3 -> -0.780\r
313quax353 quantize -0.78 1e-2 -> -0.78\r
314quax354 quantize -0.78 1e-1 -> -0.8 Inexact Rounded\r
315quax355 quantize -0.78 1e0 -> -1 Inexact Rounded\r
316quax356 quantize -0.78 1e+1 -> -0E+1 Inexact Rounded\r
317quax357 quantize -0.78 1e+2 -> -0E+2 Inexact Rounded\r
318\r
319quax360 quantize 7.8 1e-5 -> 7.80000\r
320quax361 quantize 7.8 1e-4 -> 7.8000\r
321quax362 quantize 7.8 1e-3 -> 7.800\r
322quax363 quantize 7.8 1e-2 -> 7.80\r
323quax364 quantize 7.8 1e-1 -> 7.8\r
324quax365 quantize 7.8 1e0 -> 8 Inexact Rounded\r
325quax366 quantize 7.8 1e+1 -> 1E+1 Inexact Rounded\r
326quax367 quantize 7.8 1e+2 -> 0E+2 Inexact Rounded\r
327quax368 quantize 7.8 1e+3 -> 0E+3 Inexact Rounded\r
328\r
329quax370 quantize -7.8 1e-5 -> -7.80000\r
330quax371 quantize -7.8 1e-4 -> -7.8000\r
331quax372 quantize -7.8 1e-3 -> -7.800\r
332quax373 quantize -7.8 1e-2 -> -7.80\r
333quax374 quantize -7.8 1e-1 -> -7.8\r
334quax375 quantize -7.8 1e0 -> -8 Inexact Rounded\r
335quax376 quantize -7.8 1e+1 -> -1E+1 Inexact Rounded\r
336quax377 quantize -7.8 1e+2 -> -0E+2 Inexact Rounded\r
337quax378 quantize -7.8 1e+3 -> -0E+3 Inexact Rounded\r
338\r
339-- some individuals\r
340precision: 9\r
341quax380 quantize 352364.506 1e-2 -> 352364.51 Inexact Rounded\r
342quax381 quantize 3523645.06 1e-2 -> 3523645.06\r
343quax382 quantize 35236450.6 1e-2 -> NaN Invalid_operation\r
344quax383 quantize 352364506 1e-2 -> NaN Invalid_operation\r
345quax384 quantize -352364.506 1e-2 -> -352364.51 Inexact Rounded\r
346quax385 quantize -3523645.06 1e-2 -> -3523645.06\r
347quax386 quantize -35236450.6 1e-2 -> NaN Invalid_operation\r
348quax387 quantize -352364506 1e-2 -> NaN Invalid_operation\r
349\r
350rounding: down\r
351quax389 quantize 35236450.6 1e-2 -> NaN Invalid_operation\r
352-- ? should that one instead have been:\r
353-- quax389 quantize 35236450.6 1e-2 -> NaN Invalid_operation\r
354rounding: half_up\r
355\r
356-- and a few more from e-mail discussions\r
357precision: 7\r
358quax391 quantize 12.34567 1e-3 -> 12.346 Inexact Rounded\r
359quax392 quantize 123.4567 1e-3 -> 123.457 Inexact Rounded\r
360quax393 quantize 1234.567 1e-3 -> 1234.567\r
361quax394 quantize 12345.67 1e-3 -> NaN Invalid_operation\r
362quax395 quantize 123456.7 1e-3 -> NaN Invalid_operation\r
363quax396 quantize 1234567. 1e-3 -> NaN Invalid_operation\r
364\r
365-- some 9999 round-up cases\r
366precision: 9\r
367quax400 quantize 9.999 1e-5 -> 9.99900\r
368quax401 quantize 9.999 1e-4 -> 9.9990\r
369quax402 quantize 9.999 1e-3 -> 9.999\r
370quax403 quantize 9.999 1e-2 -> 10.00 Inexact Rounded\r
371quax404 quantize 9.999 1e-1 -> 10.0 Inexact Rounded\r
372quax405 quantize 9.999 1e0 -> 10 Inexact Rounded\r
373quax406 quantize 9.999 1e1 -> 1E+1 Inexact Rounded\r
374quax407 quantize 9.999 1e2 -> 0E+2 Inexact Rounded\r
375\r
376quax410 quantize 0.999 1e-5 -> 0.99900\r
377quax411 quantize 0.999 1e-4 -> 0.9990\r
378quax412 quantize 0.999 1e-3 -> 0.999\r
379quax413 quantize 0.999 1e-2 -> 1.00 Inexact Rounded\r
380quax414 quantize 0.999 1e-1 -> 1.0 Inexact Rounded\r
381quax415 quantize 0.999 1e0 -> 1 Inexact Rounded\r
382quax416 quantize 0.999 1e1 -> 0E+1 Inexact Rounded\r
383\r
384quax420 quantize 0.0999 1e-5 -> 0.09990\r
385quax421 quantize 0.0999 1e-4 -> 0.0999\r
386quax422 quantize 0.0999 1e-3 -> 0.100 Inexact Rounded\r
387quax423 quantize 0.0999 1e-2 -> 0.10 Inexact Rounded\r
388quax424 quantize 0.0999 1e-1 -> 0.1 Inexact Rounded\r
389quax425 quantize 0.0999 1e0 -> 0 Inexact Rounded\r
390quax426 quantize 0.0999 1e1 -> 0E+1 Inexact Rounded\r
391\r
392quax430 quantize 0.00999 1e-5 -> 0.00999\r
393quax431 quantize 0.00999 1e-4 -> 0.0100 Inexact Rounded\r
394quax432 quantize 0.00999 1e-3 -> 0.010 Inexact Rounded\r
395quax433 quantize 0.00999 1e-2 -> 0.01 Inexact Rounded\r
396quax434 quantize 0.00999 1e-1 -> 0.0 Inexact Rounded\r
397quax435 quantize 0.00999 1e0 -> 0 Inexact Rounded\r
398quax436 quantize 0.00999 1e1 -> 0E+1 Inexact Rounded\r
399\r
400quax440 quantize 0.000999 1e-5 -> 0.00100 Inexact Rounded\r
401quax441 quantize 0.000999 1e-4 -> 0.0010 Inexact Rounded\r
402quax442 quantize 0.000999 1e-3 -> 0.001 Inexact Rounded\r
403quax443 quantize 0.000999 1e-2 -> 0.00 Inexact Rounded\r
404quax444 quantize 0.000999 1e-1 -> 0.0 Inexact Rounded\r
405quax445 quantize 0.000999 1e0 -> 0 Inexact Rounded\r
406quax446 quantize 0.000999 1e1 -> 0E+1 Inexact Rounded\r
407\r
408precision: 8\r
409quax449 quantize 9.999E-15 1e-23 -> NaN Invalid_operation\r
410quax450 quantize 9.999E-15 1e-22 -> 9.9990000E-15\r
411quax451 quantize 9.999E-15 1e-21 -> 9.999000E-15\r
412quax452 quantize 9.999E-15 1e-20 -> 9.99900E-15\r
413quax453 quantize 9.999E-15 1e-19 -> 9.9990E-15\r
414quax454 quantize 9.999E-15 1e-18 -> 9.999E-15\r
415quax455 quantize 9.999E-15 1e-17 -> 1.000E-14 Inexact Rounded\r
416quax456 quantize 9.999E-15 1e-16 -> 1.00E-14 Inexact Rounded\r
417quax457 quantize 9.999E-15 1e-15 -> 1.0E-14 Inexact Rounded\r
418quax458 quantize 9.999E-15 1e-14 -> 1E-14 Inexact Rounded\r
419quax459 quantize 9.999E-15 1e-13 -> 0E-13 Inexact Rounded\r
420quax460 quantize 9.999E-15 1e-12 -> 0E-12 Inexact Rounded\r
421quax461 quantize 9.999E-15 1e-11 -> 0E-11 Inexact Rounded\r
422quax462 quantize 9.999E-15 1e-10 -> 0E-10 Inexact Rounded\r
423quax463 quantize 9.999E-15 1e-9 -> 0E-9 Inexact Rounded\r
424quax464 quantize 9.999E-15 1e-8 -> 0E-8 Inexact Rounded\r
425quax465 quantize 9.999E-15 1e-7 -> 0E-7 Inexact Rounded\r
426quax466 quantize 9.999E-15 1e-6 -> 0.000000 Inexact Rounded\r
427quax467 quantize 9.999E-15 1e-5 -> 0.00000 Inexact Rounded\r
428quax468 quantize 9.999E-15 1e-4 -> 0.0000 Inexact Rounded\r
429quax469 quantize 9.999E-15 1e-3 -> 0.000 Inexact Rounded\r
430quax470 quantize 9.999E-15 1e-2 -> 0.00 Inexact Rounded\r
431quax471 quantize 9.999E-15 1e-1 -> 0.0 Inexact Rounded\r
432quax472 quantize 9.999E-15 1e0 -> 0 Inexact Rounded\r
433quax473 quantize 9.999E-15 1e1 -> 0E+1 Inexact Rounded\r
434\r
435precision: 7\r
436quax900 quantize 9.999E-15 1e-22 -> NaN Invalid_operation\r
437quax901 quantize 9.999E-15 1e-21 -> 9.999000E-15\r
438quax902 quantize 9.999E-15 1e-20 -> 9.99900E-15\r
439quax903 quantize 9.999E-15 1e-19 -> 9.9990E-15\r
440quax904 quantize 9.999E-15 1e-18 -> 9.999E-15\r
441quax905 quantize 9.999E-15 1e-17 -> 1.000E-14 Inexact Rounded\r
442quax906 quantize 9.999E-15 1e-16 -> 1.00E-14 Inexact Rounded\r
443quax907 quantize 9.999E-15 1e-15 -> 1.0E-14 Inexact Rounded\r
444quax908 quantize 9.999E-15 1e-14 -> 1E-14 Inexact Rounded\r
445quax909 quantize 9.999E-15 1e-13 -> 0E-13 Inexact Rounded\r
446quax910 quantize 9.999E-15 1e-12 -> 0E-12 Inexact Rounded\r
447quax911 quantize 9.999E-15 1e-11 -> 0E-11 Inexact Rounded\r
448quax912 quantize 9.999E-15 1e-10 -> 0E-10 Inexact Rounded\r
449quax913 quantize 9.999E-15 1e-9 -> 0E-9 Inexact Rounded\r
450quax914 quantize 9.999E-15 1e-8 -> 0E-8 Inexact Rounded\r
451quax915 quantize 9.999E-15 1e-7 -> 0E-7 Inexact Rounded\r
452quax916 quantize 9.999E-15 1e-6 -> 0.000000 Inexact Rounded\r
453quax917 quantize 9.999E-15 1e-5 -> 0.00000 Inexact Rounded\r
454quax918 quantize 9.999E-15 1e-4 -> 0.0000 Inexact Rounded\r
455quax919 quantize 9.999E-15 1e-3 -> 0.000 Inexact Rounded\r
456quax920 quantize 9.999E-15 1e-2 -> 0.00 Inexact Rounded\r
457quax921 quantize 9.999E-15 1e-1 -> 0.0 Inexact Rounded\r
458quax922 quantize 9.999E-15 1e0 -> 0 Inexact Rounded\r
459quax923 quantize 9.999E-15 1e1 -> 0E+1 Inexact Rounded\r
460\r
461precision: 6\r
462quax930 quantize 9.999E-15 1e-22 -> NaN Invalid_operation\r
463quax931 quantize 9.999E-15 1e-21 -> NaN Invalid_operation\r
464quax932 quantize 9.999E-15 1e-20 -> 9.99900E-15\r
465quax933 quantize 9.999E-15 1e-19 -> 9.9990E-15\r
466quax934 quantize 9.999E-15 1e-18 -> 9.999E-15\r
467quax935 quantize 9.999E-15 1e-17 -> 1.000E-14 Inexact Rounded\r
468quax936 quantize 9.999E-15 1e-16 -> 1.00E-14 Inexact Rounded\r
469quax937 quantize 9.999E-15 1e-15 -> 1.0E-14 Inexact Rounded\r
470quax938 quantize 9.999E-15 1e-14 -> 1E-14 Inexact Rounded\r
471quax939 quantize 9.999E-15 1e-13 -> 0E-13 Inexact Rounded\r
472quax940 quantize 9.999E-15 1e-12 -> 0E-12 Inexact Rounded\r
473quax941 quantize 9.999E-15 1e-11 -> 0E-11 Inexact Rounded\r
474quax942 quantize 9.999E-15 1e-10 -> 0E-10 Inexact Rounded\r
475quax943 quantize 9.999E-15 1e-9 -> 0E-9 Inexact Rounded\r
476quax944 quantize 9.999E-15 1e-8 -> 0E-8 Inexact Rounded\r
477quax945 quantize 9.999E-15 1e-7 -> 0E-7 Inexact Rounded\r
478quax946 quantize 9.999E-15 1e-6 -> 0.000000 Inexact Rounded\r
479quax947 quantize 9.999E-15 1e-5 -> 0.00000 Inexact Rounded\r
480quax948 quantize 9.999E-15 1e-4 -> 0.0000 Inexact Rounded\r
481quax949 quantize 9.999E-15 1e-3 -> 0.000 Inexact Rounded\r
482quax950 quantize 9.999E-15 1e-2 -> 0.00 Inexact Rounded\r
483quax951 quantize 9.999E-15 1e-1 -> 0.0 Inexact Rounded\r
484quax952 quantize 9.999E-15 1e0 -> 0 Inexact Rounded\r
485quax953 quantize 9.999E-15 1e1 -> 0E+1 Inexact Rounded\r
486\r
487precision: 3\r
488quax960 quantize 9.999E-15 1e-22 -> NaN Invalid_operation\r
489quax961 quantize 9.999E-15 1e-21 -> NaN Invalid_operation\r
490quax962 quantize 9.999E-15 1e-20 -> NaN Invalid_operation\r
491quax963 quantize 9.999E-15 1e-19 -> NaN Invalid_operation\r
492quax964 quantize 9.999E-15 1e-18 -> NaN Invalid_operation\r
493quax965 quantize 9.999E-15 1e-17 -> NaN Invalid_operation\r
494quax966 quantize 9.999E-15 1e-16 -> 1.00E-14 Inexact Rounded\r
495quax967 quantize 9.999E-15 1e-15 -> 1.0E-14 Inexact Rounded\r
496quax968 quantize 9.999E-15 1e-14 -> 1E-14 Inexact Rounded\r
497quax969 quantize 9.999E-15 1e-13 -> 0E-13 Inexact Rounded\r
498quax970 quantize 9.999E-15 1e-12 -> 0E-12 Inexact Rounded\r
499quax971 quantize 9.999E-15 1e-11 -> 0E-11 Inexact Rounded\r
500quax972 quantize 9.999E-15 1e-10 -> 0E-10 Inexact Rounded\r
501quax973 quantize 9.999E-15 1e-9 -> 0E-9 Inexact Rounded\r
502quax974 quantize 9.999E-15 1e-8 -> 0E-8 Inexact Rounded\r
503quax975 quantize 9.999E-15 1e-7 -> 0E-7 Inexact Rounded\r
504quax976 quantize 9.999E-15 1e-6 -> 0.000000 Inexact Rounded\r
505quax977 quantize 9.999E-15 1e-5 -> 0.00000 Inexact Rounded\r
506quax978 quantize 9.999E-15 1e-4 -> 0.0000 Inexact Rounded\r
507quax979 quantize 9.999E-15 1e-3 -> 0.000 Inexact Rounded\r
508quax980 quantize 9.999E-15 1e-2 -> 0.00 Inexact Rounded\r
509quax981 quantize 9.999E-15 1e-1 -> 0.0 Inexact Rounded\r
510quax982 quantize 9.999E-15 1e0 -> 0 Inexact Rounded\r
511quax983 quantize 9.999E-15 1e1 -> 0E+1 Inexact Rounded\r
512\r
513-- Fung Lee's case & similar\r
514precision: 3\r
515quax1001 quantize 0.000 0.001 -> 0.000\r
516quax1002 quantize 0.001 0.001 -> 0.001\r
517quax1003 quantize 0.0012 0.001 -> 0.001 Inexact Rounded\r
518quax1004 quantize 0.0018 0.001 -> 0.002 Inexact Rounded\r
519quax1005 quantize 0.501 0.001 -> 0.501\r
520quax1006 quantize 0.5012 0.001 -> 0.501 Inexact Rounded\r
521quax1007 quantize 0.5018 0.001 -> 0.502 Inexact Rounded\r
522quax1008 quantize 0.999 0.001 -> 0.999\r
523quax1009 quantize 0.9992 0.001 -> 0.999 Inexact Rounded\r
524quax1010 quantize 0.9998 0.001 -> NaN Invalid_operation\r
525quax1011 quantize 1.0001 0.001 -> NaN Invalid_operation\r
526quax1012 quantize 1.0051 0.001 -> NaN Invalid_operation\r
527quax1013 quantize 1.0551 0.001 -> NaN Invalid_operation\r
528quax1014 quantize 1.5551 0.001 -> NaN Invalid_operation\r
529quax1015 quantize 1.9999 0.001 -> NaN Invalid_operation\r
530\r
531-- long operand checks [rhs checks removed]\r
532maxexponent: 999\r
533minexponent: -999\r
534precision: 9\r
535quax481 quantize 12345678000 1e+3 -> 1.2345678E+10 Rounded\r
536quax482 quantize 1234567800 1e+1 -> 1.23456780E+9 Rounded\r
537quax483 quantize 1234567890 1e+1 -> 1.23456789E+9 Rounded\r
538quax484 quantize 1234567891 1e+1 -> 1.23456789E+9 Inexact Rounded\r
539quax485 quantize 12345678901 1e+2 -> 1.23456789E+10 Inexact Rounded\r
540quax486 quantize 1234567896 1e+1 -> 1.23456790E+9 Inexact Rounded\r
541-- a potential double-round\r
542quax487 quantize 1234.987643 1e-4 -> 1234.9876 Inexact Rounded\r
543quax488 quantize 1234.987647 1e-4 -> 1234.9876 Inexact Rounded\r
544\r
545precision: 15\r
546quax491 quantize 12345678000 1e+3 -> 1.2345678E+10 Rounded\r
547quax492 quantize 1234567800 1e+1 -> 1.23456780E+9 Rounded\r
548quax493 quantize 1234567890 1e+1 -> 1.23456789E+9 Rounded\r
549quax494 quantize 1234567891 1e+1 -> 1.23456789E+9 Inexact Rounded\r
550quax495 quantize 12345678901 1e+2 -> 1.23456789E+10 Inexact Rounded\r
551quax496 quantize 1234567896 1e+1 -> 1.23456790E+9 Inexact Rounded\r
552quax497 quantize 1234.987643 1e-4 -> 1234.9876 Inexact Rounded\r
553quax498 quantize 1234.987647 1e-4 -> 1234.9876 Inexact Rounded\r
554\r
555-- Zeros\r
556quax500 quantize 0 1e1 -> 0E+1\r
557quax501 quantize 0 1e0 -> 0\r
558quax502 quantize 0 1e-1 -> 0.0\r
559quax503 quantize 0.0 1e-1 -> 0.0\r
560quax504 quantize 0.0 1e0 -> 0\r
561quax505 quantize 0.0 1e+1 -> 0E+1\r
562quax506 quantize 0E+1 1e-1 -> 0.0\r
563quax507 quantize 0E+1 1e0 -> 0\r
564quax508 quantize 0E+1 1e+1 -> 0E+1\r
565quax509 quantize -0 1e1 -> -0E+1\r
566quax510 quantize -0 1e0 -> -0\r
567quax511 quantize -0 1e-1 -> -0.0\r
568quax512 quantize -0.0 1e-1 -> -0.0\r
569quax513 quantize -0.0 1e0 -> -0\r
570quax514 quantize -0.0 1e+1 -> -0E+1\r
571quax515 quantize -0E+1 1e-1 -> -0.0\r
572quax516 quantize -0E+1 1e0 -> -0\r
573quax517 quantize -0E+1 1e+1 -> -0E+1\r
574\r
575-- Suspicious RHS values\r
576maxexponent: 999999999\r
577minexponent: -999999999\r
578precision: 15\r
579quax520 quantize 1.234 1e999999000 -> 0E+999999000 Inexact Rounded\r
580quax521 quantize 123.456 1e999999000 -> 0E+999999000 Inexact Rounded\r
581quax522 quantize 1.234 1e999999999 -> 0E+999999999 Inexact Rounded\r
582quax523 quantize 123.456 1e999999999 -> 0E+999999999 Inexact Rounded\r
583quax524 quantize 123.456 1e1000000000 -> NaN Invalid_operation\r
584quax525 quantize 123.456 1e12345678903 -> NaN Invalid_operation\r
585-- next four are "won't fit" overflows\r
586quax526 quantize 1.234 1e-999999000 -> NaN Invalid_operation\r
587quax527 quantize 123.456 1e-999999000 -> NaN Invalid_operation\r
588quax528 quantize 1.234 1e-999999999 -> NaN Invalid_operation\r
589quax529 quantize 123.456 1e-999999999 -> NaN Invalid_operation\r
590quax530 quantize 123.456 1e-1000000014 -> NaN Invalid_operation\r
591quax531 quantize 123.456 1e-12345678903 -> NaN Invalid_operation\r
592\r
593maxexponent: 999\r
594minexponent: -999\r
595precision: 15\r
596quax532 quantize 1.234E+999 1e999 -> 1E+999 Inexact Rounded\r
597quax533 quantize 1.234E+998 1e999 -> 0E+999 Inexact Rounded\r
598quax534 quantize 1.234 1e999 -> 0E+999 Inexact Rounded\r
599quax535 quantize 1.234 1e1000 -> NaN Invalid_operation\r
600quax536 quantize 1.234 1e5000 -> NaN Invalid_operation\r
601quax537 quantize 0 1e-999 -> 0E-999\r
602-- next two are "won't fit" overflows\r
603quax538 quantize 1.234 1e-999 -> NaN Invalid_operation\r
604quax539 quantize 1.234 1e-1000 -> NaN Invalid_operation\r
605quax540 quantize 1.234 1e-5000 -> NaN Invalid_operation\r
606-- [more below]\r
607\r
608-- check bounds (lhs maybe out of range for destination, etc.)\r
609precision: 7\r
610quax541 quantize 1E+999 1e+999 -> 1E+999\r
611quax542 quantize 1E+1000 1e+999 -> NaN Invalid_operation\r
612quax543 quantize 1E+999 1e+1000 -> NaN Invalid_operation\r
613quax544 quantize 1E-999 1e-999 -> 1E-999\r
614quax545 quantize 1E-1000 1e-999 -> 0E-999 Inexact Rounded\r
615quax546 quantize 1E-999 1e-1000 -> 1.0E-999\r
616quax547 quantize 1E-1005 1e-999 -> 0E-999 Inexact Rounded\r
617quax548 quantize 1E-1006 1e-999 -> 0E-999 Inexact Rounded\r
618quax549 quantize 1E-1007 1e-999 -> 0E-999 Inexact Rounded\r
619quax550 quantize 1E-998 1e-1005 -> NaN Invalid_operation -- won't fit\r
620quax551 quantize 1E-999 1e-1005 -> 1.000000E-999\r
621quax552 quantize 1E-1000 1e-1005 -> 1.00000E-1000 Subnormal\r
622quax553 quantize 1E-999 1e-1006 -> NaN Invalid_operation\r
623quax554 quantize 1E-999 1e-1007 -> NaN Invalid_operation\r
624-- related subnormal rounding\r
625quax555 quantize 1.666666E-999 1e-1005 -> 1.666666E-999\r
626quax556 quantize 1.666666E-1000 1e-1005 -> 1.66667E-1000 Subnormal Inexact Rounded\r
627quax557 quantize 1.666666E-1001 1e-1005 -> 1.6667E-1001 Subnormal Inexact Rounded\r
628quax558 quantize 1.666666E-1002 1e-1005 -> 1.667E-1002 Subnormal Inexact Rounded\r
629quax559 quantize 1.666666E-1003 1e-1005 -> 1.67E-1003 Subnormal Inexact Rounded\r
630quax560 quantize 1.666666E-1004 1e-1005 -> 1.7E-1004 Subnormal Inexact Rounded\r
631quax561 quantize 1.666666E-1005 1e-1005 -> 2E-1005 Subnormal Inexact Rounded\r
632quax562 quantize 1.666666E-1006 1e-1005 -> 0E-1005 Inexact Rounded\r
633quax563 quantize 1.666666E-1007 1e-1005 -> 0E-1005 Inexact Rounded\r
634\r
635-- Specials\r
636quax580 quantize Inf -Inf -> Infinity\r
637quax581 quantize Inf 1e-1000 -> NaN Invalid_operation\r
638quax582 quantize Inf 1e-1 -> NaN Invalid_operation\r
639quax583 quantize Inf 1e0 -> NaN Invalid_operation\r
640quax584 quantize Inf 1e1 -> NaN Invalid_operation\r
641quax585 quantize Inf 1e1000 -> NaN Invalid_operation\r
642quax586 quantize Inf Inf -> Infinity\r
643quax587 quantize -1000 Inf -> NaN Invalid_operation\r
644quax588 quantize -Inf Inf -> -Infinity\r
645quax589 quantize -1 Inf -> NaN Invalid_operation\r
646quax590 quantize 0 Inf -> NaN Invalid_operation\r
647quax591 quantize 1 Inf -> NaN Invalid_operation\r
648quax592 quantize 1000 Inf -> NaN Invalid_operation\r
649quax593 quantize Inf Inf -> Infinity\r
650quax594 quantize Inf 1e-0 -> NaN Invalid_operation\r
651quax595 quantize -0 Inf -> NaN Invalid_operation\r
652\r
653quax600 quantize -Inf -Inf -> -Infinity\r
654quax601 quantize -Inf 1e-1000 -> NaN Invalid_operation\r
655quax602 quantize -Inf 1e-1 -> NaN Invalid_operation\r
656quax603 quantize -Inf 1e0 -> NaN Invalid_operation\r
657quax604 quantize -Inf 1e1 -> NaN Invalid_operation\r
658quax605 quantize -Inf 1e1000 -> NaN Invalid_operation\r
659quax606 quantize -Inf Inf -> -Infinity\r
660quax607 quantize -1000 Inf -> NaN Invalid_operation\r
661quax608 quantize -Inf -Inf -> -Infinity\r
662quax609 quantize -1 -Inf -> NaN Invalid_operation\r
663quax610 quantize 0 -Inf -> NaN Invalid_operation\r
664quax611 quantize 1 -Inf -> NaN Invalid_operation\r
665quax612 quantize 1000 -Inf -> NaN Invalid_operation\r
666quax613 quantize Inf -Inf -> Infinity\r
667quax614 quantize -Inf 1e-0 -> NaN Invalid_operation\r
668quax615 quantize -0 -Inf -> NaN Invalid_operation\r
669\r
670quax621 quantize NaN -Inf -> NaN\r
671quax622 quantize NaN 1e-1000 -> NaN\r
672quax623 quantize NaN 1e-1 -> NaN\r
673quax624 quantize NaN 1e0 -> NaN\r
674quax625 quantize NaN 1e1 -> NaN\r
675quax626 quantize NaN 1e1000 -> NaN\r
676quax627 quantize NaN Inf -> NaN\r
677quax628 quantize NaN NaN -> NaN\r
678quax629 quantize -Inf NaN -> NaN\r
679quax630 quantize -1000 NaN -> NaN\r
680quax631 quantize -1 NaN -> NaN\r
681quax632 quantize 0 NaN -> NaN\r
682quax633 quantize 1 NaN -> NaN\r
683quax634 quantize 1000 NaN -> NaN\r
684quax635 quantize Inf NaN -> NaN\r
685quax636 quantize NaN 1e-0 -> NaN\r
686quax637 quantize -0 NaN -> NaN\r
687\r
688quax641 quantize sNaN -Inf -> NaN Invalid_operation\r
689quax642 quantize sNaN 1e-1000 -> NaN Invalid_operation\r
690quax643 quantize sNaN 1e-1 -> NaN Invalid_operation\r
691quax644 quantize sNaN 1e0 -> NaN Invalid_operation\r
692quax645 quantize sNaN 1e1 -> NaN Invalid_operation\r
693quax646 quantize sNaN 1e1000 -> NaN Invalid_operation\r
694quax647 quantize sNaN NaN -> NaN Invalid_operation\r
695quax648 quantize sNaN sNaN -> NaN Invalid_operation\r
696quax649 quantize NaN sNaN -> NaN Invalid_operation\r
697quax650 quantize -Inf sNaN -> NaN Invalid_operation\r
698quax651 quantize -1000 sNaN -> NaN Invalid_operation\r
699quax652 quantize -1 sNaN -> NaN Invalid_operation\r
700quax653 quantize 0 sNaN -> NaN Invalid_operation\r
701quax654 quantize 1 sNaN -> NaN Invalid_operation\r
702quax655 quantize 1000 sNaN -> NaN Invalid_operation\r
703quax656 quantize Inf sNaN -> NaN Invalid_operation\r
704quax657 quantize NaN sNaN -> NaN Invalid_operation\r
705quax658 quantize sNaN 1e-0 -> NaN Invalid_operation\r
706quax659 quantize -0 sNaN -> NaN Invalid_operation\r
707\r
708-- propagating NaNs\r
709quax661 quantize NaN9 -Inf -> NaN9\r
710quax662 quantize NaN8 919 -> NaN8\r
711quax663 quantize NaN71 Inf -> NaN71\r
712quax664 quantize NaN6 NaN5 -> NaN6\r
713quax665 quantize -Inf NaN4 -> NaN4\r
714quax666 quantize -919 NaN31 -> NaN31\r
715quax667 quantize Inf NaN2 -> NaN2\r
716\r
717quax671 quantize sNaN99 -Inf -> NaN99 Invalid_operation\r
718quax672 quantize sNaN98 -11 -> NaN98 Invalid_operation\r
719quax673 quantize sNaN97 NaN -> NaN97 Invalid_operation\r
720quax674 quantize sNaN16 sNaN94 -> NaN16 Invalid_operation\r
721quax675 quantize NaN95 sNaN93 -> NaN93 Invalid_operation\r
722quax676 quantize -Inf sNaN92 -> NaN92 Invalid_operation\r
723quax677 quantize 088 sNaN91 -> NaN91 Invalid_operation\r
724quax678 quantize Inf sNaN90 -> NaN90 Invalid_operation\r
725quax679 quantize NaN sNaN88 -> NaN88 Invalid_operation\r
726\r
727quax681 quantize -NaN9 -Inf -> -NaN9\r
728quax682 quantize -NaN8 919 -> -NaN8\r
729quax683 quantize -NaN71 Inf -> -NaN71\r
730quax684 quantize -NaN6 -NaN5 -> -NaN6\r
731quax685 quantize -Inf -NaN4 -> -NaN4\r
732quax686 quantize -919 -NaN31 -> -NaN31\r
733quax687 quantize Inf -NaN2 -> -NaN2\r
734\r
735quax691 quantize -sNaN99 -Inf -> -NaN99 Invalid_operation\r
736quax692 quantize -sNaN98 -11 -> -NaN98 Invalid_operation\r
737quax693 quantize -sNaN97 NaN -> -NaN97 Invalid_operation\r
738quax694 quantize -sNaN16 sNaN94 -> -NaN16 Invalid_operation\r
739quax695 quantize -NaN95 -sNaN93 -> -NaN93 Invalid_operation\r
740quax696 quantize -Inf -sNaN92 -> -NaN92 Invalid_operation\r
741quax697 quantize 088 -sNaN91 -> -NaN91 Invalid_operation\r
742quax698 quantize Inf -sNaN90 -> -NaN90 Invalid_operation\r
743quax699 quantize NaN -sNaN88 -> -NaN88 Invalid_operation\r
744\r
745-- subnormals and underflow\r
746precision: 4\r
747maxexponent: 999\r
748minexponent: -999\r
749quax710 quantize 1.00E-999 1e-999 -> 1E-999 Rounded\r
750quax711 quantize 0.1E-999 2e-1000 -> 1E-1000 Subnormal\r
751quax712 quantize 0.10E-999 3e-1000 -> 1E-1000 Subnormal Rounded\r
752quax713 quantize 0.100E-999 4e-1000 -> 1E-1000 Subnormal Rounded\r
753quax714 quantize 0.01E-999 5e-1001 -> 1E-1001 Subnormal\r
754-- next is rounded to Emin\r
755quax715 quantize 0.999E-999 1e-999 -> 1E-999 Inexact Rounded\r
756quax716 quantize 0.099E-999 10e-1000 -> 1E-1000 Inexact Rounded Subnormal\r
757\r
758quax717 quantize 0.009E-999 1e-1001 -> 1E-1001 Inexact Rounded Subnormal\r
759quax718 quantize 0.001E-999 1e-1001 -> 0E-1001 Inexact Rounded\r
760quax719 quantize 0.0009E-999 1e-1001 -> 0E-1001 Inexact Rounded\r
761quax720 quantize 0.0001E-999 1e-1001 -> 0E-1001 Inexact Rounded\r
762\r
763quax730 quantize -1.00E-999 1e-999 -> -1E-999 Rounded\r
764quax731 quantize -0.1E-999 1e-999 -> -0E-999 Rounded Inexact\r
765quax732 quantize -0.10E-999 1e-999 -> -0E-999 Rounded Inexact\r
766quax733 quantize -0.100E-999 1e-999 -> -0E-999 Rounded Inexact\r
767quax734 quantize -0.01E-999 1e-999 -> -0E-999 Inexact Rounded\r
768-- next is rounded to Emin\r
769quax735 quantize -0.999E-999 90e-999 -> -1E-999 Inexact Rounded\r
770quax736 quantize -0.099E-999 -1e-999 -> -0E-999 Inexact Rounded\r
771quax737 quantize -0.009E-999 -1e-999 -> -0E-999 Inexact Rounded\r
772quax738 quantize -0.001E-999 -0e-999 -> -0E-999 Inexact Rounded\r
773quax739 quantize -0.0001E-999 0e-999 -> -0E-999 Inexact Rounded\r
774\r
775quax740 quantize -1.00E-999 1e-1000 -> -1.0E-999 Rounded\r
776quax741 quantize -0.1E-999 1e-1000 -> -1E-1000 Subnormal\r
777quax742 quantize -0.10E-999 1e-1000 -> -1E-1000 Subnormal Rounded\r
778quax743 quantize -0.100E-999 1e-1000 -> -1E-1000 Subnormal Rounded\r
779quax744 quantize -0.01E-999 1e-1000 -> -0E-1000 Inexact Rounded\r
780-- next is rounded to Emin\r
781quax745 quantize -0.999E-999 1e-1000 -> -1.0E-999 Inexact Rounded\r
782quax746 quantize -0.099E-999 1e-1000 -> -1E-1000 Inexact Rounded Subnormal\r
783quax747 quantize -0.009E-999 1e-1000 -> -0E-1000 Inexact Rounded\r
784quax748 quantize -0.001E-999 1e-1000 -> -0E-1000 Inexact Rounded\r
785quax749 quantize -0.0001E-999 1e-1000 -> -0E-1000 Inexact Rounded\r
786\r
787quax750 quantize -1.00E-999 1e-1001 -> -1.00E-999\r
788quax751 quantize -0.1E-999 1e-1001 -> -1.0E-1000 Subnormal\r
789quax752 quantize -0.10E-999 1e-1001 -> -1.0E-1000 Subnormal\r
790quax753 quantize -0.100E-999 1e-1001 -> -1.0E-1000 Subnormal Rounded\r
791quax754 quantize -0.01E-999 1e-1001 -> -1E-1001 Subnormal\r
792-- next is rounded to Emin\r
793quax755 quantize -0.999E-999 1e-1001 -> -1.00E-999 Inexact Rounded\r
794quax756 quantize -0.099E-999 1e-1001 -> -1.0E-1000 Inexact Rounded Subnormal\r
795quax757 quantize -0.009E-999 1e-1001 -> -1E-1001 Inexact Rounded Subnormal\r
796quax758 quantize -0.001E-999 1e-1001 -> -0E-1001 Inexact Rounded\r
797quax759 quantize -0.0001E-999 1e-1001 -> -0E-1001 Inexact Rounded\r
798\r
799quax760 quantize -1.00E-999 1e-1002 -> -1.000E-999\r
800quax761 quantize -0.1E-999 1e-1002 -> -1.00E-1000 Subnormal\r
801quax762 quantize -0.10E-999 1e-1002 -> -1.00E-1000 Subnormal\r
802quax763 quantize -0.100E-999 1e-1002 -> -1.00E-1000 Subnormal\r
803quax764 quantize -0.01E-999 1e-1002 -> -1.0E-1001 Subnormal\r
804quax765 quantize -0.999E-999 1e-1002 -> -9.99E-1000 Subnormal\r
805quax766 quantize -0.099E-999 1e-1002 -> -9.9E-1001 Subnormal\r
806quax767 quantize -0.009E-999 1e-1002 -> -9E-1002 Subnormal\r
807quax768 quantize -0.001E-999 1e-1002 -> -1E-1002 Subnormal\r
808quax769 quantize -0.0001E-999 1e-1002 -> -0E-1002 Inexact Rounded\r
809\r
810-- rhs must be no less than Etiny\r
811quax770 quantize -1.00E-999 1e-1003 -> NaN Invalid_operation\r
812quax771 quantize -0.1E-999 1e-1003 -> NaN Invalid_operation\r
813quax772 quantize -0.10E-999 1e-1003 -> NaN Invalid_operation\r
814quax773 quantize -0.100E-999 1e-1003 -> NaN Invalid_operation\r
815quax774 quantize -0.01E-999 1e-1003 -> NaN Invalid_operation\r
816quax775 quantize -0.999E-999 1e-1003 -> NaN Invalid_operation\r
817quax776 quantize -0.099E-999 1e-1003 -> NaN Invalid_operation\r
818quax777 quantize -0.009E-999 1e-1003 -> NaN Invalid_operation\r
819quax778 quantize -0.001E-999 1e-1003 -> NaN Invalid_operation\r
820quax779 quantize -0.0001E-999 1e-1003 -> NaN Invalid_operation\r
821quax780 quantize -0.0001E-999 1e-1004 -> NaN Invalid_operation\r
822\r
823precision: 9\r
824maxExponent: 999999999\r
825minexponent: -999999999\r
826\r
827-- some extremes derived from Rescale testcases\r
828quax801 quantize 0 1e1000000000 -> NaN Invalid_operation\r
829quax802 quantize 0 1e-1000000000 -> 0E-1000000000\r
830quax803 quantize 0 1e2000000000 -> NaN Invalid_operation\r
831quax804 quantize 0 1e-2000000000 -> NaN Invalid_operation\r
832quax805 quantize 0 1e3000000000 -> NaN Invalid_operation\r
833quax806 quantize 0 1e-3000000000 -> NaN Invalid_operation\r
834quax807 quantize 0 1e4000000000 -> NaN Invalid_operation\r
835quax808 quantize 0 1e-4000000000 -> NaN Invalid_operation\r
836quax809 quantize 0 1e5000000000 -> NaN Invalid_operation\r
837quax810 quantize 0 1e-5000000000 -> NaN Invalid_operation\r
838quax811 quantize 0 1e6000000000 -> NaN Invalid_operation\r
839quax812 quantize 0 1e-6000000000 -> NaN Invalid_operation\r
840quax813 quantize 0 1e7000000000 -> NaN Invalid_operation\r
841quax814 quantize 0 1e-7000000000 -> NaN Invalid_operation\r
842quax815 quantize 0 1e8000000000 -> NaN Invalid_operation\r
843quax816 quantize 0 1e-8000000000 -> NaN Invalid_operation\r
844quax817 quantize 0 1e9000000000 -> NaN Invalid_operation\r
845quax818 quantize 0 1e-9000000000 -> NaN Invalid_operation\r
846quax819 quantize 0 1e9999999999 -> NaN Invalid_operation\r
847quax820 quantize 0 1e-9999999999 -> NaN Invalid_operation\r
848quax821 quantize 0 1e10000000000 -> NaN Invalid_operation\r
849quax822 quantize 0 1e-10000000000 -> NaN Invalid_operation\r
850\r
851quax843 quantize 0 1e999999999 -> 0E+999999999\r
852quax844 quantize 0 1e1000000000 -> NaN Invalid_operation\r
853quax845 quantize 0 1e-999999999 -> 0E-999999999\r
854quax846 quantize 0 1e-1000000000 -> 0E-1000000000\r
855quax847 quantize 0 1e-1000000001 -> 0E-1000000001\r
856quax848 quantize 0 1e-1000000002 -> 0E-1000000002\r
857quax849 quantize 0 1e-1000000003 -> 0E-1000000003\r
858quax850 quantize 0 1e-1000000004 -> 0E-1000000004\r
859quax851 quantize 0 1e-1000000005 -> 0E-1000000005\r
860quax852 quantize 0 1e-1000000006 -> 0E-1000000006\r
861quax853 quantize 0 1e-1000000007 -> 0E-1000000007\r
862quax854 quantize 0 1e-1000000008 -> NaN Invalid_operation\r
863\r
864quax861 quantize 1 1e+2147483649 -> NaN Invalid_operation\r
865quax862 quantize 1 1e+2147483648 -> NaN Invalid_operation\r
866quax863 quantize 1 1e+2147483647 -> NaN Invalid_operation\r
867quax864 quantize 1 1e-2147483647 -> NaN Invalid_operation\r
868quax865 quantize 1 1e-2147483648 -> NaN Invalid_operation\r
869quax866 quantize 1 1e-2147483649 -> NaN Invalid_operation\r
870\r
871-- More from Fung Lee\r
872precision: 16\r
873rounding: half_up\r
874maxExponent: 384\r
875minExponent: -383\r
876quax1021 quantize 8.666666666666000E+384 1.000000000000000E+384 -> 8.666666666666000E+384\r
877quax1022 quantize 64#8.666666666666000E+384 64#1.000000000000000E+384 -> 8.666666666666000E+384\r
878quax1023 quantize 64#8.666666666666000E+384 128#1.000000000000000E+384 -> 8.666666666666000E+384\r
879quax1024 quantize 64#8.666666666666000E+384 64#1E+384 -> 8.666666666666000E+384\r
880quax1025 quantize 64#8.666666666666000E+384 64#1E+384 -> 64#8.666666666666000E+384\r
881quax1026 quantize 64#8.666666666666000E+384 128#1E+384 -> 64#9E+384 Inexact Rounded Clamped\r
882quax1027 quantize 64#8.666666666666000E+323 64#1E+31 -> NaN Invalid_operation\r
883quax1028 quantize 64#8.666666666666000E+323 128#1E+31 -> NaN Invalid_operation\r
884quax1029 quantize 64#8.66666666E+3 128#1E+10 -> 64#0E10 Inexact Rounded\r
885quax1030 quantize 8.66666666E+3 1E+3 -> 9E+3 Inexact Rounded\r
886\r
887-- Int and uInt32 edge values for testing conversions\r
888quax1040 quantize -2147483646 0 -> -2147483646\r
889quax1041 quantize -2147483647 0 -> -2147483647\r
890quax1042 quantize -2147483648 0 -> -2147483648\r
891quax1043 quantize -2147483649 0 -> -2147483649\r
892quax1044 quantize 2147483646 0 -> 2147483646\r
893quax1045 quantize 2147483647 0 -> 2147483647\r
894quax1046 quantize 2147483648 0 -> 2147483648\r
895quax1047 quantize 2147483649 0 -> 2147483649\r
896quax1048 quantize 4294967294 0 -> 4294967294\r
897quax1049 quantize 4294967295 0 -> 4294967295\r
898quax1050 quantize 4294967296 0 -> 4294967296\r
899quax1051 quantize 4294967297 0 -> 4294967297\r
900-- and powers of ten for same\r
901quax1101 quantize 5000000000 0 -> 5000000000\r
902quax1102 quantize 4000000000 0 -> 4000000000\r
903quax1103 quantize 2000000000 0 -> 2000000000\r
904quax1104 quantize 1000000000 0 -> 1000000000\r
905quax1105 quantize 0100000000 0 -> 100000000\r
906quax1106 quantize 0010000000 0 -> 10000000\r
907quax1107 quantize 0001000000 0 -> 1000000\r
908quax1108 quantize 0000100000 0 -> 100000\r
909quax1109 quantize 0000010000 0 -> 10000\r
910quax1110 quantize 0000001000 0 -> 1000\r
911quax1111 quantize 0000000100 0 -> 100\r
912quax1112 quantize 0000000010 0 -> 10\r
913quax1113 quantize 0000000001 0 -> 1\r
914quax1114 quantize 0000000000 0 -> 0\r
915-- and powers of ten for same\r
916quax1121 quantize -5000000000 0 -> -5000000000\r
917quax1122 quantize -4000000000 0 -> -4000000000\r
918quax1123 quantize -2000000000 0 -> -2000000000\r
919quax1124 quantize -1000000000 0 -> -1000000000\r
920quax1125 quantize -0100000000 0 -> -100000000\r
921quax1126 quantize -0010000000 0 -> -10000000\r
922quax1127 quantize -0001000000 0 -> -1000000\r
923quax1128 quantize -0000100000 0 -> -100000\r
924quax1129 quantize -0000010000 0 -> -10000\r
925quax1130 quantize -0000001000 0 -> -1000\r
926quax1131 quantize -0000000100 0 -> -100\r
927quax1132 quantize -0000000010 0 -> -10\r
928quax1133 quantize -0000000001 0 -> -1\r
929quax1134 quantize -0000000000 0 -> -0\r
930\r
931-- Some miscellany\r
932precision: 34\r
933rounding: half_up\r
934maxExponent: 6144\r
935minExponent: -6143\r
936-- 1 2 3\r
937-- 1 234567890123456789012345678901234\r
938quax0a1 quantize 8.555555555555555555555555555555555E+6143 1E+6143 -> 9E+6143 Inexact Rounded\r
939quax0a2 quantize 128#8.555555555555555555555555555555555E+6143 128#1E+6143 -> 8.55555555555555555555555555555556E+6143 Rounded Inexact\r
940quax0a3 quantize 128#8.555555555555555555555555555555555E+6144 128#1E+6144 -> 8.555555555555555555555555555555555E+6144\r
941\r
942-- payload decapitate\r
943precision: 5\r
944quax62100 quantize 11 -sNaN1234567890 -> -NaN67890 Invalid_operation\r
945\r
946-- Null tests\r
947quax998 quantize 10 # -> NaN Invalid_operation\r
948quax999 quantize # 1e10 -> NaN Invalid_operation\r