~ubuntu-branches/ubuntu/wily/julia/wily

« back to all changes in this revision

Viewing changes to deps/openlibm/slatec/d1mach.f

  • Committer: Package Import Robot
  • Author(s): Sébastien Villemot
  • Date: 2013-01-16 12:29:42 UTC
  • mfrom: (1.1.2)
  • Revision ID: package-import@ubuntu.com-20130116122942-x86e42akjq31repw
Tags: 0.0.0+20130107.gitd9656f41-1
* New upstream snashot
* No longer try to rebuild helpdb.jl.
   + debian/rules: remove helpdb.jl from build-arch rule
   + debian/control: move back python-sphinx to Build-Depends-Indep
* debian/copyright: reflect upstream changes
* Add Build-Conflicts on libatlas3-base (makes linalg tests fail)
* debian/rules: replace obsolete USE_DEBIAN makeflag by a list of
  USE_SYSTEM_* flags
* debian/rules: on non-x86 systems, use libm instead of openlibm
* dpkg-buildflags.patch: remove patch, applied upstream
* Refreshed other patches

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
*DECK D1MACH
 
2
      DOUBLE PRECISION FUNCTION D1MACH (I)
 
3
C***BEGIN PROLOGUE  D1MACH
 
4
C***PURPOSE  Return floating point machine dependent constants.
 
5
C***LIBRARY   SLATEC
 
6
C***CATEGORY  R1
 
7
C***TYPE      DOUBLE PRECISION (R1MACH-S, D1MACH-D)
 
8
C***KEYWORDS  MACHINE CONSTANTS
 
9
C***AUTHOR  Fox, P. A., (Bell Labs)
 
10
C           Hall, A. D., (Bell Labs)
 
11
C           Schryer, N. L., (Bell Labs)
 
12
C***DESCRIPTION
 
13
C
 
14
C   D1MACH can be used to obtain machine-dependent parameters for the
 
15
C   local machine environment.  It is a function subprogram with one
 
16
C   (input) argument, and can be referenced as follows:
 
17
C
 
18
C        D = D1MACH(I)
 
19
C
 
20
C   where I=1,...,5.  The (output) value of D above is determined by
 
21
C   the (input) value of I.  The results for various values of I are
 
22
C   discussed below.
 
23
C
 
24
C   D1MACH( 1) = B**(EMIN-1), the smallest positive magnitude.
 
25
C   D1MACH( 2) = B**EMAX*(1 - B**(-T)), the largest magnitude.
 
26
C   D1MACH( 3) = B**(-T), the smallest relative spacing.
 
27
C   D1MACH( 4) = B**(1-T), the largest relative spacing.
 
28
C   D1MACH( 5) = LOG10(B)
 
29
C
 
30
C   Assume double precision numbers are represented in the T-digit,
 
31
C   base-B form
 
32
C
 
33
C              sign (B**E)*( (X(1)/B) + ... + (X(T)/B**T) )
 
34
C
 
35
C   where 0 .LE. X(I) .LT. B for I=1,...,T, 0 .LT. X(1), and
 
36
C   EMIN .LE. E .LE. EMAX.
 
37
C
 
38
C   The values of B, T, EMIN and EMAX are provided in I1MACH as
 
39
C   follows:
 
40
C   I1MACH(10) = B, the base.
 
41
C   I1MACH(14) = T, the number of base-B digits.
 
42
C   I1MACH(15) = EMIN, the smallest exponent E.
 
43
C   I1MACH(16) = EMAX, the largest exponent E.
 
44
C
 
45
C   To alter this function for a particular environment, the desired
 
46
C   set of DATA statements should be activated by removing the C from
 
47
C   column 1.  Also, the values of D1MACH(1) - D1MACH(4) should be
 
48
C   checked for consistency with the local operating system.
 
49
C
 
50
C***REFERENCES  P. A. Fox, A. D. Hall and N. L. Schryer, Framework for
 
51
C                 a portable library, ACM Transactions on Mathematical
 
52
C                 Software 4, 2 (June 1978), pp. 177-188.
 
53
C***ROUTINES CALLED  XERMSG
 
54
C***REVISION HISTORY  (YYMMDD)
 
55
C   750101  DATE WRITTEN
 
56
C   890213  REVISION DATE from Version 3.2
 
57
C   891214  Prologue converted to Version 4.0 format.  (BAB)
 
58
C   900315  CALLs to XERROR changed to CALLs to XERMSG.  (THJ)
 
59
C   900618  Added DEC RISC constants.  (WRB)
 
60
C   900723  Added IBM RS 6000 constants.  (WRB)
 
61
C   900911  Added SUN 386i constants.  (WRB)
 
62
C   910710  Added HP 730 constants.  (SMR)
 
63
C   911114  Added Convex IEEE constants.  (WRB)
 
64
C   920121  Added SUN -r8 compiler option constants.  (WRB)
 
65
C   920229  Added Touchstone Delta i860 constants.  (WRB)
 
66
C   920501  Reformatted the REFERENCES section.  (WRB)
 
67
C   920625  Added CONVEX -p8 and -pd8 compiler option constants.
 
68
C           (BKS, WRB)
 
69
C   930201  Added DEC Alpha and SGI constants.  (RWC and WRB)
 
70
C***END PROLOGUE  D1MACH
 
71
C
 
72
      INTEGER SMALL(4)
 
73
      INTEGER LARGE(4)
 
74
      INTEGER RIGHT(4)
 
75
      INTEGER DIVER(4)
 
76
      INTEGER LOG10(4)
 
77
C
 
78
      DOUBLE PRECISION DMACH(5)
 
79
      SAVE DMACH
 
80
C
 
81
      EQUIVALENCE (DMACH(1),SMALL(1))
 
82
      EQUIVALENCE (DMACH(2),LARGE(1))
 
83
      EQUIVALENCE (DMACH(3),RIGHT(1))
 
84
      EQUIVALENCE (DMACH(4),DIVER(1))
 
85
      EQUIVALENCE (DMACH(5),LOG10(1))
 
86
C
 
87
C     MACHINE CONSTANTS FOR THE AMIGA
 
88
C     ABSOFT FORTRAN COMPILER USING THE 68020/68881 COMPILER OPTION
 
89
C
 
90
C     DATA SMALL(1), SMALL(2) / Z'00100000', Z'00000000' /
 
91
C     DATA LARGE(1), LARGE(2) / Z'7FEFFFFF', Z'FFFFFFFF' /
 
92
C     DATA RIGHT(1), RIGHT(2) / Z'3CA00000', Z'00000000' /
 
93
C     DATA DIVER(1), DIVER(2) / Z'3CB00000', Z'00000000' /
 
94
C     DATA LOG10(1), LOG10(2) / Z'3FD34413', Z'509F79FF' /
 
95
C
 
96
C     MACHINE CONSTANTS FOR THE AMIGA
 
97
C     ABSOFT FORTRAN COMPILER USING SOFTWARE FLOATING POINT
 
98
C
 
99
C     DATA SMALL(1), SMALL(2) / Z'00100000', Z'00000000' /
 
100
C     DATA LARGE(1), LARGE(2) / Z'7FDFFFFF', Z'FFFFFFFF' /
 
101
C     DATA RIGHT(1), RIGHT(2) / Z'3CA00000', Z'00000000' /
 
102
C     DATA DIVER(1), DIVER(2) / Z'3CB00000', Z'00000000' /
 
103
C     DATA LOG10(1), LOG10(2) / Z'3FD34413', Z'509F79FF' /
 
104
C
 
105
C     MACHINE CONSTANTS FOR THE APOLLO
 
106
C
 
107
C     DATA SMALL(1), SMALL(2) / 16#00100000, 16#00000000 /
 
108
C     DATA LARGE(1), LARGE(2) / 16#7FFFFFFF, 16#FFFFFFFF /
 
109
C     DATA RIGHT(1), RIGHT(2) / 16#3CA00000, 16#00000000 /
 
110
C     DATA DIVER(1), DIVER(2) / 16#3CB00000, 16#00000000 /
 
111
C     DATA LOG10(1), LOG10(2) / 16#3FD34413, 16#509F79FF /
 
112
C
 
113
C     MACHINE CONSTANTS FOR THE BURROUGHS 1700 SYSTEM
 
114
C
 
115
C     DATA SMALL(1) / ZC00800000 /
 
116
C     DATA SMALL(2) / Z000000000 /
 
117
C     DATA LARGE(1) / ZDFFFFFFFF /
 
118
C     DATA LARGE(2) / ZFFFFFFFFF /
 
119
C     DATA RIGHT(1) / ZCC5800000 /
 
120
C     DATA RIGHT(2) / Z000000000 /
 
121
C     DATA DIVER(1) / ZCC6800000 /
 
122
C     DATA DIVER(2) / Z000000000 /
 
123
C     DATA LOG10(1) / ZD00E730E7 /
 
124
C     DATA LOG10(2) / ZC77800DC0 /
 
125
C
 
126
C     MACHINE CONSTANTS FOR THE BURROUGHS 5700 SYSTEM
 
127
C
 
128
C     DATA SMALL(1) / O1771000000000000 /
 
129
C     DATA SMALL(2) / O0000000000000000 /
 
130
C     DATA LARGE(1) / O0777777777777777 /
 
131
C     DATA LARGE(2) / O0007777777777777 /
 
132
C     DATA RIGHT(1) / O1461000000000000 /
 
133
C     DATA RIGHT(2) / O0000000000000000 /
 
134
C     DATA DIVER(1) / O1451000000000000 /
 
135
C     DATA DIVER(2) / O0000000000000000 /
 
136
C     DATA LOG10(1) / O1157163034761674 /
 
137
C     DATA LOG10(2) / O0006677466732724 /
 
138
C
 
139
C     MACHINE CONSTANTS FOR THE BURROUGHS 6700/7700 SYSTEMS
 
140
C
 
141
C     DATA SMALL(1) / O1771000000000000 /
 
142
C     DATA SMALL(2) / O7770000000000000 /
 
143
C     DATA LARGE(1) / O0777777777777777 /
 
144
C     DATA LARGE(2) / O7777777777777777 /
 
145
C     DATA RIGHT(1) / O1461000000000000 /
 
146
C     DATA RIGHT(2) / O0000000000000000 /
 
147
C     DATA DIVER(1) / O1451000000000000 /
 
148
C     DATA DIVER(2) / O0000000000000000 /
 
149
C     DATA LOG10(1) / O1157163034761674 /
 
150
C     DATA LOG10(2) / O0006677466732724 /
 
151
C
 
152
C     MACHINE CONSTANTS FOR THE CDC 170/180 SERIES USING NOS/VE
 
153
C
 
154
C     DATA SMALL(1) / Z"3001800000000000" /
 
155
C     DATA SMALL(2) / Z"3001000000000000" /
 
156
C     DATA LARGE(1) / Z"4FFEFFFFFFFFFFFE" /
 
157
C     DATA LARGE(2) / Z"4FFE000000000000" /
 
158
C     DATA RIGHT(1) / Z"3FD2800000000000" /
 
159
C     DATA RIGHT(2) / Z"3FD2000000000000" /
 
160
C     DATA DIVER(1) / Z"3FD3800000000000" /
 
161
C     DATA DIVER(2) / Z"3FD3000000000000" /
 
162
C     DATA LOG10(1) / Z"3FFF9A209A84FBCF" /
 
163
C     DATA LOG10(2) / Z"3FFFF7988F8959AC" /
 
164
C
 
165
C     MACHINE CONSTANTS FOR THE CDC 6000/7000 SERIES
 
166
C
 
167
C     DATA SMALL(1) / 00564000000000000000B /
 
168
C     DATA SMALL(2) / 00000000000000000000B /
 
169
C     DATA LARGE(1) / 37757777777777777777B /
 
170
C     DATA LARGE(2) / 37157777777777777777B /
 
171
C     DATA RIGHT(1) / 15624000000000000000B /
 
172
C     DATA RIGHT(2) / 00000000000000000000B /
 
173
C     DATA DIVER(1) / 15634000000000000000B /
 
174
C     DATA DIVER(2) / 00000000000000000000B /
 
175
C     DATA LOG10(1) / 17164642023241175717B /
 
176
C     DATA LOG10(2) / 16367571421742254654B /
 
177
C
 
178
C     MACHINE CONSTANTS FOR THE CELERITY C1260
 
179
C
 
180
C     DATA SMALL(1), SMALL(2) / Z'00100000', Z'00000000' /
 
181
C     DATA LARGE(1), LARGE(2) / Z'7FEFFFFF', Z'FFFFFFFF' /
 
182
C     DATA RIGHT(1), RIGHT(2) / Z'3CA00000', Z'00000000' /
 
183
C     DATA DIVER(1), DIVER(2) / Z'3CB00000', Z'00000000' /
 
184
C     DATA LOG10(1), LOG10(2) / Z'3FD34413', Z'509F79FF' /
 
185
C
 
186
C     MACHINE CONSTANTS FOR THE CONVEX
 
187
C     USING THE -fn OR -pd8 COMPILER OPTION
 
188
C
 
189
C     DATA DMACH(1) / Z'0010000000000000' /
 
190
C     DATA DMACH(2) / Z'7FFFFFFFFFFFFFFF' /
 
191
C     DATA DMACH(3) / Z'3CC0000000000000' /
 
192
C     DATA DMACH(4) / Z'3CD0000000000000' /
 
193
C     DATA DMACH(5) / Z'3FF34413509F79FF' /
 
194
C
 
195
C     MACHINE CONSTANTS FOR THE CONVEX
 
196
C     USING THE -fi COMPILER OPTION
 
197
C
 
198
C     DATA DMACH(1) / Z'0010000000000000' /
 
199
C     DATA DMACH(2) / Z'7FEFFFFFFFFFFFFF' /
 
200
C     DATA DMACH(3) / Z'3CA0000000000000' /
 
201
C     DATA DMACH(4) / Z'3CB0000000000000' /
 
202
C     DATA DMACH(5) / Z'3FD34413509F79FF' /
 
203
C
 
204
C     MACHINE CONSTANTS FOR THE CONVEX
 
205
C     USING THE -p8 COMPILER OPTION
 
206
C
 
207
C     DATA DMACH(1) / Z'00010000000000000000000000000000' /
 
208
C     DATA DMACH(2) / Z'7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF' /
 
209
C     DATA DMACH(3) / Z'3F900000000000000000000000000000' /
 
210
C     DATA DMACH(4) / Z'3F910000000000000000000000000000' /
 
211
C     DATA DMACH(5) / Z'3FFF34413509F79FEF311F12B35816F9' /
 
212
C
 
213
C     MACHINE CONSTANTS FOR THE CRAY
 
214
C
 
215
C     DATA SMALL(1) / 201354000000000000000B /
 
216
C     DATA SMALL(2) / 000000000000000000000B /
 
217
C     DATA LARGE(1) / 577767777777777777777B /
 
218
C     DATA LARGE(2) / 000007777777777777774B /
 
219
C     DATA RIGHT(1) / 376434000000000000000B /
 
220
C     DATA RIGHT(2) / 000000000000000000000B /
 
221
C     DATA DIVER(1) / 376444000000000000000B /
 
222
C     DATA DIVER(2) / 000000000000000000000B /
 
223
C     DATA LOG10(1) / 377774642023241175717B /
 
224
C     DATA LOG10(2) / 000007571421742254654B /
 
225
C
 
226
C     MACHINE CONSTANTS FOR THE DATA GENERAL ECLIPSE S/200
 
227
C     NOTE - IT MAY BE APPROPRIATE TO INCLUDE THE FOLLOWING CARD -
 
228
C     STATIC DMACH(5)
 
229
C
 
230
C     DATA SMALL /    20K, 3*0 /
 
231
C     DATA LARGE / 77777K, 3*177777K /
 
232
C     DATA RIGHT / 31420K, 3*0 /
 
233
C     DATA DIVER / 32020K, 3*0 /
 
234
C     DATA LOG10 / 40423K, 42023K, 50237K, 74776K /
 
235
C
 
236
C     MACHINE CONSTANTS FOR THE DEC ALPHA
 
237
C     USING G_FLOAT
 
238
C
 
239
C     DATA DMACH(1) / '0000000000000010'X /
 
240
C     DATA DMACH(2) / 'FFFFFFFFFFFF7FFF'X /
 
241
C     DATA DMACH(3) / '0000000000003CC0'X /
 
242
C     DATA DMACH(4) / '0000000000003CD0'X /
 
243
C     DATA DMACH(5) / '79FF509F44133FF3'X /
 
244
C
 
245
C     MACHINE CONSTANTS FOR THE DEC ALPHA
 
246
C     USING IEEE_FORMAT
 
247
C
 
248
C     DATA DMACH(1) / '0010000000000000'X /
 
249
C     DATA DMACH(2) / '7FEFFFFFFFFFFFFF'X /
 
250
C     DATA DMACH(3) / '3CA0000000000000'X /
 
251
C     DATA DMACH(4) / '3CB0000000000000'X /
 
252
C     DATA DMACH(5) / '3FD34413509F79FF'X /
 
253
C
 
254
C     MACHINE CONSTANTS FOR THE DEC RISC
 
255
C
 
256
C     DATA SMALL(1), SMALL(2) / Z'00000000', Z'00100000'/
 
257
C     DATA LARGE(1), LARGE(2) / Z'FFFFFFFF', Z'7FEFFFFF'/
 
258
C     DATA RIGHT(1), RIGHT(2) / Z'00000000', Z'3CA00000'/
 
259
C     DATA DIVER(1), DIVER(2) / Z'00000000', Z'3CB00000'/
 
260
C     DATA LOG10(1), LOG10(2) / Z'509F79FF', Z'3FD34413'/
 
261
C
 
262
C     MACHINE CONSTANTS FOR THE DEC VAX
 
263
C     USING D_FLOATING
 
264
C     (EXPRESSED IN INTEGER AND HEXADECIMAL)
 
265
C     THE HEX FORMAT BELOW MAY NOT BE SUITABLE FOR UNIX SYSTEMS
 
266
C     THE INTEGER FORMAT SHOULD BE OK FOR UNIX SYSTEMS
 
267
C
 
268
C     DATA SMALL(1), SMALL(2) /        128,           0 /
 
269
C     DATA LARGE(1), LARGE(2) /     -32769,          -1 /
 
270
C     DATA RIGHT(1), RIGHT(2) /       9344,           0 /
 
271
C     DATA DIVER(1), DIVER(2) /       9472,           0 /
 
272
C     DATA LOG10(1), LOG10(2) /  546979738,  -805796613 /
 
273
C
 
274
C     DATA SMALL(1), SMALL(2) / Z00000080, Z00000000 /
 
275
C     DATA LARGE(1), LARGE(2) / ZFFFF7FFF, ZFFFFFFFF /
 
276
C     DATA RIGHT(1), RIGHT(2) / Z00002480, Z00000000 /
 
277
C     DATA DIVER(1), DIVER(2) / Z00002500, Z00000000 /
 
278
C     DATA LOG10(1), LOG10(2) / Z209A3F9A, ZCFF884FB /
 
279
C
 
280
C     MACHINE CONSTANTS FOR THE DEC VAX
 
281
C     USING G_FLOATING
 
282
C     (EXPRESSED IN INTEGER AND HEXADECIMAL)
 
283
C     THE HEX FORMAT BELOW MAY NOT BE SUITABLE FOR UNIX SYSTEMS
 
284
C     THE INTEGER FORMAT SHOULD BE OK FOR UNIX SYSTEMS
 
285
C
 
286
C     DATA SMALL(1), SMALL(2) /         16,           0 /
 
287
C     DATA LARGE(1), LARGE(2) /     -32769,          -1 /
 
288
C     DATA RIGHT(1), RIGHT(2) /      15552,           0 /
 
289
C     DATA DIVER(1), DIVER(2) /      15568,           0 /
 
290
C     DATA LOG10(1), LOG10(2) /  1142112243, 2046775455 /
 
291
C
 
292
C     DATA SMALL(1), SMALL(2) / Z00000010, Z00000000 /
 
293
C     DATA LARGE(1), LARGE(2) / ZFFFF7FFF, ZFFFFFFFF /
 
294
C     DATA RIGHT(1), RIGHT(2) / Z00003CC0, Z00000000 /
 
295
C     DATA DIVER(1), DIVER(2) / Z00003CD0, Z00000000 /
 
296
C     DATA LOG10(1), LOG10(2) / Z44133FF3, Z79FF509F /
 
297
C
 
298
C     MACHINE CONSTANTS FOR THE ELXSI 6400
 
299
C     (ASSUMING REAL*8 IS THE DEFAULT DOUBLE PRECISION)
 
300
C
 
301
C     DATA SMALL(1), SMALL(2) / '00100000'X,'00000000'X /
 
302
C     DATA LARGE(1), LARGE(2) / '7FEFFFFF'X,'FFFFFFFF'X /
 
303
C     DATA RIGHT(1), RIGHT(2) / '3CB00000'X,'00000000'X /
 
304
C     DATA DIVER(1), DIVER(2) / '3CC00000'X,'00000000'X /
 
305
C     DATA LOG10(1), LOG10(2) / '3FD34413'X,'509F79FF'X /
 
306
C
 
307
C     MACHINE CONSTANTS FOR THE HARRIS 220
 
308
C
 
309
C     DATA SMALL(1), SMALL(2) / '20000000, '00000201 /
 
310
C     DATA LARGE(1), LARGE(2) / '37777777, '37777577 /
 
311
C     DATA RIGHT(1), RIGHT(2) / '20000000, '00000333 /
 
312
C     DATA DIVER(1), DIVER(2) / '20000000, '00000334 /
 
313
C     DATA LOG10(1), LOG10(2) / '23210115, '10237777 /
 
314
C
 
315
C     MACHINE CONSTANTS FOR THE HONEYWELL 600/6000 SERIES
 
316
C
 
317
C     DATA SMALL(1), SMALL(2) / O402400000000, O000000000000 /
 
318
C     DATA LARGE(1), LARGE(2) / O376777777777, O777777777777 /
 
319
C     DATA RIGHT(1), RIGHT(2) / O604400000000, O000000000000 /
 
320
C     DATA DIVER(1), DIVER(2) / O606400000000, O000000000000 /
 
321
C     DATA LOG10(1), LOG10(2) / O776464202324, O117571775714 /
 
322
C
 
323
C     MACHINE CONSTANTS FOR THE HP 730
 
324
C
 
325
C     DATA DMACH(1) / Z'0010000000000000' /
 
326
C     DATA DMACH(2) / Z'7FEFFFFFFFFFFFFF' /
 
327
C     DATA DMACH(3) / Z'3CA0000000000000' /
 
328
C     DATA DMACH(4) / Z'3CB0000000000000' /
 
329
C     DATA DMACH(5) / Z'3FD34413509F79FF' /
 
330
C
 
331
C     MACHINE CONSTANTS FOR THE HP 2100
 
332
C     THREE WORD DOUBLE PRECISION OPTION WITH FTN4
 
333
C
 
334
C     DATA SMALL(1), SMALL(2), SMALL(3) / 40000B,       0,       1 /
 
335
C     DATA LARGE(1), LARGE(2), LARGE(3) / 77777B, 177777B, 177776B /
 
336
C     DATA RIGHT(1), RIGHT(2), RIGHT(3) / 40000B,       0,    265B /
 
337
C     DATA DIVER(1), DIVER(2), DIVER(3) / 40000B,       0,    276B /
 
338
C     DATA LOG10(1), LOG10(2), LOG10(3) / 46420B,  46502B,  77777B /
 
339
C
 
340
C     MACHINE CONSTANTS FOR THE HP 2100
 
341
C     FOUR WORD DOUBLE PRECISION OPTION WITH FTN4
 
342
C
 
343
C     DATA SMALL(1), SMALL(2) /  40000B,       0 /
 
344
C     DATA SMALL(3), SMALL(4) /       0,       1 /
 
345
C     DATA LARGE(1), LARGE(2) /  77777B, 177777B /
 
346
C     DATA LARGE(3), LARGE(4) / 177777B, 177776B /
 
347
C     DATA RIGHT(1), RIGHT(2) /  40000B,       0 /
 
348
C     DATA RIGHT(3), RIGHT(4) /       0,    225B /
 
349
C     DATA DIVER(1), DIVER(2) /  40000B,       0 /
 
350
C     DATA DIVER(3), DIVER(4) /       0,    227B /
 
351
C     DATA LOG10(1), LOG10(2) /  46420B,  46502B /
 
352
C     DATA LOG10(3), LOG10(4) /  76747B, 176377B /
 
353
C
 
354
C     MACHINE CONSTANTS FOR THE HP 9000
 
355
C
 
356
C     DATA SMALL(1), SMALL(2) / 00040000000B, 00000000000B /
 
357
C     DATA LARGE(1), LARGE(2) / 17737777777B, 37777777777B /
 
358
C     DATA RIGHT(1), RIGHT(2) / 07454000000B, 00000000000B /
 
359
C     DATA DIVER(1), DIVER(2) / 07460000000B, 00000000000B /
 
360
C     DATA LOG10(1), LOG10(2) / 07764642023B, 12047674777B /
 
361
C
 
362
C     MACHINE CONSTANTS FOR THE IBM 360/370 SERIES,
 
363
C     THE XEROX SIGMA 5/7/9, THE SEL SYSTEMS 85/86, AND
 
364
C     THE PERKIN ELMER (INTERDATA) 7/32.
 
365
C
 
366
C     DATA SMALL(1), SMALL(2) / Z00100000, Z00000000 /
 
367
C     DATA LARGE(1), LARGE(2) / Z7FFFFFFF, ZFFFFFFFF /
 
368
C     DATA RIGHT(1), RIGHT(2) / Z33100000, Z00000000 /
 
369
C     DATA DIVER(1), DIVER(2) / Z34100000, Z00000000 /
 
370
C     DATA LOG10(1), LOG10(2) / Z41134413, Z509F79FF /
 
371
C
 
372
C     MACHINE CONSTANTS FOR THE IBM PC
 
373
C     ASSUMES THAT ALL ARITHMETIC IS DONE IN DOUBLE PRECISION
 
374
C     ON 8088, I.E., NOT IN 80 BIT FORM FOR THE 8087.
 
375
C
 
376
C     DATA SMALL(1) / 2.23D-308  /
 
377
C     DATA LARGE(1) / 1.79D+308  /
 
378
C     DATA RIGHT(1) / 1.11D-16   /
 
379
C     DATA DIVER(1) / 2.22D-16   /
 
380
C     DATA LOG10(1) / 0.301029995663981195D0 /
 
381
C
 
382
C     MACHINE CONSTANTS FOR THE IBM RS 6000
 
383
C
 
384
C     DATA DMACH(1) / Z'0010000000000000' /
 
385
C     DATA DMACH(2) / Z'7FEFFFFFFFFFFFFF' /
 
386
C     DATA DMACH(3) / Z'3CA0000000000000' /
 
387
C     DATA DMACH(4) / Z'3CB0000000000000' /
 
388
C     DATA DMACH(5) / Z'3FD34413509F79FF' /
 
389
C
 
390
C     MACHINE CONSTANTS FOR THE INTEL i860
 
391
C
 
392
C     DATA DMACH(1) / Z'0010000000000000' /
 
393
C     DATA DMACH(2) / Z'7FEFFFFFFFFFFFFF' /
 
394
C     DATA DMACH(3) / Z'3CA0000000000000' /
 
395
C     DATA DMACH(4) / Z'3CB0000000000000' /
 
396
C     DATA DMACH(5) / Z'3FD34413509F79FF' /
 
397
C
 
398
C     MACHINE CONSTANTS FOR THE PDP-10 (KA PROCESSOR)
 
399
C
 
400
C     DATA SMALL(1), SMALL(2) / "033400000000, "000000000000 /
 
401
C     DATA LARGE(1), LARGE(2) / "377777777777, "344777777777 /
 
402
C     DATA RIGHT(1), RIGHT(2) / "113400000000, "000000000000 /
 
403
C     DATA DIVER(1), DIVER(2) / "114400000000, "000000000000 /
 
404
C     DATA LOG10(1), LOG10(2) / "177464202324, "144117571776 /
 
405
C
 
406
C     MACHINE CONSTANTS FOR THE PDP-10 (KI PROCESSOR)
 
407
C
 
408
C     DATA SMALL(1), SMALL(2) / "000400000000, "000000000000 /
 
409
C     DATA LARGE(1), LARGE(2) / "377777777777, "377777777777 /
 
410
C     DATA RIGHT(1), RIGHT(2) / "103400000000, "000000000000 /
 
411
C     DATA DIVER(1), DIVER(2) / "104400000000, "000000000000 /
 
412
C     DATA LOG10(1), LOG10(2) / "177464202324, "476747767461 /
 
413
C
 
414
C     MACHINE CONSTANTS FOR PDP-11 FORTRAN SUPPORTING
 
415
C     32-BIT INTEGERS (EXPRESSED IN INTEGER AND OCTAL).
 
416
C
 
417
C     DATA SMALL(1), SMALL(2) /    8388608,           0 /
 
418
C     DATA LARGE(1), LARGE(2) / 2147483647,          -1 /
 
419
C     DATA RIGHT(1), RIGHT(2) /  612368384,           0 /
 
420
C     DATA DIVER(1), DIVER(2) /  620756992,           0 /
 
421
C     DATA LOG10(1), LOG10(2) / 1067065498, -2063872008 /
 
422
C
 
423
C     DATA SMALL(1), SMALL(2) / O00040000000, O00000000000 /
 
424
C     DATA LARGE(1), LARGE(2) / O17777777777, O37777777777 /
 
425
C     DATA RIGHT(1), RIGHT(2) / O04440000000, O00000000000 /
 
426
C     DATA DIVER(1), DIVER(2) / O04500000000, O00000000000 /
 
427
C     DATA LOG10(1), LOG10(2) / O07746420232, O20476747770 /
 
428
C
 
429
C     MACHINE CONSTANTS FOR PDP-11 FORTRAN SUPPORTING
 
430
C     16-BIT INTEGERS (EXPRESSED IN INTEGER AND OCTAL).
 
431
C
 
432
C     DATA SMALL(1), SMALL(2) /    128,      0 /
 
433
C     DATA SMALL(3), SMALL(4) /      0,      0 /
 
434
C     DATA LARGE(1), LARGE(2) /  32767,     -1 /
 
435
C     DATA LARGE(3), LARGE(4) /     -1,     -1 /
 
436
C     DATA RIGHT(1), RIGHT(2) /   9344,      0 /
 
437
C     DATA RIGHT(3), RIGHT(4) /      0,      0 /
 
438
C     DATA DIVER(1), DIVER(2) /   9472,      0 /
 
439
C     DATA DIVER(3), DIVER(4) /      0,      0 /
 
440
C     DATA LOG10(1), LOG10(2) /  16282,   8346 /
 
