// LAPACK++ (V. 1.1)
// (C) 1992-1996 All Rights Reserved.
// Double precision Lapack routines
#ifndef _DLAPACK_H_
#define _DLAPACK_H_
#ifndef _ARCH_H_
#include "arch.h"
#endif
#include "f2c.h"
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
// *************************** Utility Routines **********************
double F77NAME(dlamch)(char *t);
//******************** Linear Equation Solvers *************************
// general matrix
void F77NAME(dgesv)(integer *n, integer *k, doublereal *A, integer *lda, integer *ipiv,
doublereal *X, integer *ldx, integer *info);
// banded matrix
void F77NAME(dgbsv)(integer *n, integer *KL, integer *KU, integer *NRHS,
doublereal *AB, integer *ldab, integer *ipiv,
doublereal *B, integer *ldb, integer *info);
// positiv semidifinite matrix
void F77NAME(dposv)(char *uplo, integer *m, integer *k , doublereal *A, integer *lda,
doublereal *X, integer *ldx, integer *info);
// symmetric matrix
void F77NAME(dsysv)(const char *uplo, integer *n, integer *nrhs,
doublereal *A, integer *lda,
integer *ipiv,
doublereal *B, integer *ldb,
doublereal *work, integer *lwork, integer *info);
//******************** Lapack Utility Routines ************************
void F77NAME(dgels)(char *trans, integer *m, integer *n, integer *nrhs, doublereal *A,
integer *lda, doublereal *B, integer *ldb, doublereal *work, integer *lwork, integer *info);
void F77NAME(dtimmg)(integer *iflag, integer *m, integer *n, doublereal *A, integer *lda,
integer *kl, integer *ku);
void F77NAME(dlaswp)(integer *n, doublereal *A, integer *lda, integer *k1, integer *k2,
integer *ipiv, integer *incx);
doublereal F77NAME(dopla)(char *subname, integer *m, integer *n, integer *kl, integer *ku,
integer *nb);
// ******************* LU Factorization Routines **********************
void F77NAME(dgetrf)(integer *m, integer *n, doublereal *A, integer *lda, integer *ipiv,
integer *info);
void F77NAME(dgetri)(integer *n, doublereal *A, integer *lda, integer *ipiv,
doublereal *work, integer *lwork, integer *info);
void F77NAME(dgetf2)(integer *m, integer *n, doublereal *A, integer *lda, integer *ipiv,
integer *info);
void F77NAME(dgbtrf)(integer *m, integer *n, integer *KL, integer *KU, doublereal *BM,
integer *LDBM, integer *ipiv, integer *info);
void F77NAME(dgttrf)(integer *N, doublereal *DL, doublereal *D, doublereal *DU,
doublereal *DU2, integer *ipiv, integer *info);
void F77NAME(dpotrf)(char *UPLO, integer *N, doublereal *SM, integer *LDSM,
integer *info);
void F77NAME(dsytrf)(char *UPLO, integer *N, doublereal *SM, integer *LDSM,
integer *ipiv, doublereal *WORK, integer *LWORK, integer *info);
void F77NAME(dpbtrf)(char *UPLO, integer *N, integer *KD, doublereal *SBM,
integer *LDSM, integer *info);
void F77NAME(dpttrf)(integer *N, doublereal *D, doublereal *E, integer *info);
void F77NAME(dgecon)(char *norm, integer *n, double *a,
integer *lda, double *anorm, double *rcond,
double *work, integer *iwork,
integer *info);
// ********************* LU Solve Routines ***************************
void F77NAME(dgetrs)(char *trans, integer *N, integer *nrhs, doublereal *A, integer *lda,
integer * ipiv, doublereal *b, integer *ldb, integer *info);
void F77NAME(dgbtrs)(char *trans, integer *N, integer *kl, integer *ku, integer *nrhs,
doublereal *AB, integer *ldab, integer *ipiv, doublereal *b, integer *ldb, integer *info);
void F77NAME(dsytrs)(char *uplo, integer *N, integer *nrhs, doublereal *A, integer *lda,
integer *ipiv, doublereal *b, integer *ldb, integer *info);
void F77NAME(dgttrs)(char *trans, integer *N, integer *nrhs, doublereal *DL,
doublereal *D, doublereal *DU, doublereal *DU2, integer *ipiv, doublereal *b,
integer *ldb, integer *info);
void F77NAME(dpotrs)(char *UPLO, integer *N, integer *nrhs, doublereal *A, integer *LDA,
doublereal *b, integer *ldb, integer *info);
void F77NAME(dpttrs)(integer *N, integer *nrhs, doublereal *D, doublereal *E,
doublereal *b, integer *ldb, integer *info);
void F77NAME(dpbtrs)(char *UPLO, integer *N, integer *KD, integer *nrhs, doublereal *AB,
integer *LDAB, doublereal *b, integer *ldb, integer *info);
// ********************* Eigen Solve Routines ***************************
void F77NAME(dsyev)(char *jobz, char *uplo, integer *N, doublereal *S,
integer *lda, doublereal *eig, doublereal *work, integer *lwork, integer *info);
void F77NAME(dgeev)(char *jobvl, char *jobvr, integer *N, doublereal *A,
integer *lda, doublereal *wr, doublereal *wi, doublereal *vl, integer *ldvl,
doublereal *vr, integer *ldvr, doublereal *work, integer *lwork, integer *info);
// ********************* Eigenvalue/Singular Value Decomposition Drivers
void F77NAME(dsyevd)(char *jobz, char *uplo, integer *n, double *a, integer *lda, double *w, integer *info);
void F77NAME(dsyevr)(char *jobz, char *range, char *uplo, integer *n, double *a, integer *lda, double *vl, double *vu, integer *il, integer *iu, double *abstol, integer *m, double *w, double *z, integer *ldz, integer *isuppz, integer *info);
void F77NAME(dgesvd)(char *jobu, char *jobvt, integer *m, integer *n, double *a, integer *lda, double *sing, double *u, integer *ldu, double *vt, integer *ldvt, double *work, integer *lwork, integer *info);
void F77NAME(dgesdd)(char *jobz, integer *m, integer *n, double *a, integer *lda, double *s, double *u, integer *ldu, double *vt, integer *ldvt, double *work, integer *lwork, integer *iwork, integer *info);
// *******************************
#ifdef __cplusplus
}
#endif /* __cplusplus */
#endif
syntax highlighted by Code2HTML, v. 0.9.1