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

📄 dlaev2.c

📁 最著名最快的分子模拟软件
💻 C
字号:
#include <math.h>#include <types/simple.h>#include "gmx_lapack.h"voidF77_FUNC(dlaev2,DLAEV2)(double *   a, 	double *   b, 	double *   c__, 	double *   rt1, 	double *   rt2, 	double *   cs1, 	double *   sn1){    double d__1;    double ab, df, cs, ct, tb, sm, tn, rt, adf, acs;    int sgn1, sgn2;    double acmn, acmx;    sm = *a + *c__;    df = *a - *c__;    adf = fabs(df);    tb = *b + *b;    ab = fabs(tb);    if (fabs(*a) > fabs(*c__)) {	acmx = *a;	acmn = *c__;    } else {	acmx = *c__;	acmn = *a;    }    if (adf > ab) {	d__1 = ab / adf;	rt = adf * sqrt(d__1 * d__1 + 1.);    } else if (adf < ab) {	d__1 = adf / ab;	rt = ab * sqrt(d__1 * d__1 + 1.);    } else {	rt = ab * sqrt(2.);    }    if (sm < 0.) {	*rt1 = (sm - rt) * .5;	sgn1 = -1;	*rt2 = acmx / *rt1 * acmn - *b / *rt1 * *b;    } else if (sm > 0.) {	*rt1 = (sm + rt) * .5;	sgn1 = 1;	*rt2 = acmx / *rt1 * acmn - *b / *rt1 * *b;    } else {	*rt1 = rt * .5;	*rt2 = rt * -.5;	sgn1 = 1;    }    if (df >= 0.) {	cs = df + rt;	sgn2 = 1;    } else {	cs = df - rt;	sgn2 = -1;    }    acs = fabs(cs);    if (acs > ab) {	ct = -tb / cs;	*sn1 = 1. / sqrt(ct * ct + 1.);	*cs1 = ct * *sn1;    } else {	if (fabs(ab)<GMX_DOUBLE_MIN) {	    *cs1 = 1.;	    *sn1 = 0.;	} else {	    tn = -cs / tb;	    *cs1 = 1. / sqrt(tn * tn + 1.);	    *sn1 = tn * *cs1;	}    }    if (sgn1 == sgn2) {	tn = *cs1;	*cs1 = -(*sn1);	*sn1 = tn;    }    return;}

⌨️ 快捷键说明

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