nrm2_ssq1_x0.c
来自「基于Blas CLapck的.用过的人知道是干啥的」· C语言 代码 · 共 52 行
C
52 行
#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); const TYPE *stX = X + N*incX; if (scal == ATL_rzero) /* need to start ops */ { while (X != stX && *X == ATL_rzero) X += incX; if (X != stX) { scal = fabs(*X); ssq = ATL_rone; X += incX; } else return; } if (X != stX) { do { ax = fabs(*X); X += incX; if (scal >= ax) { t0 = ax / scal; ssq += t0*t0; } else { t0 = scal / ax; t0 *= t0; ssq = ATL_rone + ssq * t0; scal = ax; } } while (X != stX); } *ssq0 = ssq; *scal0 = scal;}TYPE ATL_UNRM2(const int N, const TYPE *X, const int incX){ TYPE ssq=ATL_rone, scal=ATL_rzero; if (N > 1) SSQ(N, X, incX, &scal, &ssq); else if (N == 1) return(fabs(*X)); return(scal * sqrt(ssq));}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?