more pow(0,-inf) fixes
[libc-test] / src / math / ucb / floor.h
1 // Copyright (C) 1988-1994 Sun Microsystems, Inc. 2550 Garcia Avenue
2 // Mountain View, California  94043 All rights reserved.
3 //
4 // Any person is hereby authorized to download, copy, use, create bug fixes,
5 // and distribute, subject to the following conditions:
6 //
7 //      1.  the software may not be redistributed for a fee except as
8 //          reasonable to cover media costs;
9 //      2.  any copy of the software must include this notice, as well as
10 //          any other embedded copyright notices; and
11 //      3.  any distribution of this software or derivative works thereof
12 //          must comply with all applicable U.S. export control laws.
13 //
14 // THE SOFTWARE IS MADE AVAILABLE "AS IS" AND WITHOUT EXPRESS OR IMPLIED
15 // WARRANTY OF ANY KIND, INCLUDING BUT NOT LIMITED TO THE IMPLIED
16 // WARRANTIES OF DESIGN, MERCHANTIBILITY, FITNESS FOR A PARTICULAR
17 // PURPOSE, NON-INFRINGEMENT, PERFORMANCE OR CONFORMANCE TO
18 // SPECIFICATIONS.
19 //
20 // BY DOWNLOADING AND/OR USING THIS SOFTWARE, THE USER WAIVES ALL CLAIMS
21 // AGAINST SUN MICROSYSTEMS, INC. AND ITS AFFILIATED COMPANIES IN ANY
22 // JURISDICTION, INCLUDING BUT NOT LIMITED TO CLAIMS FOR DAMAGES OR
23 // EQUITABLE RELIEF BASED ON LOSS OF DATA, AND SPECIFICALLY WAIVES EVEN
24 // UNKNOWN OR UNANTICIPATED CLAIMS OR LOSSES, PRESENT AND FUTURE.
25 //
26 // IN NO EVENT WILL SUN MICROSYSTEMS, INC. OR ANY OF ITS AFFILIATED
27 // COMPANIES BE LIABLE FOR ANY LOST REVENUE OR PROFITS OR OTHER SPECIAL,
28 // INDIRECT AND CONSEQUENTIAL DAMAGES, EVEN IF IT HAS BEEN ADVISED OF THE
29 // POSSIBILITY OF SUCH DAMAGES.
30 //
31 // This file is provided with no support and without any obligation on the
32 // part of Sun Microsystems, Inc. ("Sun") or any of its affiliated
33 // companies to assist in its use, correction, modification or
34 // enhancement.  Nevertheless, and without creating any obligation on its
35 // part, Sun welcomes your comments concerning the software and requests
36 // that they be sent to fdlibm-comments@sunpro.sun.com.
37 // floord(integer) is itself
38 T(RN,                  0x0p+0,                  0x0p+0,          0x0p+0, 0)
39 T(RN,                 -0x0p+0,                 -0x0p+0,          0x0p+0, 0)
40 T(RN,                  0x1p+0,                  0x1p+0,          0x0p+0, 0)
41 T(RN,                 -0x1p+0,                 -0x1p+0,          0x0p+0, 0)
42 T(RN,   0x1.fffffffffffffp+52,   0x1.fffffffffffffp+52,          0x0p+0, 0)
43 T(RN,  -0x1.fffffffffffffp+52,  -0x1.fffffffffffffp+52,          0x0p+0, 0)
44 T(RN, 0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+1023,          0x0p+0, 0)
45 T(RN,-0x1.fffffffffffffp+1023,-0x1.fffffffffffffp+1023,          0x0p+0, 0)
46 T(RZ,                  0x0p+0,                  0x0p+0,          0x0p+0, 0)
47 T(RZ,                 -0x0p+0,                 -0x0p+0,          0x0p+0, 0)
48 T(RZ,                  0x1p+0,                  0x1p+0,          0x0p+0, 0)
49 T(RZ,                 -0x1p+0,                 -0x1p+0,          0x0p+0, 0)
50 T(RZ,   0x1.fffffffffffffp+52,   0x1.fffffffffffffp+52,          0x0p+0, 0)
51 T(RZ,  -0x1.fffffffffffffp+52,  -0x1.fffffffffffffp+52,          0x0p+0, 0)
52 T(RZ, 0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+1023,          0x0p+0, 0)
53 T(RZ,-0x1.fffffffffffffp+1023,-0x1.fffffffffffffp+1023,          0x0p+0, 0)
54 T(RU,                  0x0p+0,                  0x0p+0,          0x0p+0, 0)
55 T(RU,                 -0x0p+0,                 -0x0p+0,          0x0p+0, 0)
56 T(RU,                  0x1p+0,                  0x1p+0,          0x0p+0, 0)
57 T(RU,                 -0x1p+0,                 -0x1p+0,          0x0p+0, 0)
58 T(RU,   0x1.fffffffffffffp+52,   0x1.fffffffffffffp+52,          0x0p+0, 0)
59 T(RU,  -0x1.fffffffffffffp+52,  -0x1.fffffffffffffp+52,          0x0p+0, 0)
60 T(RU, 0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+1023,          0x0p+0, 0)
61 T(RU,-0x1.fffffffffffffp+1023,-0x1.fffffffffffffp+1023,          0x0p+0, 0)
62 T(RD,                  0x0p+0,                  0x0p+0,          0x0p+0, 0)
63 T(RD,                 -0x0p+0,                 -0x0p+0,          0x0p+0, 0)
64 T(RD,                  0x1p+0,                  0x1p+0,          0x0p+0, 0)
65 T(RD,                 -0x1p+0,                 -0x1p+0,          0x0p+0, 0)
66 T(RD,   0x1.fffffffffffffp+52,   0x1.fffffffffffffp+52,          0x0p+0, 0)
67 T(RD,  -0x1.fffffffffffffp+52,  -0x1.fffffffffffffp+52,          0x0p+0, 0)
68 T(RD, 0x1.fffffffffffffp+1023, 0x1.fffffffffffffp+1023,          0x0p+0, 0)
69 T(RD,-0x1.fffffffffffffp+1023,-0x1.fffffffffffffp+1023,          0x0p+0, 0)
70 // integer - ulp
71 T(RN,   0x1.eeeeeeeeeeeefp+50,   0x1.eeeeeeeeeeeecp+50,          0x0p+0, INEXACT)
72 T(RN,  -0x1.eeeeeeeeeeeefp+50,   -0x1.eeeeeeeeeeefp+50,          0x0p+0, INEXACT)
73 T(RN,    0x1.fffffffffffffp+0,                  0x1p+0,          0x0p+0, INEXACT)
74 T(RN,   -0x1.fffffffffffffp+0,                 -0x1p+1,          0x0p+0, INEXACT)
75 T(RN,    0x1.fffffffffffffp-1,                  0x0p+0,          0x0p+0, INEXACT)
76 T(RN,   -0x1.fffffffffffffp-1,                 -0x1p+0,          0x0p+0, INEXACT)
77 T(RZ,   0x1.eeeeeeeeeeeefp+50,   0x1.eeeeeeeeeeeecp+50,          0x0p+0, INEXACT)
78 T(RZ,  -0x1.eeeeeeeeeeeefp+50,   -0x1.eeeeeeeeeeefp+50,          0x0p+0, INEXACT)
79 T(RZ,    0x1.fffffffffffffp+0,                  0x1p+0,          0x0p+0, INEXACT)
80 T(RZ,   -0x1.fffffffffffffp+0,                 -0x1p+1,          0x0p+0, INEXACT)
81 T(RZ,    0x1.fffffffffffffp-1,                  0x0p+0,          0x0p+0, INEXACT)
82 T(RZ,   -0x1.fffffffffffffp-1,                 -0x1p+0,          0x0p+0, INEXACT)
83 T(RU,   0x1.eeeeeeeeeeeefp+50,   0x1.eeeeeeeeeeeecp+50,          0x0p+0, INEXACT)
84 T(RU,  -0x1.eeeeeeeeeeeefp+50,   -0x1.eeeeeeeeeeefp+50,          0x0p+0, INEXACT)
85 T(RU,    0x1.fffffffffffffp+0,                  0x1p+0,          0x0p+0, INEXACT)
86 T(RU,   -0x1.fffffffffffffp+0,                 -0x1p+1,          0x0p+0, INEXACT)
87 T(RU,    0x1.fffffffffffffp-1,                  0x0p+0,          0x0p+0, INEXACT)
88 T(RU,   -0x1.fffffffffffffp-1,                 -0x1p+0,          0x0p+0, INEXACT)
89 T(RD,   0x1.eeeeeeeeeeeefp+50,   0x1.eeeeeeeeeeeecp+50,          0x0p+0, INEXACT)
90 T(RD,  -0x1.eeeeeeeeeeeefp+50,   -0x1.eeeeeeeeeeefp+50,          0x0p+0, INEXACT)
91 T(RD,    0x1.fffffffffffffp+0,                  0x1p+0,          0x0p+0, INEXACT)
92 T(RD,   -0x1.fffffffffffffp+0,                 -0x1p+1,          0x0p+0, INEXACT)
93 T(RD,    0x1.fffffffffffffp-1,                  0x0p+0,          0x0p+0, INEXACT)
94 T(RD,   -0x1.fffffffffffffp-1,                 -0x1p+0,          0x0p+0, INEXACT)
95 // integer + ulp
96 T(RN,   0x1.eeeeeeeeeeeedp+50,   0x1.eeeeeeeeeeeecp+50,          0x0p+0, INEXACT)
97 T(RN,  -0x1.eeeeeeeeeeeedp+50,   -0x1.eeeeeeeeeeefp+50,          0x0p+0, INEXACT)
98 T(RN,    0x1.0000000000001p+0,                  0x1p+0,          0x0p+0, INEXACT)
99 T(RN,   -0x1.0000000000001p+0,                 -0x1p+1,          0x0p+0, INEXACT)
100 T(RN,               0x1p-1022,                  0x0p+0,          0x0p+0, INEXACT)
101 T(RN,              -0x1p-1022,                 -0x1p+0,          0x0p+0, INEXACT)
102 T(RZ,   0x1.eeeeeeeeeeeedp+50,   0x1.eeeeeeeeeeeecp+50,          0x0p+0, INEXACT)
103 T(RZ,  -0x1.eeeeeeeeeeeedp+50,   -0x1.eeeeeeeeeeefp+50,          0x0p+0, INEXACT)
104 T(RZ,    0x1.0000000000001p+0,                  0x1p+0,          0x0p+0, INEXACT)
105 T(RZ,   -0x1.0000000000001p+0,                 -0x1p+1,          0x0p+0, INEXACT)
106 T(RZ,               0x1p-1022,                  0x0p+0,          0x0p+0, INEXACT)
107 T(RZ,              -0x1p-1022,                 -0x1p+0,          0x0p+0, INEXACT)
108 T(RU,   0x1.eeeeeeeeeeeedp+50,   0x1.eeeeeeeeeeeecp+50,          0x0p+0, INEXACT)
109 T(RU,  -0x1.eeeeeeeeeeeedp+50,   -0x1.eeeeeeeeeeefp+50,          0x0p+0, INEXACT)
110 T(RU,    0x1.0000000000001p+0,                  0x1p+0,          0x0p+0, INEXACT)
111 T(RU,   -0x1.0000000000001p+0,                 -0x1p+1,          0x0p+0, INEXACT)
112 T(RU,               0x1p-1022,                  0x0p+0,          0x0p+0, INEXACT)
113 T(RU,              -0x1p-1022,                 -0x1p+0,          0x0p+0, INEXACT)
114 T(RD,   0x1.eeeeeeeeeeeedp+50,   0x1.eeeeeeeeeeeecp+50,          0x0p+0, INEXACT)
115 T(RD,  -0x1.eeeeeeeeeeeedp+50,   -0x1.eeeeeeeeeeefp+50,          0x0p+0, INEXACT)
116 T(RD,    0x1.0000000000001p+0,                  0x1p+0,          0x0p+0, INEXACT)
117 T(RD,   -0x1.0000000000001p+0,                 -0x1p+1,          0x0p+0, INEXACT)
118 T(RD,               0x1p-1022,                  0x0p+0,          0x0p+0, INEXACT)
119 T(RD,              -0x1p-1022,                 -0x1p+0,          0x0p+0, INEXACT)
120 //  half way case, half way case +- ulp
121 T(RN,    0x1.fffffffffffffp-2,                  0x0p+0,          0x0p+0, INEXACT)
122 T(RN,                  0x1p-1,                  0x0p+0,          0x0p+0, INEXACT)
123 T(RN,    0x1.0000000000001p-1,                  0x0p+0,          0x0p+0, INEXACT)
124 T(RN,   -0x1.fffffffffffffp-2,                 -0x1p+0,          0x0p+0, INEXACT)
125 T(RN,                 -0x1p-1,                 -0x1p+0,          0x0p+0, INEXACT)
126 T(RN,   -0x1.0000000000001p-1,                 -0x1p+0,          0x0p+0, INEXACT)
127 T(RN,    0x1.7ffffffffffffp+0,                  0x1p+0,          0x0p+0, INEXACT)
128 T(RN,                0x1.8p+0,                  0x1p+0,          0x0p+0, INEXACT)
129 T(RN,    0x1.8000000000001p+0,                  0x1p+0,          0x0p+0, INEXACT)
130 T(RN,   -0x1.7ffffffffffffp+0,                 -0x1p+1,          0x0p+0, INEXACT)
131 T(RN,               -0x1.8p+0,                 -0x1p+1,          0x0p+0, INEXACT)
132 T(RN,   -0x1.8000000000001p+0,                 -0x1p+1,          0x0p+0, INEXACT)
133 T(RN,    0x1.3ffffffffffffp+1,                  0x1p+1,          0x0p+0, INEXACT)
134 T(RN,                0x1.4p+1,                  0x1p+1,          0x0p+0, INEXACT)
135 T(RN,    0x1.4000000000001p+1,                  0x1p+1,          0x0p+0, INEXACT)
136 T(RN,   -0x1.3ffffffffffffp+1,               -0x1.8p+1,          0x0p+0, INEXACT)
137 T(RN,               -0x1.4p+1,               -0x1.8p+1,          0x0p+0, INEXACT)
138 T(RN,   -0x1.4000000000001p+1,               -0x1.8p+1,          0x0p+0, INEXACT)
139 T(RN,   0x1.eeeeeeeeeeee7p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
140 T(RN,   0x1.eeeeeeeeeeee8p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
141 T(RN,   0x1.eeeeeeeeeeee9p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
142 T(RN,  -0x1.eeeeeeeeeeee7p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
143 T(RN,  -0x1.eeeeeeeeeeee8p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
144 T(RN,  -0x1.eeeeeeeeeeee9p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
145 T(RZ,    0x1.fffffffffffffp-2,                  0x0p+0,          0x0p+0, INEXACT)
146 T(RZ,                  0x1p-1,                  0x0p+0,          0x0p+0, INEXACT)
147 T(RZ,    0x1.0000000000001p-1,                  0x0p+0,          0x0p+0, INEXACT)
148 T(RZ,   -0x1.fffffffffffffp-2,                 -0x1p+0,          0x0p+0, INEXACT)
149 T(RZ,                 -0x1p-1,                 -0x1p+0,          0x0p+0, INEXACT)
150 T(RZ,   -0x1.0000000000001p-1,                 -0x1p+0,          0x0p+0, INEXACT)
151 T(RZ,    0x1.7ffffffffffffp+0,                  0x1p+0,          0x0p+0, INEXACT)
152 T(RZ,                0x1.8p+0,                  0x1p+0,          0x0p+0, INEXACT)
153 T(RZ,    0x1.8000000000001p+0,                  0x1p+0,          0x0p+0, INEXACT)
154 T(RZ,   -0x1.7ffffffffffffp+0,                 -0x1p+1,          0x0p+0, INEXACT)
155 T(RZ,               -0x1.8p+0,                 -0x1p+1,          0x0p+0, INEXACT)
156 T(RZ,   -0x1.8000000000001p+0,                 -0x1p+1,          0x0p+0, INEXACT)
157 T(RZ,    0x1.3ffffffffffffp+1,                  0x1p+1,          0x0p+0, INEXACT)
158 T(RZ,                0x1.4p+1,                  0x1p+1,          0x0p+0, INEXACT)
159 T(RZ,    0x1.4000000000001p+1,                  0x1p+1,          0x0p+0, INEXACT)
160 T(RZ,   -0x1.3ffffffffffffp+1,               -0x1.8p+1,          0x0p+0, INEXACT)
161 T(RZ,               -0x1.4p+1,               -0x1.8p+1,          0x0p+0, INEXACT)
162 T(RZ,   -0x1.4000000000001p+1,               -0x1.8p+1,          0x0p+0, INEXACT)
163 T(RZ,   0x1.eeeeeeeeeeee7p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
164 T(RZ,   0x1.eeeeeeeeeeee8p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
165 T(RZ,   0x1.eeeeeeeeeeee9p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
166 T(RZ,  -0x1.eeeeeeeeeeee7p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
167 T(RZ,  -0x1.eeeeeeeeeeee8p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
168 T(RZ,  -0x1.eeeeeeeeeeee9p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
169 T(RU,    0x1.fffffffffffffp-2,                  0x0p+0,          0x0p+0, INEXACT)
170 T(RU,                  0x1p-1,                  0x0p+0,          0x0p+0, INEXACT)
171 T(RU,    0x1.0000000000001p-1,                  0x0p+0,          0x0p+0, INEXACT)
172 T(RU,   -0x1.fffffffffffffp-2,                 -0x1p+0,          0x0p+0, INEXACT)
173 T(RU,                 -0x1p-1,                 -0x1p+0,          0x0p+0, INEXACT)
174 T(RU,   -0x1.0000000000001p-1,                 -0x1p+0,          0x0p+0, INEXACT)
175 T(RU,    0x1.7ffffffffffffp+0,                  0x1p+0,          0x0p+0, INEXACT)
176 T(RU,                0x1.8p+0,                  0x1p+0,          0x0p+0, INEXACT)
177 T(RU,    0x1.8000000000001p+0,                  0x1p+0,          0x0p+0, INEXACT)
178 T(RU,   -0x1.7ffffffffffffp+0,                 -0x1p+1,          0x0p+0, INEXACT)
179 T(RU,               -0x1.8p+0,                 -0x1p+1,          0x0p+0, INEXACT)
180 T(RU,   -0x1.8000000000001p+0,                 -0x1p+1,          0x0p+0, INEXACT)
181 T(RU,    0x1.3ffffffffffffp+1,                  0x1p+1,          0x0p+0, INEXACT)
182 T(RU,                0x1.4p+1,                  0x1p+1,          0x0p+0, INEXACT)
183 T(RU,    0x1.4000000000001p+1,                  0x1p+1,          0x0p+0, INEXACT)
184 T(RU,   -0x1.3ffffffffffffp+1,               -0x1.8p+1,          0x0p+0, INEXACT)
185 T(RU,               -0x1.4p+1,               -0x1.8p+1,          0x0p+0, INEXACT)
186 T(RU,   -0x1.4000000000001p+1,               -0x1.8p+1,          0x0p+0, INEXACT)
187 T(RU,   0x1.eeeeeeeeeeee7p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
188 T(RU,   0x1.eeeeeeeeeeee8p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
189 T(RU,   0x1.eeeeeeeeeeee9p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
190 T(RU,  -0x1.eeeeeeeeeeee7p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
191 T(RU,  -0x1.eeeeeeeeeeee8p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
192 T(RU,  -0x1.eeeeeeeeeeee9p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
193 T(RD,    0x1.fffffffffffffp-2,                  0x0p+0,          0x0p+0, INEXACT)
194 T(RD,                  0x1p-1,                  0x0p+0,          0x0p+0, INEXACT)
195 T(RD,    0x1.0000000000001p-1,                  0x0p+0,          0x0p+0, INEXACT)
196 T(RD,   -0x1.fffffffffffffp-2,                 -0x1p+0,          0x0p+0, INEXACT)
197 T(RD,                 -0x1p-1,                 -0x1p+0,          0x0p+0, INEXACT)
198 T(RD,   -0x1.0000000000001p-1,                 -0x1p+0,          0x0p+0, INEXACT)
199 T(RD,    0x1.7ffffffffffffp+0,                  0x1p+0,          0x0p+0, INEXACT)
200 T(RD,                0x1.8p+0,                  0x1p+0,          0x0p+0, INEXACT)
201 T(RD,    0x1.8000000000001p+0,                  0x1p+0,          0x0p+0, INEXACT)
202 T(RD,   -0x1.7ffffffffffffp+0,                 -0x1p+1,          0x0p+0, INEXACT)
203 T(RD,               -0x1.8p+0,                 -0x1p+1,          0x0p+0, INEXACT)
204 T(RD,   -0x1.8000000000001p+0,                 -0x1p+1,          0x0p+0, INEXACT)
205 T(RD,    0x1.3ffffffffffffp+1,                  0x1p+1,          0x0p+0, INEXACT)
206 T(RD,                0x1.4p+1,                  0x1p+1,          0x0p+0, INEXACT)
207 T(RD,    0x1.4000000000001p+1,                  0x1p+1,          0x0p+0, INEXACT)
208 T(RD,   -0x1.3ffffffffffffp+1,               -0x1.8p+1,          0x0p+0, INEXACT)
209 T(RD,               -0x1.4p+1,               -0x1.8p+1,          0x0p+0, INEXACT)
210 T(RD,   -0x1.4000000000001p+1,               -0x1.8p+1,          0x0p+0, INEXACT)
211 T(RD,   0x1.eeeeeeeeeeee7p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
212 T(RD,   0x1.eeeeeeeeeeee8p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
213 T(RD,   0x1.eeeeeeeeeeee9p+48,    0x1.eeeeeeeeeeeep+48,          0x0p+0, INEXACT)
214 T(RD,  -0x1.eeeeeeeeeeee7p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
215 T(RD,  -0x1.eeeeeeeeeeee8p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
216 T(RD,  -0x1.eeeeeeeeeeee9p+48,   -0x1.eeeeeeeeeeefp+48,          0x0p+0, INEXACT)
217 // random arguments between -100,100
218 T(RN,   -0x1.adeefb2b5006dp+3,               -0x1.cp+3,          0x0p+0, INEXACT)
219 T(RN,    0x1.1ce3efb825911p+5,               0x1.18p+5,          0x0p+0, INEXACT)
220 T(RN,    0x1.602e109de7505p+5,                0x1.6p+5,          0x0p+0, INEXACT)
221 T(RN,   -0x1.0b245fba96889p+5,               -0x1.1p+5,          0x0p+0, INEXACT)
222 T(RN,   -0x1.b171ee27084ddp+3,               -0x1.cp+3,          0x0p+0, INEXACT)
223 T(RN,   -0x1.f6eff1b093c41p+0,                 -0x1p+1,          0x0p+0, INEXACT)
224 T(RN,    0x1.ceaa3d18455f5p+4,                0x1.cp+4,          0x0p+0, INEXACT)
225 T(RN,    0x1.560914a51b239p+5,                0x1.5p+5,          0x0p+0, INEXACT)
226 T(RN,   -0x1.0ce901079de4dp+3,               -0x1.2p+3,          0x0p+0, INEXACT)
227 T(RN,   -0x1.7f35b3103b871p+5,               -0x1.8p+5,          0x0p+0, INEXACT)
228 // inf,nan, and subnormal number
229 T(RN,               0x1p-1074,                  0x0p+0,          0x0p+0, INEXACT)
230 T(RN,              -0x1p-1074,                 -0x1p+0,          0x0p+0, INEXACT)
231 T(RN,                     inf,                     inf,          0x0p+0, 0)
232 T(RN,                    -inf,                    -inf,          0x0p+0, 0)
233 T(RN,                     nan,                     nan,          0x0p+0, 0)
234 T(RZ,               0x1p-1074,                  0x0p+0,          0x0p+0, INEXACT)
235 T(RZ,              -0x1p-1074,                 -0x1p+0,          0x0p+0, INEXACT)
236 T(RZ,                     inf,                     inf,          0x0p+0, 0)
237 T(RZ,                    -inf,                    -inf,          0x0p+0, 0)
238 T(RZ,                     nan,                     nan,          0x0p+0, 0)
239 T(RU,               0x1p-1074,                  0x0p+0,          0x0p+0, INEXACT)
240 T(RU,              -0x1p-1074,                 -0x1p+0,          0x0p+0, INEXACT)
241 T(RU,                     inf,                     inf,          0x0p+0, 0)
242 T(RU,                    -inf,                    -inf,          0x0p+0, 0)
243 T(RU,                     nan,                     nan,          0x0p+0, 0)
244 T(RD,               0x1p-1074,                  0x0p+0,          0x0p+0, INEXACT)
245 T(RD,              -0x1p-1074,                 -0x1p+0,          0x0p+0, INEXACT)
246 T(RD,                     inf,                     inf,          0x0p+0, 0)
247 T(RD,                    -inf,                    -inf,          0x0p+0, 0)
248 T(RD,                     nan,                     nan,          0x0p+0, 0)
249 T(RD,               0x1.2p+12,               0x1.2p+12,          0x0p+0, 0)
250 T(RD,                 0x1p+23,                 0x1p+23,          0x0p+0, 0)
251 T(RD,   0x1.ffffffffffffep+51,   0x1.ffffffffffffep+51,          0x0p+0, 0)
252 T(RD,                 0x1p+52,                 0x1p+52,          0x0p+0, 0)
253 T(RD,   0x1.0000000000001p+52,   0x1.0000000000001p+52,          0x0p+0, 0)
254 T(RD, 0x1.fffffffffffeep+1014, 0x1.fffffffffffeep+1014,          0x0p+0, 0)
255 T(RD, 0x1.ffffffffffff7p+1014, 0x1.ffffffffffff7p+1014,          0x0p+0, 0)
256 T(RD, 0x1.fffffffffffffp+1014, 0x1.fffffffffffffp+1014,          0x0p+0, 0)
257 T(RD,               0x1p+1015,               0x1p+1015,          0x0p+0, 0)
258 T(RD,              -0x1.2p+12,              -0x1.2p+12,          0x0p+0, 0)
259 T(RD,                -0x1p+23,                -0x1p+23,          0x0p+0, 0)
260 T(RD,  -0x1.ffffffffffffep+51,  -0x1.ffffffffffffep+51,          0x0p+0, 0)
261 T(RD,                -0x1p+52,                -0x1p+52,          0x0p+0, 0)
262 T(RD,  -0x1.0000000000001p+52,  -0x1.0000000000001p+52,          0x0p+0, 0)
263 T(RD,-0x1.fffffffffffeep+1014,-0x1.fffffffffffeep+1014,          0x0p+0, 0)
264 T(RD,-0x1.ffffffffffff7p+1014,-0x1.ffffffffffff7p+1014,          0x0p+0, 0)
265 T(RD,-0x1.fffffffffffffp+1014,-0x1.fffffffffffffp+1014,          0x0p+0, 0)
266 T(RD,              -0x1p+1015,              -0x1p+1015,          0x0p+0, 0)
267 T(RD, 0x1.ffffffffffffep-1023,                  0x0p+0,          0x0p+0, INEXACT)
268 T(RD,                0x1.ep-1,                  0x0p+0,          0x0p+0, INEXACT)
269 T(RD,                0x1.2p+2,                  0x1p+2,          0x0p+0, INEXACT)
270 T(RD,    0x1.fffffffffffffp+2,                0x1.cp+2,          0x0p+0, INEXACT)
271 T(RD,    0x1.0000000000001p+3,                  0x1p+3,          0x0p+0, INEXACT)
272 T(RD,    0x1.0000000000008p+9,                  0x1p+9,          0x0p+0, INEXACT)
273 T(RD,   0x1.0000000000001p+18,                 0x1p+18,          0x0p+0, INEXACT)
274 T(RD,   0x1.0000000000001p+23,                 0x1p+23,          0x0p+0, INEXACT)
275 T(RD,   0x1.ffffffffffffdp+51,   0x1.ffffffffffffcp+51,          0x0p+0, INEXACT)
276 T(RD,   0x1.fffffffffffffp+51,   0x1.ffffffffffffep+51,          0x0p+0, INEXACT)
277 T(RD,-0x1.ffffffffffffep-1023,                 -0x1p+0,          0x0p+0, INEXACT)
278 T(RD,               -0x1.2p+2,               -0x1.4p+2,          0x0p+0, INEXACT)
279 T(RD,   -0x1.fffffffffffffp+2,                 -0x1p+3,          0x0p+0, INEXACT)
280 T(RD,   -0x1.0000000000001p+3,               -0x1.2p+3,          0x0p+0, INEXACT)
281 T(RD,   -0x1.ffffffffffff8p+8,                 -0x1p+9,          0x0p+0, INEXACT)
282 T(RD,  -0x1.fffffffffffffp+17,                -0x1p+18,          0x0p+0, INEXACT)
283 T(RD,  -0x1.ffffffffffffdp+22,                -0x1p+23,          0x0p+0, INEXACT)
284 T(RD,  -0x1.ffffffffffffep+22,                -0x1p+23,          0x0p+0, INEXACT)
285 T(RD,  -0x1.fffffffffffffp+22,                -0x1p+23,          0x0p+0, INEXACT)
286 T(RD,  -0x1.ffffffffffffdp+51,  -0x1.ffffffffffffep+51,          0x0p+0, INEXACT)
287 T(RD,  -0x1.fffffffffffffp+51,                -0x1p+52,          0x0p+0, INEXACT)
288 T(RD,                     nan,                     nan,          0x0p+0, 0)
289 T(RN,               0x1.2p+12,               0x1.2p+12,          0x0p+0, 0)
290 T(RN,                 0x1p+23,                 0x1p+23,          0x0p+0, 0)
291 T(RN,   0x1.ffffffffffffep+51,   0x1.ffffffffffffep+51,          0x0p+0, 0)
292 T(RN,                 0x1p+52,                 0x1p+52,          0x0p+0, 0)
293 T(RN,   0x1.0000000000001p+52,   0x1.0000000000001p+52,          0x0p+0, 0)
294 T(RN, 0x1.fffffffffffeep+1014, 0x1.fffffffffffeep+1014,          0x0p+0, 0)
295 T(RN, 0x1.ffffffffffff7p+1014, 0x1.ffffffffffff7p+1014,          0x0p+0, 0)
296 T(RN, 0x1.fffffffffffffp+1014, 0x1.fffffffffffffp+1014,          0x0p+0, 0)
297 T(RN,               0x1p+1015,               0x1p+1015,          0x0p+0, 0)
298 T(RN,              -0x1.2p+12,              -0x1.2p+12,          0x0p+0, 0)
299 T(RN,                -0x1p+23,                -0x1p+23,          0x0p+0, 0)
300 T(RN,  -0x1.ffffffffffffep+51,  -0x1.ffffffffffffep+51,          0x0p+0, 0)
301 T(RN,                -0x1p+52,                -0x1p+52,          0x0p+0, 0)
302 T(RN,  -0x1.0000000000001p+52,  -0x1.0000000000001p+52,          0x0p+0, 0)
303 T(RN,-0x1.fffffffffffeep+1014,-0x1.fffffffffffeep+1014,          0x0p+0, 0)
304 T(RN,-0x1.ffffffffffff7p+1014,-0x1.ffffffffffff7p+1014,          0x0p+0, 0)
305 T(RN,-0x1.fffffffffffffp+1014,-0x1.fffffffffffffp+1014,          0x0p+0, 0)
306 T(RN,              -0x1p+1015,              -0x1p+1015,          0x0p+0, 0)
307 T(RN, 0x1.ffffffffffffep-1023,                  0x0p+0,          0x0p+0, INEXACT)
308 T(RN,                0x1.ep-1,                  0x0p+0,          0x0p+0, INEXACT)
309 T(RN,                0x1.2p+2,                  0x1p+2,          0x0p+0, INEXACT)
310 T(RN,    0x1.2000000000001p+2,                  0x1p+2,          0x0p+0, INEXACT)
311 T(RN,    0x1.0000000000001p+3,                  0x1p+3,          0x0p+0, INEXACT)
312 T(RN,    0x1.0000000000008p+9,                  0x1p+9,          0x0p+0, INEXACT)
313 T(RN,   0x1.0000000000001p+18,                 0x1p+18,          0x0p+0, INEXACT)
314 T(RN,   0x1.0000000000001p+23,                 0x1p+23,          0x0p+0, INEXACT)
315 T(RN,   0x1.ffffffffffffdp+51,   0x1.ffffffffffffcp+51,          0x0p+0, INEXACT)
316 T(RN,   0x1.fffffffffffffp+51,   0x1.ffffffffffffep+51,          0x0p+0, INEXACT)
317 T(RN,   -0x1.2000000000001p+2,               -0x1.4p+2,          0x0p+0, INEXACT)
318 T(RN,   -0x1.fffffffffffffp+2,                 -0x1p+3,          0x0p+0, INEXACT)
319 T(RN,   -0x1.ffffffffffff8p+8,                 -0x1p+9,          0x0p+0, INEXACT)
320 T(RN,  -0x1.fffffffffffffp+17,                -0x1p+18,          0x0p+0, INEXACT)
321 T(RN,  -0x1.ffffffffffffdp+22,                -0x1p+23,          0x0p+0, INEXACT)
322 T(RN,  -0x1.ffffffffffffep+22,                -0x1p+23,          0x0p+0, INEXACT)
323 T(RN,  -0x1.fffffffffffffp+22,                -0x1p+23,          0x0p+0, INEXACT)
324 T(RN,  -0x1.ffffffffffffdp+51,  -0x1.ffffffffffffep+51,          0x0p+0, INEXACT)
325 T(RN,  -0x1.fffffffffffffp+51,                -0x1p+52,          0x0p+0, INEXACT)
326 T(RN,                     nan,                     nan,          0x0p+0, 0)
327 T(RU,               0x1.2p+12,               0x1.2p+12,          0x0p+0, 0)
328 T(RU,                 0x1p+23,                 0x1p+23,          0x0p+0, 0)
329 T(RU,   0x1.ffffffffffffep+51,   0x1.ffffffffffffep+51,          0x0p+0, 0)
330 T(RU,                 0x1p+52,                 0x1p+52,          0x0p+0, 0)
331 T(RU,   0x1.0000000000001p+52,   0x1.0000000000001p+52,          0x0p+0, 0)
332 T(RU, 0x1.fffffffffffeep+1014, 0x1.fffffffffffeep+1014,          0x0p+0, 0)
333 T(RU, 0x1.ffffffffffff7p+1014, 0x1.ffffffffffff7p+1014,          0x0p+0, 0)
334 T(RU, 0x1.fffffffffffffp+1014, 0x1.fffffffffffffp+1014,          0x0p+0, 0)
335 T(RU,               0x1p+1015,               0x1p+1015,          0x0p+0, 0)
336 T(RU,              -0x1.2p+12,              -0x1.2p+12,          0x0p+0, 0)
337 T(RU,                -0x1p+23,                -0x1p+23,          0x0p+0, 0)
338 T(RU,  -0x1.ffffffffffffep+51,  -0x1.ffffffffffffep+51,          0x0p+0, 0)
339 T(RU,                -0x1p+52,                -0x1p+52,          0x0p+0, 0)
340 T(RU,  -0x1.0000000000001p+52,  -0x1.0000000000001p+52,          0x0p+0, 0)
341 T(RU,-0x1.fffffffffffeep+1014,-0x1.fffffffffffeep+1014,          0x0p+0, 0)
342 T(RU,-0x1.ffffffffffff7p+1014,-0x1.ffffffffffff7p+1014,          0x0p+0, 0)
343 T(RU,-0x1.fffffffffffffp+1014,-0x1.fffffffffffffp+1014,          0x0p+0, 0)
344 T(RU,              -0x1p+1015,              -0x1p+1015,          0x0p+0, 0)
345 T(RU,                0x1.ep-1,                  0x0p+0,          0x0p+0, INEXACT)
346 T(RU,   0x1.0000000000001p+23,                 0x1p+23,          0x0p+0, INEXACT)
347 T(RU,   0x1.ffffffffffffdp+51,   0x1.ffffffffffffcp+51,          0x0p+0, INEXACT)
348 T(RU,   0x1.fffffffffffffp+51,   0x1.ffffffffffffep+51,          0x0p+0, INEXACT)
349 T(RU,  -0x1.ffffffffffffdp+22,                -0x1p+23,          0x0p+0, INEXACT)
350 T(RU,  -0x1.ffffffffffffep+22,                -0x1p+23,          0x0p+0, INEXACT)
351 T(RU,  -0x1.fffffffffffffp+22,                -0x1p+23,          0x0p+0, INEXACT)
352 T(RU,  -0x1.ffffffffffffdp+51,  -0x1.ffffffffffffep+51,          0x0p+0, INEXACT)
353 T(RU,  -0x1.fffffffffffffp+51,                -0x1p+52,          0x0p+0, INEXACT)
354 T(RU,                     nan,                     nan,          0x0p+0, 0)
355 T(RZ,               0x1.2p+12,               0x1.2p+12,          0x0p+0, 0)
356 T(RZ,                 0x1p+23,                 0x1p+23,          0x0p+0, 0)
357 T(RZ,   0x1.ffffffffffffep+51,   0x1.ffffffffffffep+51,          0x0p+0, 0)
358 T(RZ,                 0x1p+52,                 0x1p+52,          0x0p+0, 0)
359 T(RZ,   0x1.0000000000001p+52,   0x1.0000000000001p+52,          0x0p+0, 0)
360 T(RZ, 0x1.fffffffffffeep+1014, 0x1.fffffffffffeep+1014,          0x0p+0, 0)
361 T(RZ, 0x1.ffffffffffff7p+1014, 0x1.ffffffffffff7p+1014,          0x0p+0, 0)
362 T(RZ, 0x1.fffffffffffffp+1014, 0x1.fffffffffffffp+1014,          0x0p+0, 0)
363 T(RZ,               0x1p+1015,               0x1p+1015,          0x0p+0, 0)
364 T(RZ,              -0x1.2p+12,              -0x1.2p+12,          0x0p+0, 0)
365 T(RZ,                -0x1p+23,                -0x1p+23,          0x0p+0, 0)
366 T(RZ,  -0x1.ffffffffffffep+51,  -0x1.ffffffffffffep+51,          0x0p+0, 0)
367 T(RZ,                -0x1p+52,                -0x1p+52,          0x0p+0, 0)
368 T(RZ,  -0x1.0000000000001p+52,  -0x1.0000000000001p+52,          0x0p+0, 0)
369 T(RZ,-0x1.fffffffffffeep+1014,-0x1.fffffffffffeep+1014,          0x0p+0, 0)
370 T(RZ,-0x1.ffffffffffff7p+1014,-0x1.ffffffffffff7p+1014,          0x0p+0, 0)
371 T(RZ,-0x1.fffffffffffffp+1014,-0x1.fffffffffffffp+1014,          0x0p+0, 0)
372 T(RZ,              -0x1p+1015,              -0x1p+1015,          0x0p+0, 0)
373 T(RZ, 0x1.ffffffffffffep-1023,                  0x0p+0,          0x0p+0, INEXACT)
374 T(RZ,                0x1.ep-1,                  0x0p+0,          0x0p+0, INEXACT)
375 T(RZ,                0x1.2p+2,                  0x1p+2,          0x0p+0, INEXACT)
376 T(RZ,    0x1.fffffffffffffp+2,                0x1.cp+2,          0x0p+0, INEXACT)
377 T(RZ,    0x1.0000000000001p+3,                  0x1p+3,          0x0p+0, INEXACT)
378 T(RZ,    0x1.0000000000008p+9,                  0x1p+9,          0x0p+0, INEXACT)
379 T(RZ,   0x1.0000000000001p+18,                 0x1p+18,          0x0p+0, INEXACT)
380 T(RZ,   0x1.0000000000001p+23,                 0x1p+23,          0x0p+0, INEXACT)
381 T(RZ,   0x1.ffffffffffffdp+51,   0x1.ffffffffffffcp+51,          0x0p+0, INEXACT)
382 T(RZ,   0x1.fffffffffffffp+51,   0x1.ffffffffffffep+51,          0x0p+0, INEXACT)
383 T(RZ,  -0x1.ffffffffffffdp+22,                -0x1p+23,          0x0p+0, INEXACT)
384 T(RZ,  -0x1.ffffffffffffep+22,                -0x1p+23,          0x0p+0, INEXACT)
385 T(RZ,  -0x1.fffffffffffffp+22,                -0x1p+23,          0x0p+0, INEXACT)
386 T(RZ,  -0x1.ffffffffffffdp+51,  -0x1.ffffffffffffep+51,          0x0p+0, INEXACT)
387 T(RZ,  -0x1.fffffffffffffp+51,                -0x1p+52,          0x0p+0, INEXACT)
388 T(RZ,                     nan,                     nan,          0x0p+0, 0)