this code will be compiled for a hypre blas library to enhance portability of
IJ_matrix_vector. This will automatically be sued unless the configure --with-blas option is used, which looks for the blas library elsewhere
This commit is contained in:
parent
7a043cae48
commit
2a0573d712
82
blas/Makefile
Normal file
82
blas/Makefile
Normal file
@ -0,0 +1,82 @@
|
||||
# Generated automatically from Makefile.in by configure.
|
||||
#BHEADER***********************************************************************
|
||||
# (c) 1997 The Regents of the University of California
|
||||
#
|
||||
# See the file COPYRIGHT_and_DISCLAIMER for a complete copyright
|
||||
# notice, contact person, and disclaimer.
|
||||
#
|
||||
# $Revision$
|
||||
#EHEADER***********************************************************************
|
||||
|
||||
.SUFFIXES:
|
||||
.SUFFIXES: .c .f .o
|
||||
|
||||
srcdir = .
|
||||
|
||||
|
||||
CC = mpicc
|
||||
|
||||
C_COMPILE_FLAGS= -O
|
||||
CXX_COMPILE_FLAGS= -O
|
||||
F77_COMPILE_FLAGS= -O -silent
|
||||
CINCLUDES=
|
||||
CDEFS = -DHYPRE_NO_PTHREAD_MANGLING
|
||||
|
||||
CFLAGS =\
|
||||
-I.\
|
||||
${C_COMPILE_FLAGS}\
|
||||
${CINCLUDES}\
|
||||
${CDEFS}
|
||||
|
||||
RANLIB= ranlib
|
||||
|
||||
LIBFLAGS = -lm
|
||||
LDLIBFLAGS =
|
||||
|
||||
HEADERS =\
|
||||
f2c.h
|
||||
|
||||
FILES =\
|
||||
dcopy.c \
|
||||
ddot.c \
|
||||
dnrm2.c
|
||||
|
||||
OBJS = ${FILES:.c=.o}
|
||||
|
||||
##################################################################
|
||||
# Targets
|
||||
##################################################################
|
||||
|
||||
all: libHYPRE_blas.a
|
||||
|
||||
install: all
|
||||
@cp -f f2c.h $$HYPRE_INSTALL_DIR/include/.
|
||||
@cp -f libHYPRE_*.a $$HYPRE_INSTALL_DIR/lib/.
|
||||
|
||||
clean:
|
||||
@rm -f *.o
|
||||
|
||||
veryclean: clean
|
||||
@rm -f libHYPRE_*.a
|
||||
|
||||
##################################################################
|
||||
# Rules
|
||||
##################################################################
|
||||
|
||||
libHYPRE_blas.a: ${OBJS}
|
||||
@echo "Building $@ ... "
|
||||
ar -rcu $@ ${OBJS}
|
||||
${RANLIB} $@
|
||||
|
||||
${OBJS}: ${HEADERS}
|
||||
|
||||
##################################################################
|
||||
# Generic rules
|
||||
##################################################################
|
||||
|
||||
.c.o:
|
||||
${CC} -o $@ -c ${CFLAGS} $<
|
||||
|
||||
.f.o:
|
||||
${F77} -o $@ -c ${FFLAGS} $<
|
||||
|
||||
82
blas/Makefile.in
Normal file
82
blas/Makefile.in
Normal file
@ -0,0 +1,82 @@
|
||||
#BHEADER***********************************************************************
|
||||
# (c) 1997 The Regents of the University of California
|
||||
#
|
||||
# See the file COPYRIGHT_and_DISCLAIMER for a complete copyright
|
||||
# notice, contact person, and disclaimer.
|
||||
#
|
||||
# $Revision$
|
||||
#EHEADER***********************************************************************
|
||||
|
||||
.SUFFIXES:
|
||||
.SUFFIXES: .c .f .o
|
||||
|
||||
srcdir = @srcdir@
|
||||
VPATH = @srcdir@
|
||||
|
||||
|
||||
CC = @CC@
|
||||
|
||||
C_COMPILE_FLAGS=@CFLAGS@
|
||||
CXX_COMPILE_FLAGS=@CXXFLAGS@
|
||||
F77_COMPILE_FLAGS=@F77FLAGS@
|
||||
CINCLUDES=@INCLUDES@
|
||||
CDEFS = -DHYPRE_NO_PTHREAD_MANGLING
|
||||
|
||||
CFLAGS =\
|
||||
-I.\
|
||||
${C_COMPILE_FLAGS}\
|
||||
${CINCLUDES}\
|
||||
${CDEFS}
|
||||
|
||||
RANLIB= @RANLIB@
|
||||
|
||||
LIBFLAGS = @LIBDIRS@ @LIBS@
|
||||
LDLIBFLAGS = @LDLIBDIRS@ @LDLIBS@
|
||||
|
||||
HEADERS =\
|
||||
f2c.h
|
||||
|
||||
FILES =\
|
||||
dcopy.c \
|
||||
ddot.c \
|
||||
dnrm2.c
|
||||
|
||||
OBJS = ${FILES:.c=.o}
|
||||
|
||||
##################################################################
|
||||
# Targets
|
||||
##################################################################
|
||||
|
||||
all: libHYPRE_blas.a
|
||||
|
||||
install: all
|
||||
@cp -f f2c.h $$HYPRE_INSTALL_DIR/include/.
|
||||
@cp -f libHYPRE_*.a $$HYPRE_INSTALL_DIR/lib/.
|
||||
|
||||
clean:
|
||||
@rm -f *.o
|
||||
|
||||
veryclean: clean
|
||||
@rm -f libHYPRE_*.a
|
||||
|
||||
##################################################################
|
||||
# Rules
|
||||
##################################################################
|
||||
|
||||
libHYPRE_blas.a: ${OBJS}
|
||||
@echo "Building $@ ... "
|
||||
ar -rcu $@ ${OBJS}
|
||||
${RANLIB} $@
|
||||
|
||||
${OBJS}: ${HEADERS}
|
||||
|
||||
##################################################################
|
||||
# Generic rules
|
||||
##################################################################
|
||||
|
||||
.c.o:
|
||||
${CC} -o $@ -c ${CFLAGS} $<
|
||||
|
||||
.f.o:
|
||||
${F77} -o $@ -c ${FFLAGS} $<
|
||||
|
||||
92
blas/dcopy.c
Normal file
92
blas/dcopy.c
Normal file
@ -0,0 +1,92 @@
|
||||
/* dcopy.f -- translated by f2c (version 19960315).
|
||||
You must link the resulting object file with the libraries:
|
||||
-lf2c -lm (in that order)
|
||||
*/
|
||||
|
||||
#include "f2c.h"
|
||||
|
||||
/* Subroutine */ int dcopy_(n, dx, incx, dy, incy)
|
||||
integer *n;
|
||||
doublereal *dx;
|
||||
integer *incx;
|
||||
doublereal *dy;
|
||||
integer *incy;
|
||||
{
|
||||
/* System generated locals */
|
||||
integer i__1;
|
||||
|
||||
/* Local variables */
|
||||
static integer i__, m, ix, iy, mp1;
|
||||
|
||||
|
||||
/* copies a vector, x, to a vector, y. */
|
||||
/* uses unrolled loops for increments equal to one. */
|
||||
/* jack dongarra, linpack, 3/11/78. */
|
||||
|
||||
|
||||
/* Parameter adjustments */
|
||||
--dy;
|
||||
--dx;
|
||||
|
||||
/* Function Body */
|
||||
if (*n <= 0) {
|
||||
return 0;
|
||||
}
|
||||
if (*incx == 1 && *incy == 1) {
|
||||
goto L20;
|
||||
}
|
||||
|
||||
/* code for unequal increments or equal increments */
|
||||
/* not equal to 1 */
|
||||
|
||||
ix = 1;
|
||||
iy = 1;
|
||||
if (*incx < 0) {
|
||||
ix = (-(*n) + 1) * *incx + 1;
|
||||
}
|
||||
if (*incy < 0) {
|
||||
iy = (-(*n) + 1) * *incy + 1;
|
||||
}
|
||||
i__1 = *n;
|
||||
for (i__ = 1; i__ <= i__1; ++i__) {
|
||||
dy[iy] = dx[ix];
|
||||
ix += *incx;
|
||||
iy += *incy;
|
||||
/* L10: */
|
||||
}
|
||||
return 0;
|
||||
|
||||
/* code for both increments equal to 1 */
|
||||
|
||||
|
||||
/* clean-up loop */
|
||||
|
||||
L20:
|
||||
m = *n % 7;
|
||||
if (m == 0) {
|
||||
goto L40;
|
||||
}
|
||||
i__1 = m;
|
||||
for (i__ = 1; i__ <= i__1; ++i__) {
|
||||
dy[i__] = dx[i__];
|
||||
/* L30: */
|
||||
}
|
||||
if (*n < 7) {
|
||||
return 0;
|
||||
}
|
||||
L40:
|
||||
mp1 = m + 1;
|
||||
i__1 = *n;
|
||||
for (i__ = mp1; i__ <= i__1; i__ += 7) {
|
||||
dy[i__] = dx[i__];
|
||||
dy[i__ + 1] = dx[i__ + 1];
|
||||
dy[i__ + 2] = dx[i__ + 2];
|
||||
dy[i__ + 3] = dx[i__ + 3];
|
||||
dy[i__ + 4] = dx[i__ + 4];
|
||||
dy[i__ + 5] = dx[i__ + 5];
|
||||
dy[i__ + 6] = dx[i__ + 6];
|
||||
/* L50: */
|
||||
}
|
||||
return 0;
|
||||
} /* dcopy_ */
|
||||
|
||||
96
blas/ddot.c
Normal file
96
blas/ddot.c
Normal file
@ -0,0 +1,96 @@
|
||||
/* ddot.f -- translated by f2c (version 19960315).
|
||||
You must link the resulting object file with the libraries:
|
||||
-lf2c -lm (in that order)
|
||||
*/
|
||||
|
||||
#include "f2c.h"
|
||||
|
||||
doublereal ddot_(n, dx, incx, dy, incy)
|
||||
integer *n;
|
||||
doublereal *dx;
|
||||
integer *incx;
|
||||
doublereal *dy;
|
||||
integer *incy;
|
||||
{
|
||||
/* System generated locals */
|
||||
integer i__1;
|
||||
doublereal ret_val;
|
||||
|
||||
/* Local variables */
|
||||
static integer i__, m;
|
||||
static doublereal dtemp;
|
||||
static integer ix, iy, mp1;
|
||||
|
||||
|
||||
/* forms the dot product of two vectors. */
|
||||
/* uses unrolled loops for increments equal to one. */
|
||||
/* jack dongarra, linpack, 3/11/78. */
|
||||
|
||||
|
||||
/* Parameter adjustments */
|
||||
--dy;
|
||||
--dx;
|
||||
|
||||
/* Function Body */
|
||||
ret_val = 0.;
|
||||
dtemp = 0.;
|
||||
if (*n <= 0) {
|
||||
return ret_val;
|
||||
}
|
||||
if (*incx == 1 && *incy == 1) {
|
||||
goto L20;
|
||||
}
|
||||
|
||||
/* code for unequal increments or equal increments */
|
||||
/* not equal to 1 */
|
||||
|
||||
ix = 1;
|
||||
iy = 1;
|
||||
if (*incx < 0) {
|
||||
ix = (-(*n) + 1) * *incx + 1;
|
||||
}
|
||||
if (*incy < 0) {
|
||||
iy = (-(*n) + 1) * *incy + 1;
|
||||
}
|
||||
i__1 = *n;
|
||||
for (i__ = 1; i__ <= i__1; ++i__) {
|
||||
dtemp += dx[ix] * dy[iy];
|
||||
ix += *incx;
|
||||
iy += *incy;
|
||||
/* L10: */
|
||||
}
|
||||
ret_val = dtemp;
|
||||
return ret_val;
|
||||
|
||||
/* code for both increments equal to 1 */
|
||||
|
||||
|
||||
/* clean-up loop */
|
||||
|
||||
L20:
|
||||
m = *n % 5;
|
||||
if (m == 0) {
|
||||
goto L40;
|
||||
}
|
||||
i__1 = m;
|
||||
for (i__ = 1; i__ <= i__1; ++i__) {
|
||||
dtemp += dx[i__] * dy[i__];
|
||||
/* L30: */
|
||||
}
|
||||
if (*n < 5) {
|
||||
goto L60;
|
||||
}
|
||||
L40:
|
||||
mp1 = m + 1;
|
||||
i__1 = *n;
|
||||
for (i__ = mp1; i__ <= i__1; i__ += 5) {
|
||||
dtemp = dtemp + dx[i__] * dy[i__] + dx[i__ + 1] * dy[i__ + 1] + dx[
|
||||
i__ + 2] * dy[i__ + 2] + dx[i__ + 3] * dy[i__ + 3] + dx[i__ +
|
||||
4] * dy[i__ + 4];
|
||||
/* L50: */
|
||||
}
|
||||
L60:
|
||||
ret_val = dtemp;
|
||||
return ret_val;
|
||||
} /* ddot_ */
|
||||
|
||||
213
blas/dnrm2.c
Normal file
213
blas/dnrm2.c
Normal file
@ -0,0 +1,213 @@
|
||||
/* dnrm2.f -- translated by f2c (version 19960315).
|
||||
You must link the resulting object file with the libraries:
|
||||
-lf2c -lm (in that order)
|
||||
*/
|
||||
|
||||
#include "f2c.h"
|
||||
|
||||
doublereal dnrm2_(n, dx, incx)
|
||||
integer *n;
|
||||
doublereal *dx;
|
||||
integer *incx;
|
||||
{
|
||||
/* Initialized data */
|
||||
|
||||
static doublereal zero = 0.;
|
||||
static doublereal one = 1.;
|
||||
static doublereal cutlo = 8.232e-11;
|
||||
static doublereal cuthi = 1.304e19;
|
||||
|
||||
/* Format strings */
|
||||
static char fmt_30[] = "";
|
||||
static char fmt_50[] = "";
|
||||
static char fmt_70[] = "";
|
||||
static char fmt_110[] = "";
|
||||
|
||||
/* System generated locals */
|
||||
integer i__1;
|
||||
doublereal ret_val, d__1;
|
||||
|
||||
/* Builtin functions */
|
||||
double sqrt();
|
||||
|
||||
/* Local variables */
|
||||
static doublereal xmax;
|
||||
static integer next, i__, j, ix;
|
||||
static doublereal hitest, sum;
|
||||
|
||||
/* Assigned format variables */
|
||||
static char *next_fmt;
|
||||
|
||||
/* Parameter adjustments */
|
||||
--dx;
|
||||
|
||||
/* Function Body */
|
||||
|
||||
/* euclidean norm of the n-vector stored in dx() with storage */
|
||||
/* increment incx . */
|
||||
/* if n .le. 0 return with result = 0. */
|
||||
/* if n .ge. 1 then incx must be .ge. 1 */
|
||||
|
||||
/* c.l.lawson, 1978 jan 08 */
|
||||
/* modified to correct failure to update ix, 1/25/92. */
|
||||
/* modified 3/93 to return if incx .le. 0. */
|
||||
|
||||
/* four phase method using two built-in constants that are */
|
||||
/* hopefully applicable to all machines. */
|
||||
/* cutlo = maximum of dsqrt(u/eps) over all known machines. */
|
||||
/* cuthi = minimum of dsqrt(v) over all known machines. */
|
||||
/* where */
|
||||
/* eps = smallest no. such that eps + 1. .gt. 1. */
|
||||
/* u = smallest positive no. (underflow limit) */
|
||||
/* v = largest no. (overflow limit) */
|
||||
|
||||
/* brief outline of algorithm.. */
|
||||
|
||||
/* phase 1 scans zero components. */
|
||||
/* move to phase 2 when a component is nonzero and .le. cutlo */
|
||||
/* move to phase 3 when a component is .gt. cutlo */
|
||||
/* move to phase 4 when a component is .ge. cuthi/m */
|
||||
/* where m = n for x() real and m = 2*n for complex. */
|
||||
|
||||
/* values for cutlo and cuthi.. */
|
||||
/* from the environmental parameters listed in the imsl converter */
|
||||
/* document the limiting values are as follows.. */
|
||||
/* cutlo, s.p. u/eps = 2**(-102) for honeywell. close seconds are
|
||||
*/
|
||||
/* univac and dec at 2**(-103) */
|
||||
/* thus cutlo = 2**(-51) = 4.44089e-16 */
|
||||
/* cuthi, s.p. v = 2**127 for univac, honeywell, and dec. */
|
||||
/* thus cuthi = 2**(63.5) = 1.30438e19 */
|
||||
/* cutlo, d.p. u/eps = 2**(-67) for honeywell and dec. */
|
||||
/* thus cutlo = 2**(-33.5) = 8.23181d-11 */
|
||||
/* cuthi, d.p. same as s.p. cuthi = 1.30438d19 */
|
||||
/* data cutlo, cuthi / 8.232d-11, 1.304d19 / */
|
||||
/* data cutlo, cuthi / 4.441e-16, 1.304e19 / */
|
||||
|
||||
if (*n > 0 && *incx > 0) {
|
||||
goto L10;
|
||||
}
|
||||
ret_val = zero;
|
||||
goto L300;
|
||||
|
||||
L10:
|
||||
next = 0;
|
||||
next_fmt = fmt_30;
|
||||
sum = zero;
|
||||
i__ = 1;
|
||||
ix = 1;
|
||||
/* begin main loop */
|
||||
L20:
|
||||
switch ((int)next) {
|
||||
case 0: goto L30;
|
||||
case 1: goto L50;
|
||||
case 2: goto L70;
|
||||
case 3: goto L110;
|
||||
}
|
||||
L30:
|
||||
if ((d__1 = dx[i__], abs(d__1)) > cutlo) {
|
||||
goto L85;
|
||||
}
|
||||
next = 1;
|
||||
next_fmt = fmt_50;
|
||||
xmax = zero;
|
||||
|
||||
/* phase 1. sum is zero */
|
||||
|
||||
L50:
|
||||
if (dx[i__] == zero) {
|
||||
goto L200;
|
||||
}
|
||||
if ((d__1 = dx[i__], abs(d__1)) > cutlo) {
|
||||
goto L85;
|
||||
}
|
||||
|
||||
/* prepare for phase 2. */
|
||||
next = 2;
|
||||
next_fmt = fmt_70;
|
||||
goto L105;
|
||||
|
||||
/* prepare for phase 4. */
|
||||
|
||||
L100:
|
||||
ix = j;
|
||||
next = 3;
|
||||
next_fmt = fmt_110;
|
||||
sum = sum / dx[i__] / dx[i__];
|
||||
L105:
|
||||
xmax = (d__1 = dx[i__], abs(d__1));
|
||||
goto L115;
|
||||
|
||||
/* phase 2. sum is small. */
|
||||
/* scale to avoid destructive underflow. */
|
||||
|
||||
L70:
|
||||
if ((d__1 = dx[i__], abs(d__1)) > cutlo) {
|
||||
goto L75;
|
||||
}
|
||||
|
||||
/* common code for phases 2 and 4. */
|
||||
/* in phase 4 sum is large. scale to avoid overflow.
|
||||
*/
|
||||
|
||||
L110:
|
||||
if ((d__1 = dx[i__], abs(d__1)) <= xmax) {
|
||||
goto L115;
|
||||
}
|
||||
/* Computing 2nd power */
|
||||
d__1 = xmax / dx[i__];
|
||||
sum = one + sum * (d__1 * d__1);
|
||||
xmax = (d__1 = dx[i__], abs(d__1));
|
||||
goto L200;
|
||||
|
||||
L115:
|
||||
/* Computing 2nd power */
|
||||
d__1 = dx[i__] / xmax;
|
||||
sum += d__1 * d__1;
|
||||
goto L200;
|
||||
|
||||
|
||||
/* prepare for phase 3. */
|
||||
|
||||
L75:
|
||||
sum = sum * xmax * xmax;
|
||||
|
||||
|
||||
/* for real or d.p. set hitest = cuthi/n */
|
||||
/* for complex set hitest = cuthi/(2*n) */
|
||||
|
||||
L85:
|
||||
hitest = cuthi / (real) (*n);
|
||||
|
||||
/* phase 3. sum is mid-range. no scaling. */
|
||||
|
||||
i__1 = *n;
|
||||
for (j = ix; j <= i__1; ++j) {
|
||||
if ((d__1 = dx[i__], abs(d__1)) >= hitest) {
|
||||
goto L100;
|
||||
}
|
||||
/* Computing 2nd power */
|
||||
d__1 = dx[i__];
|
||||
sum += d__1 * d__1;
|
||||
i__ += *incx;
|
||||
/* L95: */
|
||||
}
|
||||
ret_val = sqrt(sum);
|
||||
goto L300;
|
||||
|
||||
L200:
|
||||
++ix;
|
||||
i__ += *incx;
|
||||
if (ix <= *n) {
|
||||
goto L20;
|
||||
}
|
||||
|
||||
/* end of main loop. */
|
||||
|
||||
/* compute square root and adjust for scaling. */
|
||||
|
||||
ret_val = xmax * sqrt(sum);
|
||||
L300:
|
||||
return ret_val;
|
||||
} /* dnrm2_ */
|
||||
|
||||
231
blas/f2c.h
Normal file
231
blas/f2c.h
Normal file
@ -0,0 +1,231 @@
|
||||
/* f2c.h -- Standard Fortran to C header file */
|
||||
|
||||
/** barf [ba:rf] 2. "He suggested using FORTRAN, and everybody barfed."
|
||||
|
||||
- From The Shogakukan DICTIONARY OF NEW ENGLISH (Second edition) */
|
||||
|
||||
#ifndef F2C_INCLUDE
|
||||
#define F2C_INCLUDE
|
||||
|
||||
/* F2C_INTEGER will normally be `int' but would be `long' on 16-bit systems */
|
||||
/* we assume short, float are OK */
|
||||
typedef long int /* long int */ integer;
|
||||
typedef unsigned long int /* long */ uinteger;
|
||||
typedef char *address;
|
||||
typedef short int shortint;
|
||||
typedef float real;
|
||||
typedef double doublereal;
|
||||
typedef struct { real r, i; } complex;
|
||||
typedef struct { doublereal r, i; } doublecomplex;
|
||||
typedef long int /* long int */ logical;
|
||||
typedef short int shortlogical;
|
||||
typedef char logical1;
|
||||
typedef char integer1;
|
||||
/* integer*8 support from f2c not currently supported: */
|
||||
#if 0
|
||||
typedef @F2C_LONGINT@ /* long long */ longint; /* system-dependent */
|
||||
typedef unsigned @F2C_LONGINT@ ulongint; /* system-dependent */
|
||||
#define qbit_clear(a,b) ((a) & ~((ulongint)1 << (b)))
|
||||
#define qbit_set(a,b) ((a) | ((ulongint)1 << (b)))
|
||||
#endif
|
||||
typedef long long int longint;
|
||||
|
||||
#define TRUE_ (1)
|
||||
#define FALSE_ (0)
|
||||
|
||||
/* Extern is for use with -E */
|
||||
#ifndef Extern
|
||||
#define Extern extern
|
||||
#endif
|
||||
|
||||
/* I/O stuff */
|
||||
|
||||
#ifdef f2c_i2
|
||||
#error f2c_i2 will not work with g77!!!!
|
||||
/* for -i2 */
|
||||
typedef short flag;
|
||||
typedef short ftnlen;
|
||||
typedef short ftnint;
|
||||
#else
|
||||
typedef long int /* int or long int */ flag;
|
||||
typedef long int /* int or long int */ ftnlen;
|
||||
typedef long int /* int or long int */ ftnint;
|
||||
#endif
|
||||
|
||||
/*external read, write*/
|
||||
typedef struct
|
||||
{ flag cierr;
|
||||
ftnint ciunit;
|
||||
flag ciend;
|
||||
char *cifmt;
|
||||
ftnint cirec;
|
||||
} cilist;
|
||||
|
||||
/*internal read, write*/
|
||||
typedef struct
|
||||
{ flag icierr;
|
||||
char *iciunit;
|
||||
flag iciend;
|
||||
char *icifmt;
|
||||
ftnint icirlen;
|
||||
ftnint icirnum;
|
||||
} icilist;
|
||||
|
||||
/*open*/
|
||||
typedef struct
|
||||
{ flag oerr;
|
||||
ftnint ounit;
|
||||
char *ofnm;
|
||||
ftnlen ofnmlen;
|
||||
char *osta;
|
||||
char *oacc;
|
||||
char *ofm;
|
||||
ftnint orl;
|
||||
char *oblnk;
|
||||
} olist;
|
||||
|
||||
/*close*/
|
||||
typedef struct
|
||||
{ flag cerr;
|
||||
ftnint cunit;
|
||||
char *csta;
|
||||
} cllist;
|
||||
|
||||
/*rewind, backspace, endfile*/
|
||||
typedef struct
|
||||
{ flag aerr;
|
||||
ftnint aunit;
|
||||
} alist;
|
||||
|
||||
/* inquire */
|
||||
typedef struct
|
||||
{ flag inerr;
|
||||
ftnint inunit;
|
||||
char *infile;
|
||||
ftnlen infilen;
|
||||
ftnint *inex; /*parameters in standard's order*/
|
||||
ftnint *inopen;
|
||||
ftnint *innum;
|
||||
ftnint *innamed;
|
||||
char *inname;
|
||||
ftnlen innamlen;
|
||||
char *inacc;
|
||||
ftnlen inacclen;
|
||||
char *inseq;
|
||||
ftnlen inseqlen;
|
||||
char *indir;
|
||||
ftnlen indirlen;
|
||||
char *infmt;
|
||||
ftnlen infmtlen;
|
||||
char *inform;
|
||||
ftnint informlen;
|
||||
char *inunf;
|
||||
ftnlen inunflen;
|
||||
ftnint *inrecl;
|
||||
ftnint *innrec;
|
||||
char *inblank;
|
||||
ftnlen inblanklen;
|
||||
} inlist;
|
||||
|
||||
#define VOID void
|
||||
|
||||
union Multitype { /* for multiple entry points */
|
||||
integer1 g;
|
||||
shortint h;
|
||||
integer i;
|
||||
/* longint j; */
|
||||
real r;
|
||||
doublereal d;
|
||||
complex c;
|
||||
doublecomplex z;
|
||||
};
|
||||
|
||||
typedef union Multitype Multitype;
|
||||
|
||||
/*typedef long int Long;*/ /* No longer used; formerly in Namelist */
|
||||
|
||||
struct Vardesc { /* for Namelist */
|
||||
char *name;
|
||||
char *addr;
|
||||
ftnlen *dims;
|
||||
int type;
|
||||
};
|
||||
typedef struct Vardesc Vardesc;
|
||||
|
||||
struct Namelist {
|
||||
char *name;
|
||||
Vardesc **vars;
|
||||
int nvars;
|
||||
};
|
||||
typedef struct Namelist Namelist;
|
||||
|
||||
#define abs(x) ((x) >= 0 ? (x) : -(x))
|
||||
#define dabs(x) (doublereal)abs(x)
|
||||
#define min(a,b) ((a) <= (b) ? (a) : (b))
|
||||
#define max(a,b) ((a) >= (b) ? (a) : (b))
|
||||
#define dmin(a,b) (doublereal)min(a,b)
|
||||
#define dmax(a,b) (doublereal)max(a,b)
|
||||
#define bit_test(a,b) ((a) >> (b) & 1)
|
||||
#define bit_clear(a,b) ((a) & ~((uinteger)1 << (b)))
|
||||
#define bit_set(a,b) ((a) | ((uinteger)1 << (b)))
|
||||
|
||||
/* procedure parameter types for -A and -C++ */
|
||||
|
||||
#define F2C_proc_par_types 1
|
||||
#ifdef __cplusplus
|
||||
typedef int /* Unknown procedure type */ (*U_fp)(...);
|
||||
typedef shortint (*J_fp)(...);
|
||||
typedef integer (*I_fp)(...);
|
||||
typedef real (*R_fp)(...);
|
||||
typedef doublereal (*D_fp)(...), (*E_fp)(...);
|
||||
typedef /* Complex */ VOID (*C_fp)(...);
|
||||
typedef /* Double Complex */ VOID (*Z_fp)(...);
|
||||
typedef logical (*L_fp)(...);
|
||||
typedef shortlogical (*K_fp)(...);
|
||||
typedef /* Character */ VOID (*H_fp)(...);
|
||||
typedef /* Subroutine */ int (*S_fp)(...);
|
||||
#else
|
||||
typedef int /* Unknown procedure type */ (*U_fp)();
|
||||
typedef shortint (*J_fp)();
|
||||
typedef integer (*I_fp)();
|
||||
typedef real (*R_fp)();
|
||||
typedef doublereal (*D_fp)(), (*E_fp)();
|
||||
typedef /* Complex */ VOID (*C_fp)();
|
||||
typedef /* Double Complex */ VOID (*Z_fp)();
|
||||
typedef logical (*L_fp)();
|
||||
typedef shortlogical (*K_fp)();
|
||||
typedef /* Character */ VOID (*H_fp)();
|
||||
typedef /* Subroutine */ int (*S_fp)();
|
||||
#endif
|
||||
/* E_fp is for real functions when -R is not specified */
|
||||
typedef VOID C_f; /* complex function */
|
||||
typedef VOID H_f; /* character function */
|
||||
typedef VOID Z_f; /* double complex function */
|
||||
typedef doublereal E_f; /* real function with -R not specified */
|
||||
|
||||
/* undef any lower-case symbols that your C compiler predefines, e.g.: */
|
||||
|
||||
#ifndef Skip_f2c_Undefs
|
||||
/* (No such symbols should be defined in a strict ANSI C compiler.
|
||||
We can avoid trouble with f2c-translated code by using
|
||||
gcc -ansi [-traditional].) */
|
||||
#undef cray
|
||||
#undef gcos
|
||||
#undef mc68010
|
||||
#undef mc68020
|
||||
#undef mips
|
||||
#undef pdp11
|
||||
#undef sgi
|
||||
#undef sparc
|
||||
#undef sun
|
||||
#undef sun2
|
||||
#undef sun3
|
||||
#undef sun4
|
||||
#undef u370
|
||||
#undef u3b
|
||||
#undef u3b2
|
||||
#undef u3b5
|
||||
#undef unix
|
||||
#undef vax
|
||||
#endif
|
||||
#endif
|
||||
BIN
blas/libf2c.a
Normal file
BIN
blas/libf2c.a
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user