c90d7c800dbc5b8350f7888724fea9d9c81d2f3e
[profile/ivi/opencv.git] / 3rdparty / lapack / isamax.c
1 #include "clapack.h"
2
3 integer isamax_(integer *n, real *sx, integer *incx)
4 {
5     /* System generated locals */
6     integer ret_val, i__1;
7     real r__1;
8
9     /* Local variables */
10     integer i__, ix;
11     real smax;
12
13 /*     .. Scalar Arguments .. */
14 /*     .. */
15 /*     .. Array Arguments .. */
16 /*     .. */
17
18 /*  Purpose */
19 /*  ======= */
20
21 /*     finds the index of element having max. absolute value. */
22 /*     jack dongarra, linpack, 3/11/78. */
23 /*     modified 3/93 to return if incx .le. 0. */
24 /*     modified 12/3/93, array(1) declarations changed to array(*) */
25
26
27 /*     .. Local Scalars .. */
28 /*     .. */
29 /*     .. Intrinsic Functions .. */
30 /*     .. */
31     /* Parameter adjustments */
32     --sx;
33
34     /* Function Body */
35     ret_val = 0;
36     if (*n < 1 || *incx <= 0) {
37         return ret_val;
38     }
39     ret_val = 1;
40     if (*n == 1) {
41         return ret_val;
42     }
43     if (*incx == 1) {
44         goto L20;
45     }
46
47 /*        code for increment not equal to 1 */
48
49     ix = 1;
50     smax = dabs(sx[1]);
51     ix += *incx;
52     i__1 = *n;
53     for (i__ = 2; i__ <= i__1; ++i__) {
54         if ((r__1 = sx[ix], dabs(r__1)) <= smax) {
55             goto L5;
56         }
57         ret_val = i__;
58         smax = (r__1 = sx[ix], dabs(r__1));
59 L5:
60         ix += *incx;
61 /* L10: */
62     }
63     return ret_val;
64
65 /*        code for increment equal to 1 */
66
67 L20:
68     smax = dabs(sx[1]);
69     i__1 = *n;
70     for (i__ = 2; i__ <= i__1; ++i__) {
71         if ((r__1 = sx[i__], dabs(r__1)) <= smax) {
72             goto L30;
73         }
74         ret_val = i__;
75         smax = (r__1 = sx[i__], dabs(r__1));
76 L30:
77         ;
78     }
79     return ret_val;
80 } /* isamax_ */