441
C     DATA LOG10(3), LOG10(4) / -31493, -12296 /
 
442
C
 
443
C     DATA SMALL(1), SMALL(2) / O000200, O000000 /
 
444
C     DATA SMALL(3), SMALL(4) / O000000, O000000 /
 
445
C     DATA LARGE(1), LARGE(2) / O077777, O177777 /
 
446
C     DATA LARGE(3), LARGE(4) / O177777, O177777 /
 
447
C     DATA RIGHT(1), RIGHT(2) / O022200, O000000 /
 
448
C     DATA RIGHT(3), RIGHT(4) / O000000, O000000 /
 
449
C     DATA DIVER(1), DIVER(2) / O022400, O000000 /
 
450
C     DATA DIVER(3), DIVER(4) / O000000, O000000 /
 
451
C     DATA LOG10(1), LOG10(2) / O037632, O020232 /
 
452
C     DATA LOG10(3), LOG10(4) / O102373, O147770 /
 
453
C
 
454
C     MACHINE CONSTANTS FOR THE SILICON GRAPHICS
 
455
C
 
456
C     DATA SMALL(1), SMALL(2) / Z'00100000', Z'00000000' /
 
457
C     DATA LARGE(1), LARGE(2) / Z'7FEFFFFF', Z'FFFFFFFF' /
 
458
C     DATA RIGHT(1), RIGHT(2) / Z'3CA00000', Z'00000000' /
 
459
C     DATA DIVER(1), DIVER(2) / Z'3CB00000', Z'00000000' /
 
460
C     DATA LOG10(1), LOG10(2) / Z'3FD34413', Z'509F79FF' /
 
461
C
 
462
C     MACHINE CONSTANTS FOR THE SUN
 
463
C
 
464
C     DATA DMACH(1) / Z'0010000000000000' /
 
465
C     DATA DMACH(2) / Z'7FEFFFFFFFFFFFFF' /
 
466
C     DATA DMACH(3) / Z'3CA0000000000000' /
 
467
C     DATA DMACH(4) / Z'3CB0000000000000' /
 
468
C     DATA DMACH(5) / Z'3FD34413509F79FF' /
 
469
C
 
470
C     MACHINE CONSTANTS FOR THE SUN
 
471
C     USING THE -r8 COMPILER OPTION
 
472
C
 
473
C     DATA DMACH(1) / Z'00010000000000000000000000000000' /
 
474
C     DATA DMACH(2) / Z'7FFEFFFFFFFFFFFFFFFFFFFFFFFFFFFF' /
 
475
C     DATA DMACH(3) / Z'3F8E0000000000000000000000000000' /
 
476
C     DATA DMACH(4) / Z'3F8F0000000000000000000000000000' /
 
477
C     DATA DMACH(5) / Z'3FFD34413509F79FEF311F12B35816F9' /
 
478
C
 
479
C     MACHINE CONSTANTS FOR THE SUN 386i
 
480
C
 
481
C     DATA SMALL(1), SMALL(2) / Z'FFFFFFFD', Z'000FFFFF' /
 
482
C     DATA LARGE(1), LARGE(2) / Z'FFFFFFB0', Z'7FEFFFFF' /
 
483
C     DATA RIGHT(1), RIGHT(2) / Z'000000B0', Z'3CA00000' /
 
484
C     DATA DIVER(1), DIVER(2) / Z'FFFFFFCB', Z'3CAFFFFF'
 
485
C     DATA LOG10(1), LOG10(2) / Z'509F79E9', Z'3FD34413' /
 
486
C
 
487
C     MACHINE CONSTANTS FOR THE UNIVAC 1100 SERIES FTN COMPILER
 
488
C
 
489
C     DATA SMALL(1), SMALL(2) / O000040000000, O000000000000 /
 
490
C     DATA LARGE(1), LARGE(2) / O377777777777, O777777777777 /
 
491
C     DATA RIGHT(1), RIGHT(2) / O170540000000, O000000000000 /
 
492
C     DATA DIVER(1), DIVER(2) / O170640000000, O000000000000 /
 
493
C     DATA LOG10(1), LOG10(2) / O177746420232, O411757177572 /
 
494
C
 
495
C***FIRST EXECUTABLE STATEMENT  D1MACH
 
496
      IF (I .LT. 1 .OR. I .GT. 5) CALL XERMSG ('SLATEC', 'D1MACH',
 
497
     +   'I OUT OF BOUNDS', 1, 2)
 
498
C
 
499
      D1MACH = DMACH(I)
 
500
      RETURN
 
501
C
 
502
      END