⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dbdsdc.c

📁 最著名最快的分子模拟软件
💻 C
字号:
#include <ctype.h>#include <math.h>#include "gmx_blas.h"#include "gmx_lapack.h"#include "lapack_limits.h"#include <types/simple.h>voidF77_FUNC(dbdsdc,DBDSDC)(char *uplo, 	char *compq, 	int *n,	double *d__, 	double *e, 	double *u, 	int *ldu,	double *vt, 	int *ldvt,	double *q,	int *iq,	double *work, 	int *iwork, 	int *info){    int u_dim1, u_offset, vt_dim1, vt_offset, i__1, i__2;    int i__, j, k;    double p, r__;    int z__, ic, ii, kk;    double cs;    int is, iu;    double sn;    int nm1;    double eps;    int ivt, difl, difr, ierr, perm, mlvl, sqre;    int poles, iuplo, nsize, start;    int givcol;    int icompq;    double orgnrm;    int givnum, givptr, qstart, smlsiz, wstart, smlszp;    double zero = 0.0;    double one = 1.0;    int c_0 = 0;    int c_1 = 1;    --d__;    --e;    u_dim1 = *ldu;    u_offset = 1 + u_dim1;    u -= u_offset;    vt_dim1 = *ldvt;    vt_offset = 1 + vt_dim1;    vt -= vt_offset;    --q;    --iq;    --work;    --iwork;    k = iu = z__ = ic = is = ivt = difl = difr = perm = 0;    poles = givnum = givptr = givcol = 0;        smlsiz = DBDSDC_SMALLSIZE;    *info = 0;    iuplo = (*uplo=='U' || *uplo=='u') ? 1 : 2;    switch(*compq) {    case 'n':    case 'N':      icompq = 0;      break;    case 'p':    case 'P':      icompq = 1;      break;    case 'i':    case 'I':      icompq = 2;      break;    default:      return;    }    if (*n <= 0) 	return;        if (*n == 1) {	if (icompq == 1) {	  q[1] = (d__[1]>0) ? 1.0 : -1.0;	  q[smlsiz * *n + 1] = 1.;	} else if (icompq == 2) {	  u[u_dim1 + 1] = (d__[1]>0) ? 1.0 : -1.0;	  vt[vt_dim1 + 1] = 1.;	}	d__[1] = fabs(d__[1]);	return;    }    nm1 = *n - 1;    wstart = 1;    qstart = 3;    if (icompq == 1) {	F77_FUNC(dcopy,DCOPY)(n, &d__[1], &c_1, &q[1], &c_1);	i__1 = *n - 1;	F77_FUNC(dcopy,DCOPY)(&i__1, &e[1], &c_1, &q[*n + 1], &c_1);    }    if (iuplo == 2) {	qstart = 5;	wstart = (*n << 1) - 1;	i__1 = *n - 1;	for (i__ = 1; i__ <= i__1; ++i__) {	    F77_FUNC(dlartg,DLARTG)(&d__[i__], &e[i__], &cs, &sn, &r__);	    d__[i__] = r__;	    e[i__] = sn * d__[i__ + 1];	    d__[i__ + 1] = cs * d__[i__ + 1];	    if (icompq == 1) {		q[i__ + (*n << 1)] = cs;		q[i__ + *n * 3] = sn;	    } else if (icompq == 2) {		work[i__] = cs;		work[nm1 + i__] = -sn;	    }	}    }    if (icompq == 0) {      F77_FUNC(dlasdq,DLASDQ)("U",&c_0,n,&c_0,&c_0,&c_0,&d__[1],&e[1],&vt[vt_offset],ldvt,	      &u[u_offset], ldu, &u[u_offset], ldu, &work[wstart], info);	goto L40;    }    if (*n <= smlsiz) {	if (icompq == 2) {	    F77_FUNC(dlaset,DLASET)("A", n, n, &zero, &one, &u[u_offset], ldu);	    F77_FUNC(dlaset,DLASET)("A", n, n, &zero, &one, &vt[vt_offset], ldvt);	    F77_FUNC(dlasdq,DLASDQ)("U",&c_0,n,n,n,&c_0,&d__[1],&e[1],&vt[vt_offset],ldvt,		    &u[u_offset],ldu,&u[u_offset],ldu,&work[wstart],info);	} else if (icompq == 1) {	    iu = 1;	    ivt = iu + *n;	    F77_FUNC(dlaset,DLASET)("A", n, n, &zero, &one, &q[iu + (qstart - 1) * *n], n);	    F77_FUNC(dlaset,DLASET)("A", n, n, &zero, &one, &q[ivt + (qstart - 1) * *n], n);	    F77_FUNC(dlasdq,DLASDQ)("U", &c_0, n, n, n, &c_0, &d__[1], &e[1], 		    &q[ivt + (qstart - 1) * *n], n, &q[iu + (qstart - 1) * *n], 		    n, &q[iu + (qstart - 1) * *n], n, &work[wstart], info);	}	goto L40;    }    if (icompq == 2) {	F77_FUNC(dlaset,DLASET)("A", n, n, &zero, &one, &u[u_offset], ldu);	F77_FUNC(dlaset,DLASET)("A", n, n, &zero, &one, &vt[vt_offset], ldvt);    }    orgnrm = F77_FUNC(dlanst,DLANST)("M", n, &d__[1], &e[1]);    if ( fabs(orgnrm)<GMX_DOUBLE_MIN) {	return;    }    F77_FUNC(dlascl,DLASCL)("G", &c_0, &c_0, &orgnrm, &one, n, &c_1, &d__[1], n, &ierr);    F77_FUNC(dlascl,DLASCL)("G", &c_0, &c_0, &orgnrm, &one, &nm1, &c_1, &e[1], &nm1, &ierr);    eps = GMX_DOUBLE_EPS;    mlvl = (int) (log((double) (*n) / (double) (smlsiz + 1)) / 	    log(2.)) + 1;    smlszp = smlsiz + 1;    if (icompq == 1) {	iu = 1;	ivt = smlsiz + 1;	difl = ivt + smlszp;	difr = difl + mlvl;	z__ = difr + (mlvl << 1);	ic = z__ + mlvl;	is = ic + 1;	poles = is + 1;	givnum = poles + (mlvl << 1);	k = 1;	givptr = 2;	perm = 3;	givcol = perm + mlvl;    }    i__1 = *n;    for (i__ = 1; i__ <= i__1; ++i__) {	if (fabs(d__[i__]) < eps) 	    d__[i__] = (d__[i__]>0) ? eps : -eps;    }    start = 1;    sqre = 0;    i__1 = nm1;    for (i__ = 1; i__ <= i__1; ++i__) {	if (fabs(e[i__]) < eps || i__ == nm1) {	    if (i__ < nm1) {		nsize = i__ - start + 1;	    } else if (fabs(e[i__]) >= eps) {		nsize = *n - start + 1;	    } else {		nsize = i__ - start + 1;		if (icompq == 2) {		    u[*n + *n * u_dim1] = (d__[*n]>0) ? 1.0 : -1.0; 		    vt[*n + *n * vt_dim1] = 1.;		} else if (icompq == 1) {		    q[*n + (qstart - 1) * *n] = (d__[*n]>0) ? 1.0 : -1.0; 		    q[*n + (smlsiz + qstart - 1) * *n] = 1.;		}		d__[*n] = fabs(d__[*n]);	    }	    if (icompq == 2) {		F77_FUNC(dlasd0,DLASD0)(&nsize, &sqre, &d__[start], &e[start], 			&u[start + start * u_dim1], ldu, 			&vt[start + start * vt_dim1], 			ldvt, &smlsiz, &iwork[1], &work[wstart], info);	    } else {		F77_FUNC(dlasda,DLASDA)(&icompq, &smlsiz, &nsize, &sqre, &d__[start], 			&e[start], &q[start + (iu + qstart - 2) * *n], n, 			&q[start + (ivt + qstart - 2) * *n], &iq[start + k * *n],			&q[start + (difl + qstart - 2) * *n], 			&q[start + (difr + qstart - 2) * *n], 			&q[start + (z__ + qstart - 2) * *n], 			&q[start + (poles + qstart - 2) * *n], 			&iq[start + givptr * *n], &iq[start + givcol * *n], n, 			&iq[start + perm * *n], 			&q[start + (givnum + qstart - 2) * *n], 			&q[start + (ic + qstart - 2) * *n], 			&q[start + (is + qstart - 2) * *n], &work[wstart], 			&iwork[1], info);		if (*info != 0) {		    return;		}	    }	    start = i__ + 1;	}    }    F77_FUNC(dlascl,DLASCL)("G", &c_0, &c_0, &one, &orgnrm, n, &c_1, &d__[1], n, &ierr);L40:    i__1 = *n;    for (ii = 2; ii <= i__1; ++ii) {	i__ = ii - 1;	kk = i__;	p = d__[i__];	i__2 = *n;	for (j = ii; j <= i__2; ++j) {	    if (d__[j] > p) {		kk = j;		p = d__[j];	    }	}	if (kk != i__) {	    d__[kk] = d__[i__];	    d__[i__] = p;	    if (icompq == 1) {		iq[i__] = kk;	    } else if (icompq == 2) {		F77_FUNC(dswap,DSWAP)(n, &u[i__ * u_dim1 + 1],&c_1,&u[kk*u_dim1+1],&c_1);		F77_FUNC(dswap,DSWAP)(n, &vt[i__ + vt_dim1], ldvt, &vt[kk + vt_dim1], ldvt);	    }	} else if (icompq == 1) {	    iq[i__] = i__;	}    }    if (icompq == 1) {	if (iuplo == 1) {	    iq[*n] = 1;	} else {	    iq[*n] = 0;	}    }    if (iuplo == 2 && icompq == 2) {	F77_FUNC(dlasr,DLASR)("L", "V", "B", n, n, &work[1], &work[*n], &u[u_offset], ldu);    }    return;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -