2
DOUBLE PRECISION FUNCTION D1MACH (I)
3
C***BEGIN PROLOGUE D1MACH
4
C***PURPOSE Return floating point machine dependent constants.
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)
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:
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
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)
30
C Assume double precision numbers are represented in the T-digit,
33
C sign (B**E)*( (X(1)/B) + ... + (X(T)/B**T) )
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.
38
C The values of B, T, EMIN and EMAX are provided in I1MACH as
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.
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.
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)
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.
69
C 930201 Added DEC Alpha and SGI constants. (RWC and WRB)
70
C***END PROLOGUE D1MACH
78
DOUBLE PRECISION DMACH(5)
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))
87
C MACHINE CONSTANTS FOR THE AMIGA
88
C ABSOFT FORTRAN COMPILER USING THE 68020/68881 COMPILER OPTION
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' /
96
C MACHINE CONSTANTS FOR THE AMIGA
97
C ABSOFT FORTRAN COMPILER USING SOFTWARE FLOATING POINT
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' /
105
C MACHINE CONSTANTS FOR THE APOLLO
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 /
113
C MACHINE CONSTANTS FOR THE BURROUGHS 1700 SYSTEM
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 /
126
C MACHINE CONSTANTS FOR THE BURROUGHS 5700 SYSTEM
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 /
139
C MACHINE CONSTANTS FOR THE BURROUGHS 6700/7700 SYSTEMS
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 /
152
C MACHINE CONSTANTS FOR THE CDC 170/180 SERIES USING NOS/VE
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" /
165
C MACHINE CONSTANTS FOR THE CDC 6000/7000 SERIES
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 /
178
C MACHINE CONSTANTS FOR THE CELERITY C1260
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' /
186
C MACHINE CONSTANTS FOR THE CONVEX
187
C USING THE -fn OR -pd8 COMPILER OPTION
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' /
195
C MACHINE CONSTANTS FOR THE CONVEX
196
C USING THE -fi COMPILER OPTION
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' /
204
C MACHINE CONSTANTS FOR THE CONVEX
205
C USING THE -p8 COMPILER OPTION
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' /
213
C MACHINE CONSTANTS FOR THE CRAY
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 /
226
C MACHINE CONSTANTS FOR THE DATA GENERAL ECLIPSE S/200
227
C NOTE - IT MAY BE APPROPRIATE TO INCLUDE THE FOLLOWING CARD -
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 /
236
C MACHINE CONSTANTS FOR THE DEC ALPHA
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 /
245
C MACHINE CONSTANTS FOR THE DEC ALPHA
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 /
254
C MACHINE CONSTANTS FOR THE DEC RISC
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'/
262
C MACHINE CONSTANTS FOR THE DEC VAX
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
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 /
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 /
280
C MACHINE CONSTANTS FOR THE DEC VAX
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
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 /
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 /
298
C MACHINE CONSTANTS FOR THE ELXSI 6400
299
C (ASSUMING REAL*8 IS THE DEFAULT DOUBLE PRECISION)
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 /
307
C MACHINE CONSTANTS FOR THE HARRIS 220
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 /
315
C MACHINE CONSTANTS FOR THE HONEYWELL 600/6000 SERIES
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 /
323
C MACHINE CONSTANTS FOR THE HP 730
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' /
331
C MACHINE CONSTANTS FOR THE HP 2100
332
C THREE WORD DOUBLE PRECISION OPTION WITH FTN4
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 /
340
C MACHINE CONSTANTS FOR THE HP 2100
341
C FOUR WORD DOUBLE PRECISION OPTION WITH FTN4
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 /
354
C MACHINE CONSTANTS FOR THE HP 9000
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 /
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.
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 /
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.
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 /
382
C MACHINE CONSTANTS FOR THE IBM RS 6000
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' /
390
C MACHINE CONSTANTS FOR THE INTEL i860
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' /
398
C MACHINE CONSTANTS FOR THE PDP-10 (KA PROCESSOR)
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 /
406
C MACHINE CONSTANTS FOR THE PDP-10 (KI PROCESSOR)
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 /
414
C MACHINE CONSTANTS FOR PDP-11 FORTRAN SUPPORTING
415
C 32-BIT INTEGERS (EXPRESSED IN INTEGER AND OCTAL).
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 /
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 /
429
C MACHINE CONSTANTS FOR PDP-11 FORTRAN SUPPORTING
430
C 16-BIT INTEGERS (EXPRESSED IN INTEGER AND OCTAL).
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 /
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 /
454
C MACHINE CONSTANTS FOR THE SILICON GRAPHICS
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' /
462
C MACHINE CONSTANTS FOR THE SUN
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' /
470
C MACHINE CONSTANTS FOR THE SUN
471
C USING THE -r8 COMPILER OPTION
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' /
479
C MACHINE CONSTANTS FOR THE SUN 386i
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' /
487
C MACHINE CONSTANTS FOR THE UNIVAC 1100 SERIES FTN COMPILER
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 /
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)