-
Notifications
You must be signed in to change notification settings - Fork 3
/
snrm2.c
112 lines (84 loc) · 3.14 KB
/
snrm2.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*******************************************************************************
License:
This software was developed at the National Institute of Standards and
Technology (NIST) by employees of the Federal Government in the course
of their official duties. Pursuant to title 17 Section 105 of the
United States Code, this software is not subject to copyright protection
and is in the public domain. NIST assumes no responsibility whatsoever for
its use by other parties, and makes no guarantees, expressed or implied,
about its quality, reliability, or any other characteristic.
Disclaimer:
This software was developed to promote biometric standards and biometric
technology testing for the Federal Government in accordance with the USA
PATRIOT Act and the Enhanced Border Security and Visa Entry Reform Act.
Specific hardware and software products identified in this software were used
in order to perform the software development. In no case does such
identification imply recommendation or endorsement by the National Institute
of Standards and Technology, nor does it imply that the products and equipment
identified are necessarily the best available for the purpose.
*******************************************************************************/
/*
* ======================================================================
* NIST Guide to Available Math Software.
* Source for module SNRM2.C from package CBLAS.
* Retrieved from NETLIB on Tue Mar 14 10:54:20 2000.
* ======================================================================
*/
/* -- translated by f2c (version 19940927).
You must link the resulting object file with the libraries:
-lf2c -lm (in that order)
*/
#include "f2c.h"
doublereal snrm2_(integer *n, real *x, integer *incx)
{
/* System generated locals */
integer i__1, i__2;
real ret_val, r__1;
double sqrt(doublereal);
/* Local variables */
static real norm, scale, absxi;
static integer ix;
static real ssq;
/* SNRM2 returns the euclidean norm of a vector via the function
name, so that
SNRM2 := sqrt( x'*x )
-- This version written on 25-October-1982.
Modified on 14-October-1993 to inline the call to SLASSQ.
Sven Hammarling, Nag Ltd.
Parameter adjustments
Function Body */
#define X(I) x[(I)-1]
if (*n < 1 || *incx < 1) {
norm = 0.f;
} else if (*n == 1) {
norm = dabs(X(1));
} else {
scale = 0.f;
ssq = 1.f;
/* The following loop is equivalent to this call to the LAPACK
auxiliary routine:
CALL SLASSQ( N, X, INCX, SCALE, SSQ ) */
i__1 = (*n - 1) * *incx + 1;
i__2 = *incx;
for (ix = 1; *incx < 0 ? ix >= (*n-1)**incx+1 : ix <= (*n-1)**incx+1; ix += *incx) {
if (X(ix) != 0.f) {
absxi = (r__1 = X(ix), dabs(r__1));
if (scale < absxi) {
/* Computing 2nd power */
r__1 = scale / absxi;
ssq = ssq * (r__1 * r__1) + 1.f;
scale = absxi;
} else {
/* Computing 2nd power */
r__1 = absxi / scale;
ssq += r__1 * r__1;
}
}
/* L10: */
}
norm = scale * sqrt(ssq);
}
ret_val = norm;
return ret_val;
/* End of SNRM2. */
} /* snrm2_ */