cosmetic fixups, mainly long lines.
[deliverable/binutils-gdb.git] / gas / flonum-konst.c
CommitLineData
6efd877d
KR
1/* flonum_const.c - Useful Flonum constants
2 Copyright (C) 1987, 1990, 1991, 1992 Free Software Foundation, Inc.
3
4 This file is part of GAS, the GNU Assembler.
5
6 GAS is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
9 any later version.
10
11 GAS is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with GAS; see the file COPYING. If not, write to
d197a7ab 18 the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
6efd877d 19
d197a7ab 20#include <ansidecl.h>
6efd877d
KR
21#include "flonum.h"
22/* JF: I added the last entry to this table, and I'm not
23 sure if its right or not. Could go either way. I wish
24 I really understood this stuff. */
25
26
d197a7ab 27const int table_size_of_flonum_powers_of_ten = 13;
6efd877d
KR
28
29static const LITTLENUM_TYPE zero[] =
30{1};
31
32/***********************************************************************\
33 * *
34 * Warning: the low order bits may be WRONG here. *
35 * I took this from a suspect bc(1) script. *
36 * "minus_X"[] is supposed to be 10^(2^-X) expressed in base 2^16. *
37 * The radix point is just AFTER the highest element of the [] *
38 * *
39 * Because bc rounds DOWN for printing (I think), the lowest *
40 * significance littlenums should probably have 1 added to them. *
41 * *
42 \***********************************************************************/
43
44/* JF: If this equals 6553/(2^16)+39321/(2^32)+... it approaches .1 */
45static const LITTLENUM_TYPE minus_1[] =
46{
d197a7ab 47 39322, 39321, 39321, 39321, 39321, 39321, 39321, 39321, 39321, 39321,
6efd877d
KR
48 39321, 39321, 39321, 39321, 39321, 39321, 39321, 39321, 39321, 6553};
49static const LITTLENUM_TYPE plus_1[] =
50{10};
51
52/* JF: If this equals 655/(2^16) + 23592/(2^32) + ... it approaches .01 */
53static const LITTLENUM_TYPE minus_2[] =
54{
d197a7ab 55 10486, 36700, 62914, 23592, 49807, 10485, 36700, 62914, 23592, 49807,
6efd877d
KR
56 10485, 36700, 62914, 23592, 49807, 10485, 36700, 62914, 23592, 655};
57static const LITTLENUM_TYPE plus_2[] =
58{100};
59
60/* This approaches .0001 */
61static const LITTLENUM_TYPE minus_3[] =
62{
d197a7ab 63 52534, 20027, 37329, 65116, 64067, 60397, 14784, 18979, 33659, 19503,
6efd877d
KR
64 2726, 9542, 629, 2202, 40475, 10590, 4299, 47815, 36280, 6};
65static const LITTLENUM_TYPE plus_3[] =
66{10000};
67
68/* JF: this approaches 1e-8 */
69static const LITTLENUM_TYPE minus_4[] =
70{
d197a7ab 71 22517, 49501, 54293, 19424, 60699, 6716, 24348, 22618, 23904, 21327,
6efd877d
KR
72 3919, 44703, 19149, 28803, 48959, 6259, 50273, 62237, 42};
73/* This equals 1525 * 2^16 + 57600 */
74static const LITTLENUM_TYPE plus_4[] =
75{57600, 1525};
76
77/* This approaches 1e-16 */
78static const LITTLENUM_TYPE minus_5[] =
79{
80 22199, 45957, 17005, 26266, 10526, 16260, 55017, 35680, 40443, 19789,
81 17356, 30195, 55905, 28426, 63010, 44197, 1844};
82static const LITTLENUM_TYPE plus_5[] =
83{28609, 34546, 35};
84
85static const LITTLENUM_TYPE minus_6[] =
86{
87 30926, 26518, 13110, 43018, 54982, 48258, 24658, 15209, 63366, 11929,
88 20069, 43857, 60487, 51};
89static const LITTLENUM_TYPE plus_6[] =
90{61313, 34220, 16731, 11629, 1262};
91
92static const LITTLENUM_TYPE minus_7[] =
93{
94 29819, 14733, 21490, 40602, 31315, 65186, 2695};
95static const LITTLENUM_TYPE plus_7[] =
96{
97 7937, 49002, 60772, 28216, 38893, 55975, 63988, 59711, 20227, 24};
98
99static const LITTLENUM_TYPE minus_8[] =
100{
d197a7ab 101 27579, 64807, 12543, 794, 13907, 61297, 12013, 64360, 15961, 20566,
6efd877d
KR
102 24178, 15922, 59427, 110};
103static const LITTLENUM_TYPE plus_8[] =
104{
d197a7ab
ILT
105 15873, 11925, 39177, 991, 14589, 3861, 58415, 9076, 62956, 54223,
106 56328, 50180, 45274, 48333, 32537, 42547, 9731, 59679, 590};
6efd877d
KR
107
108static const LITTLENUM_TYPE minus_9[] =
109{
d197a7ab
ILT
110 11042, 8464, 58971, 63429, 6022, 63485, 5500, 53464, 47545, 50068,
111 56988, 22819, 49708, 54493, 9920, 47667, 40409, 35764, 10383, 54466,
112 32702, 17493, 32420, 34382, 22750, 20681, 12300};
6efd877d
KR
113static const LITTLENUM_TYPE plus_9[] =
114{
d197a7ab
ILT
115 20678, 27614, 28272, 53066, 55311, 54677, 29038, 9906, 26288, 44486,
116 13860, 7445, 54106, 15426, 21518, 25599, 29632, 52309, 61207, 26105,
117 10482, 21948, 51191, 32988, 60892, 62574, 61390, 24540, 21495, 5};
6efd877d
KR
118
119static const LITTLENUM_TYPE minus_10[] =
120{
d197a7ab
ILT
121 6214, 48771, 23471, 30163, 31763, 38013, 57001, 11770, 18263, 36366,
122 20742, 45086, 56969, 53231, 37856, 55814, 38057, 15692, 46761, 8713,
123 6102, 20083, 8269, 11839, 11571, 50963, 15649, 11698, 40675, 2308};
6efd877d
KR
124static const LITTLENUM_TYPE plus_10[] =
125{
d197a7ab
ILT
126 63839, 36576, 45712, 44516, 37803, 29482, 4966, 30556, 37961, 23310,
127 27070, 44972, 29507, 48257, 45209, 7494, 17831, 38728, 41577, 29443,
128 36016, 7955, 35339, 35479, 36011, 14553, 49618, 5588, 25396, 28};
6efd877d
KR
129
130static const LITTLENUM_TYPE minus_11[] =
131{
d197a7ab
ILT
132 16663, 56882, 61983, 7804, 36555, 32060, 34502, 1000, 14356, 21681,
133 6605, 34767, 51411, 59048, 53614, 39850, 30079, 6496, 6846, 26841,
134 40778, 19578, 59899, 44085, 54016, 24259, 11232, 21229, 21313, 81};
6efd877d
KR
135static const LITTLENUM_TYPE plus_11[] =
136{
d197a7ab
ILT
137 92, 9054, 62707, 17993, 7821, 56838, 13992, 21321, 29637, 48426,
138 42982, 38668, 49574, 28820, 18200, 18927, 53979, 16219, 37484, 2516,
139 44642, 14665, 11587, 41926, 13556, 23956, 54320, 6661, 55766, 805};
140
141static const LITTLENUM_TYPE minus_12[] =
142{
143 33202, 45969, 58804, 56734, 16482, 26007, 44984, 49334, 31007, 32944,
144 44517, 63329, 47131, 15291, 59465, 2264, 23218, 11829, 59771, 38798,
145 31051, 28748, 23129, 40541, 41562, 35108, 50620, 59014, 51817, 6613};
146static const LITTLENUM_TYPE plus_12[] =
147{
148 10098, 37922, 58070, 7432, 10470, 63465, 23718, 62190, 47420, 7009,
149 38443, 4587, 45596, 38472, 52129, 52779, 29012, 13559, 48688, 31678,
150 41753, 58662, 10668, 36067, 29906, 56906, 21461, 46556, 59571, 9};
151
152static const LITTLENUM_TYPE minus_13[] =
153{
154 45309, 27592, 37144, 34637, 34328, 41671, 34620, 24135, 53401, 22112,
155 21576, 45147, 39310, 44051, 48572, 3676, 46544, 59768, 33350, 2323,
156 49524, 61568, 3903, 36487, 36356, 30903, 14975, 9035, 29715, 667};
157static const LITTLENUM_TYPE plus_13[] =
158{
159 18788, 16960, 6318, 45685, 55400, 46230, 35794, 25588, 7253, 55541,
160 49716, 59760, 63592, 8191, 63765, 58530, 44667, 13294, 10001, 55586,
161 47887, 18738, 9509, 40896, 42506, 52580, 4171, 325, 12329, 98};
6efd877d
KR
162
163/* Shut up complaints about differing pointer types. They only differ
164 in the const attribute, but there isn't any easy way to do this
165 */
166#define X (LITTLENUM_TYPE *)
167
168const FLONUM_TYPE flonum_negative_powers_of_ten[] =
169{
170 {X zero, X zero, X zero, 0, '+'},
171 {X minus_1, X minus_1 + 19, X minus_1 + 19, -20, '+'},
172 {X minus_2, X minus_2 + 19, X minus_2 + 19, -20, '+'},
173 {X minus_3, X minus_3 + 19, X minus_3 + 19, -20, '+'},
174 {X minus_4, X minus_4 + 18, X minus_4 + 18, -20, '+'},
175 {X minus_5, X minus_5 + 16, X minus_5 + 16, -20, '+'},
176 {X minus_6, X minus_6 + 13, X minus_6 + 13, -20, '+'},
177 {X minus_7, X minus_7 + 6, X minus_7 + 6, -20, '+'},
178 {X minus_8, X minus_8 + 13, X minus_8 + 13, -40, '+'},
179 {X minus_9, X minus_9 + 26, X minus_9 + 26, -80, '+'},
180 {X minus_10, X minus_10 + 29, X minus_10 + 29, -136, '+'},
181 {X minus_11, X minus_11 + 29, X minus_11 + 29, -242, '+'},
d197a7ab
ILT
182 {X minus_12, X minus_12 + 29, X minus_12 + 29, -455, '+'},
183 {X minus_13, X minus_13 + 29, X minus_13 + 29, -880, '+'},
6efd877d
KR
184};
185
186const FLONUM_TYPE flonum_positive_powers_of_ten[] =
187{
188 {X zero, X zero, X zero, 0, '+'},
189 {X plus_1, X plus_1 + 0, X plus_1 + 0, 0, '+'},
190 {X plus_2, X plus_2 + 0, X plus_2 + 0, 0, '+'},
191 {X plus_3, X plus_3 + 0, X plus_3 + 0, 0, '+'},
192 {X plus_4, X plus_4 + 1, X plus_4 + 1, 0, '+'},
193 {X plus_5, X plus_5 + 2, X plus_5 + 2, 1, '+'},
194 {X plus_6, X plus_6 + 4, X plus_6 + 4, 2, '+'},
195 {X plus_7, X plus_7 + 9, X plus_7 + 9, 4, '+'},
196 {X plus_8, X plus_8 + 18, X plus_8 + 18, 8, '+'},
197 {X plus_9, X plus_9 + 29, X plus_9 + 29, 24, '+'},
198 {X plus_10, X plus_10 + 29, X plus_10 + 29, 77, '+'},
199 {X plus_11, X plus_11 + 29, X plus_11 + 29, 183, '+'},
d197a7ab
ILT
200 {X plus_12, X plus_12 + 29, X plus_12 + 29, 396, '+'},
201 {X plus_13, X plus_13 + 29, X plus_13 + 29, 821, '+'},
6efd877d
KR
202};
203
204#ifdef VMS
d197a7ab 205void dummy1 () { }
6efd877d
KR
206#endif
207/* end of flonum_const.c */
This page took 0.222309 seconds and 4 git commands to generate.