nrm2_ssqr1_x1.c
来自「基于Blas CLapck的.用过的人知道是干啥的」· C语言 代码 · 共 140 行
C
140 行
#include "atlas_misc.h"#include <math.h>static void SSQ(const int N, const TYPE *X, const int incX, TYPE *scal0, TYPE *ssq0){ TYPE t0, ax, ssq=(*ssq0), scal=(*scal0); int i; if (scal == ATL_rzero) /* need to start ops */ { for (i=0; i < N && X[i] == ATL_rzero; i++); if (i < N) { scal = fabs(X[i]); ssq = ATL_rone; i++; } else return; } else i = 0; for (; i < N; i++) { ax = fabs(X[i]); if (scal >= ax) { t0 = ax / scal; ssq += t0*t0; } else { t0 = scal / ax; t0 *= t0; ssq = ATL_rone + ssq * t0; scal = ax; } } *ssq0 = ssq; *scal0 = scal;}#include <float.h>#if FLT_RADIX != 2 #define SSQr SSQ#else /* SSQr depends on using power of 2 storage */ #ifdef SREAL #define ATL_MIN_EXP FLT_MIN_EXP #define ATL_MAX_EXP FLT_MAX_EXP #else #define ATL_MIN_EXP DBL_MIN_EXP #define ATL_MAX_EXP DBL_MAX_EXP #endifstatic TYPE RecipScal(TYPE scal)/* * We guarantee this function never called with scal of 0, so returning * zero indicates it is not safe to recipricate the number scal. Otherwise, * the function returns 1 / scal */{/* * Use smallest max exponent so that it can be reciprocated in both directions */ static const int maxexp = Mmin(ATL_MAX_EXP, -ATL_MIN_EXP); TYPE mant, rscal=ATL_rzero; int iexp, j; mant = frexp(scal, &iexp); mant = 0.5 / mant; mant = frexp(mant, &j); iexp = 1 + j - iexp; if (Mabs(iexp) < maxexp) rscal = ldexp(mant, iexp); return(rscal);}static void SSQr(const int N, const TYPE *X, const int incX, TYPE *scal0, TYPE *ssq0){ TYPE t0, ax, ssq=(*ssq0), scal=(*scal0), rscal; int i, iexp; if (scal == ATL_rzero) /* need to start ops */ { for (i=0; i < N && X[i] == ATL_rzero; i++); if (i < N) { scal = fabs(X[i]); ssq = ATL_rone; i++; } else return; } else i = 0; rscal = RecipScal(scal); if (rscal == ATL_rzero) /* not safe to reciprocate, call non-rec SSQ */ { *scal0 = scal; *ssq0 = ssq; SSQ(N-i, X+i, 1, scal0, ssq0); return; } for (; i < N; i++) { ax = fabs(X[i]); if (scal >= ax) { t0 = ax * rscal; ssq += t0*t0; } else /* getting new scal */ { rscal = RecipScal(ax); if (rscal != ATL_rzero) { t0 = scal * rscal; t0 *= t0; ssq = ATL_rone + ssq * t0; scal = ax; } else /* need to use non-rec SSQ */ { *scal0 = scal; *ssq0 = ssq; SSQ(N-i, X+i, incX, scal0, ssq0); return; } } } *ssq0 = ssq; *scal0 = scal;}#endifTYPE ATL_UNRM2(const int N, const TYPE *X, const int incX){ TYPE ssq=ATL_rone, scal=ATL_rzero; if (N > 1) SSQr(N, X, incX, &scal, &ssq); else if (N == 1) return(fabs(*X)); return(scal * sqrt(ssq));}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?