summaryrefslogtreecommitdiffstats
path: root/Lib/test/decimaltestdata/ddMaxMag.decTest
blob: ec2b83054111c46b76315cda95a3fb860c595a70 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
------------------------------------------------------------------------
-- ddMaxMag.decTest -- decDouble maxnummag                            --
-- Copyright (c) IBM Corporation, 1981, 2008.  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.59

-- we assume that base comparison is tested in compare.decTest, so
-- these mainly cover special cases and rounding
precision:   16
maxExponent: 384
minExponent: -383
extended:    1
clamp:       1
rounding:    half_even

-- sanity checks
ddmxg001 maxmag  -2  -2  -> -2
ddmxg002 maxmag  -2  -1  -> -2
ddmxg003 maxmag  -2   0  -> -2
ddmxg004 maxmag  -2   1  -> -2
ddmxg005 maxmag  -2   2  ->  2
ddmxg006 maxmag  -1  -2  -> -2
ddmxg007 maxmag  -1  -1  -> -1
ddmxg008 maxmag  -1   0  -> -1
ddmxg009 maxmag  -1   1  ->  1
ddmxg010 maxmag  -1   2  ->  2
ddmxg011 maxmag   0  -2  -> -2
ddmxg012 maxmag   0  -1  -> -1
ddmxg013 maxmag   0   0  ->  0
ddmxg014 maxmag   0   1  ->  1
ddmxg015 maxmag   0   2  ->  2
ddmxg016 maxmag   1  -2  -> -2
ddmxg017 maxmag   1  -1  ->  1
ddmxg018 maxmag   1   0  ->  1
ddmxg019 maxmag   1   1  ->  1
ddmxg020 maxmag   1   2  ->  2
ddmxg021 maxmag   2  -2  ->  2
ddmxg022 maxmag   2  -1  ->  2
ddmxg023 maxmag   2   0  ->  2
ddmxg025 maxmag   2   1  ->  2
ddmxg026 maxmag   2   2  ->  2

-- extended zeros
ddmxg030 maxmag   0     0   ->  0
ddmxg031 maxmag   0    -0   ->  0
ddmxg032 maxmag   0    -0.0 ->  0
ddmxg033 maxmag   0     0.0 ->  0
ddmxg034 maxmag  -0     0   ->  0    -- note: -0 = 0, but 0 chosen
ddmxg035 maxmag  -0    -0   -> -0
ddmxg036 maxmag  -0    -0.0 -> -0.0
ddmxg037 maxmag  -0     0.0 ->  0.0
ddmxg038 maxmag   0.0   0   ->  0
ddmxg039 maxmag   0.0  -0   ->  0.0
ddmxg040 maxmag   0.0  -0.0 ->  0.0
ddmxg041 maxmag   0.0   0.0 ->  0.0
ddmxg042 maxmag  -0.0   0   ->  0
ddmxg043 maxmag  -0.0  -0   -> -0.0
ddmxg044 maxmag  -0.0  -0.0 -> -0.0
ddmxg045 maxmag  -0.0   0.0 ->  0.0

ddmxg050 maxmag  -0E1   0E1 ->  0E+1
ddmxg051 maxmag  -0E2   0E2 ->  0E+2
ddmxg052 maxmag  -0E2   0E1 ->  0E+1
ddmxg053 maxmag  -0E1   0E2 ->  0E+2
ddmxg054 maxmag   0E1  -0E1 ->  0E+1
ddmxg055 maxmag   0E2  -0E2 ->  0E+2
ddmxg056 maxmag   0E2  -0E1 ->  0E+2
ddmxg057 maxmag   0E1  -0E2 ->  0E+1

ddmxg058 maxmag   0E1   0E1 ->  0E+1
ddmxg059 maxmag   0E2   0E2 ->  0E+2
ddmxg060 maxmag   0E2   0E1 ->  0E+2
ddmxg061 maxmag   0E1   0E2 ->  0E+2
ddmxg062 maxmag  -0E1  -0E1 -> -0E+1
ddmxg063 maxmag  -0E2  -0E2 -> -0E+2
ddmxg064 maxmag  -0E2  -0E1 -> -0E+1
ddmxg065 maxmag  -0E1  -0E2 -> -0E+1

-- Specials
ddmxg090 maxmag  Inf  -Inf   ->  Infinity
ddmxg091 maxmag  Inf  -1000  ->  Infinity
ddmxg092 maxmag  Inf  -1     ->  Infinity
ddmxg093 maxmag  Inf  -0     ->  Infinity
ddmxg094 maxmag  Inf   0     ->  Infinity
ddmxg095 maxmag  Inf   1     ->  Infinity
ddmxg096 maxmag  Inf   1000  ->  Infinity
ddmxg097 maxmag  Inf   Inf   ->  Infinity
ddmxg098 maxmag -1000  Inf   ->  Infinity
ddmxg099 maxmag -Inf   Inf   ->  Infinity
ddmxg100 maxmag -1     Inf   ->  Infinity
ddmxg101 maxmag -0     Inf   ->  Infinity
ddmxg102 maxmag  0     Inf   ->  Infinity
ddmxg103 maxmag  1     Inf   ->  Infinity
ddmxg104 maxmag  1000  Inf   ->  Infinity
ddmxg105 maxmag  Inf   Inf   ->  Infinity

ddmxg120 maxmag -Inf  -Inf   -> -Infinity
ddmxg121 maxmag -Inf  -1000  -> -Infinity
ddmxg122 maxmag -Inf  -1     -> -Infinity
ddmxg123 maxmag -Inf  -0     -> -Infinity
ddmxg124 maxmag -Inf   0     -> -Infinity
ddmxg125 maxmag -Inf   1     -> -Infinity
ddmxg126 maxmag -Inf   1000  -> -Infinity
ddmxg127 maxmag -Inf   Inf   ->  Infinity
ddmxg128 maxmag -Inf  -Inf   ->  -Infinity
ddmxg129 maxmag -1000 -Inf   -> -Infinity
ddmxg130 maxmag -1    -Inf   -> -Infinity
ddmxg131 maxmag -0    -Inf   -> -Infinity
ddmxg132 maxmag  0    -Inf   -> -Infinity
ddmxg133 maxmag  1    -Inf   -> -Infinity
ddmxg134 maxmag  1000 -Inf   -> -Infinity
ddmxg135 maxmag  Inf  -Inf   ->  Infinity

-- 2004.08.02 754r chooses number over NaN in mixed cases
ddmxg141 maxmag  NaN -Inf    -> -Infinity
ddmxg142 maxmag  NaN -1000   -> -1000
ddmxg143 maxmag  NaN -1      -> -1
ddmxg144 maxmag  NaN -0      -> -0
ddmxg145 maxmag  NaN  0      ->  0
ddmxg146 maxmag  NaN  1      ->  1
ddmxg147 maxmag  NaN  1000   ->  1000
ddmxg148 maxmag  NaN  Inf    ->  Infinity
ddmxg149 maxmag  NaN  NaN    ->  NaN
ddmxg150 maxmag -Inf  NaN    -> -Infinity
ddmxg151 maxmag -1000 NaN    -> -1000
ddmxg152 maxmag -1    NaN    -> -1
ddmxg153 maxmag -0    NaN    -> -0
ddmxg154 maxmag  0    NaN    ->  0
ddmxg155 maxmag  1    NaN    ->  1
ddmxg156 maxmag  1000 NaN    ->  1000
ddmxg157 maxmag  Inf  NaN    ->  Infinity

ddmxg161 maxmag  sNaN -Inf   ->  NaN  Invalid_operation
ddmxg162 maxmag  sNaN -1000  ->  NaN  Invalid_operation
ddmxg163 maxmag  sNaN -1     ->  NaN  Invalid_operation
ddmxg164 maxmag  sNaN -0     ->  NaN  Invalid_operation
ddmxg165 maxmag  sNaN  0     ->  NaN  Invalid_operation
ddmxg166 maxmag  sNaN  1     ->  NaN  Invalid_operation
ddmxg167 maxmag  sNaN  1000  ->  NaN  Invalid_operation
ddmxg168 maxmag  sNaN  NaN   ->  NaN  Invalid_operation
ddmxg169 maxmag  sNaN sNaN   ->  NaN  Invalid_operation
ddmxg170 maxmag  NaN  sNaN   ->  NaN  Invalid_operation
ddmxg171 maxmag -Inf  sNaN   ->  NaN  Invalid_operation
ddmxg172 maxmag -1000 sNaN   ->  NaN  Invalid_operation
ddmxg173 maxmag -1    sNaN   ->  NaN  Invalid_operation
ddmxg174 maxmag -0    sNaN   ->  NaN  Invalid_operation
ddmxg175 maxmag  0    sNaN   ->  NaN  Invalid_operation
ddmxg176 maxmag  1    sNaN   ->  NaN  Invalid_operation
ddmxg177 maxmag  1000 sNaN   ->  NaN  Invalid_operation
ddmxg178 maxmag  Inf  sNaN   ->  NaN  Invalid_operation
ddmxg179 maxmag  NaN  sNaN   ->  NaN  Invalid_operation

-- propagating NaNs
ddmxg181 maxmag  NaN9  -Inf   -> -Infinity
ddmxg182 maxmag  NaN8     9   ->  9
ddmxg183 maxmag -NaN7   Inf   ->  Infinity

ddmxg184 maxmag -NaN1   NaN11 -> -NaN1
ddmxg185 maxmag  NaN2   NaN12 ->  NaN2
ddmxg186 maxmag -NaN13 -NaN7  -> -NaN13
ddmxg187 maxmag  NaN14 -NaN5  ->  NaN14

ddmxg188 maxmag -Inf    NaN4  -> -Infinity
ddmxg189 maxmag -9     -NaN3  -> -9
ddmxg190 maxmag  Inf    NaN2  ->  Infinity

ddmxg191 maxmag  sNaN99 -Inf    ->  NaN99 Invalid_operation
ddmxg192 maxmag  sNaN98 -1      ->  NaN98 Invalid_operation
ddmxg193 maxmag -sNaN97  NaN    -> -NaN97 Invalid_operation
ddmxg194 maxmag  sNaN96 sNaN94  ->  NaN96 Invalid_operation
ddmxg195 maxmag  NaN95  sNaN93  ->  NaN93 Invalid_operation
ddmxg196 maxmag -Inf    sNaN92  ->  NaN92 Invalid_operation
ddmxg197 maxmag  0      sNaN91  ->  NaN91 Invalid_operation
ddmxg198 maxmag  Inf   -sNaN90  -> -NaN90 Invalid_operation
ddmxg199 maxmag  NaN    sNaN89  ->  NaN89 Invalid_operation

-- old rounding checks
ddmxg221 maxmag 12345678000 1  -> 12345678000
ddmxg222 maxmag 1 12345678000  -> 12345678000
ddmxg223 maxmag 1234567800  1  -> 1234567800
ddmxg224 maxmag 1 1234567800   -> 1234567800
ddmxg225 maxmag 1234567890  1  -> 1234567890
ddmxg226 maxmag 1 1234567890   -> 1234567890
ddmxg227 maxmag 1234567891  1  -> 1234567891
ddmxg228 maxmag 1 1234567891   -> 1234567891
ddmxg229 maxmag 12345678901 1  -> 12345678901
ddmxg230 maxmag 1 12345678901  -> 12345678901
ddmxg231 maxmag 1234567896  1  -> 1234567896
ddmxg232 maxmag 1 1234567896   -> 1234567896
ddmxg233 maxmag -1234567891  1 -> -1234567891
ddmxg234 maxmag 1 -1234567891  -> -1234567891
ddmxg235 maxmag -12345678901 1 -> -12345678901
ddmxg236 maxmag 1 -12345678901 -> -12345678901
ddmxg237 maxmag -1234567896  1 -> -1234567896
ddmxg238 maxmag 1 -1234567896  -> -1234567896

-- from examples
ddmxg280 maxmag '3'   '2'  ->  '3'
ddmxg281 maxmag '-10' '3'  ->  '-10'
ddmxg282 maxmag '1.0' '1'  ->  '1'
ddmxg283 maxmag '1' '1.0'  ->  '1'
ddmxg284 maxmag '7' 'NaN'  ->  '7'

-- expanded list from min/max 754r purple prose
-- [explicit tests for exponent ordering]
ddmxg401 maxmag  Inf    1.1     ->  Infinity
ddmxg402 maxmag  1.1    1       ->  1.1
ddmxg403 maxmag  1      1.0     ->  1
ddmxg404 maxmag  1.0    0.1     ->  1.0
ddmxg405 maxmag  0.1    0.10    ->  0.1
ddmxg406 maxmag  0.10   0.100   ->  0.10
ddmxg407 maxmag  0.10   0       ->  0.10
ddmxg408 maxmag  0      0.0     ->  0
ddmxg409 maxmag  0.0   -0       ->  0.0
ddmxg410 maxmag  0.0   -0.0     ->  0.0
ddmxg411 maxmag  0.00  -0.0     ->  0.00
ddmxg412 maxmag  0.0   -0.00    ->  0.0
ddmxg413 maxmag  0     -0.0     ->  0
ddmxg414 maxmag  0     -0       ->  0
ddmxg415 maxmag -0.0   -0       -> -0.0
ddmxg416 maxmag -0     -0.100   -> -0.100
ddmxg417 maxmag -0.100 -0.10    -> -0.100
ddmxg418 maxmag -0.10  -0.1     -> -0.10
ddmxg419 maxmag -0.1   -1.0     -> -1.0
ddmxg420 maxmag -1.0   -1       -> -1.0
ddmxg421 maxmag -1     -1.1     -> -1.1
ddmxg423 maxmag -1.1   -Inf     -> -Infinity
-- same with operands reversed
ddmxg431 maxmag  1.1    Inf     ->  Infinity
ddmxg432 maxmag  1      1.1     ->  1.1
ddmxg433 maxmag  1.0    1       ->  1
ddmxg434 maxmag  0.1    1.0     ->  1.0
ddmxg435 maxmag  0.10   0.1     ->  0.1
ddmxg436 maxmag  0.100  0.10    ->  0.10
ddmxg437 maxmag  0      0.10    ->  0.10
ddmxg438 maxmag  0.0    0       ->  0
ddmxg439 maxmag -0      0.0     ->  0.0
ddmxg440 maxmag -0.0    0.0     ->  0.0
ddmxg441 maxmag -0.0    0.00    ->  0.00
ddmxg442 maxmag -0.00   0.0     ->  0.0
ddmxg443 maxmag -0.0    0       ->  0
ddmxg444 maxmag -0      0       ->  0
ddmxg445 maxmag -0     -0.0     -> -0.0
ddmxg446 maxmag -0.100 -0       -> -0.100
ddmxg447 maxmag -0.10  -0.100   -> -0.100
ddmxg448 maxmag -0.1   -0.10    -> -0.10
ddmxg449 maxmag -1.0   -0.1     -> -1.0
ddmxg450 maxmag -1     -1.0     -> -1.0
ddmxg451 maxmag -1.1   -1       -> -1.1
ddmxg453 maxmag -Inf   -1.1     -> -Infinity
-- largies
ddmxg460 maxmag  1000   1E+3    ->  1E+3
ddmxg461 maxmag  1E+3   1000    ->  1E+3
ddmxg462 maxmag  1000  -1E+3    ->  1000
ddmxg463 maxmag  1E+3  -1000    ->  1E+3
ddmxg464 maxmag -1000   1E+3    ->  1E+3
ddmxg465 maxmag -1E+3   1000    ->  1000
ddmxg466 maxmag -1000  -1E+3    -> -1000
ddmxg467 maxmag -1E+3  -1000    -> -1000

-- subnormals
ddmxg510 maxmag  1.00E-383       0  ->   1.00E-383
ddmxg511 maxmag  0.1E-383        0  ->   1E-384    Subnormal
ddmxg512 maxmag  0.10E-383       0  ->   1.0E-384  Subnormal
ddmxg513 maxmag  0.100E-383      0  ->   1.00E-384 Subnormal
ddmxg514 maxmag  0.01E-383       0  ->   1E-385    Subnormal
ddmxg515 maxmag  0.999E-383      0  ->   9.99E-384 Subnormal
ddmxg516 maxmag  0.099E-383      0  ->   9.9E-385  Subnormal
ddmxg517 maxmag  0.009E-383      0  ->   9E-386    Subnormal
ddmxg518 maxmag  0.001E-383      0  ->   1E-386    Subnormal
ddmxg519 maxmag  0.0009E-383     0  ->   9E-387    Subnormal
ddmxg520 maxmag  0.0001E-383     0  ->   1E-387    Subnormal

ddmxg530 maxmag -1.00E-383       0  ->  -1.00E-383
ddmxg531 maxmag -0.1E-383        0  ->  -1E-384    Subnormal
ddmxg532 maxmag -0.10E-383       0  ->  -1.0E-384  Subnormal
ddmxg533 maxmag -0.100E-383      0  ->  -1.00E-384 Subnormal
ddmxg534 maxmag -0.01E-383       0  ->  -1E-385    Subnormal
ddmxg535 maxmag -0.999E-383      0  ->  -9.99E-384 Subnormal
ddmxg536 maxmag -0.099E-383      0  ->  -9.9E-385  Subnormal
ddmxg537 maxmag -0.009E-383      0  ->  -9E-386    Subnormal
ddmxg538 maxmag -0.001E-383      0  ->  -1E-386    Subnormal
ddmxg539 maxmag -0.0009E-383     0  ->  -9E-387    Subnormal
ddmxg540 maxmag -0.0001E-383     0  ->  -1E-387    Subnormal

-- Null tests
ddmxg900 maxmag 10  #  -> NaN Invalid_operation
ddmxg901 maxmag  # 10  -> NaN Invalid_operation