File: pythag.c

package info (click to toggle)
insighttoolkit 3.6.0-3
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 94,956 kB
  • ctags: 74,981
  • sloc: cpp: 355,621; ansic: 195,070; fortran: 28,713; python: 3,802; tcl: 1,996; sh: 1,175; java: 583; makefile: 415; csh: 184; perl: 175
file content (76 lines) | stat: -rw-r--r-- 1,986 bytes parent folder | download | duplicates (15)
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
/* eispack/pythag.f -- translated by f2c (version 20050501).
   You must link the resulting object file with libf2c:
        on Microsoft Windows system, link with libf2c.lib;
        on Linux or Unix systems, link with .../path/to/libf2c.a -lm
        or, if you install libf2c.a in a standard place, with -lf2c -lm
        -- in that order, at the end of the command line, as in
                cc *.o -lf2c -lm
        Source for libf2c is in /netlib/f2c/libf2c.zip, e.g.,

                http://www.netlib.org/f2c/libf2c.zip
*/

#ifdef __cplusplus
extern "C" {
#endif
#include "v3p_netlib.h"

/*<       double precision function pythag(a,b) >*/
doublereal pythag_(doublereal *a, doublereal *b)
{
    /* System generated locals */
    doublereal ret_val, d__1, d__2, d__3;

    /* Local variables */
    doublereal p, r__, s, t, u;

/*<       double precision a,b >*/

/*     finds dsqrt(a**2+b**2) without overflow or destructive underflow */

/*<       double precision p,r,s,t,u >*/
/*<       p = dmax1(dabs(a),dabs(b)) >*/
/* Computing MAX */
    d__1 = abs(*a), d__2 = abs(*b);
    p = max(d__1,d__2);
/*<       if (p .eq. 0.0d0) go to 20 >*/
    if (p == 0.) {
        goto L20;
    }
/*<       r = (dmin1(dabs(a),dabs(b))/p)**2 >*/
/* Computing MIN */
    d__2 = abs(*a), d__3 = abs(*b);
/* Computing 2nd power */
    d__1 = min(d__2,d__3) / p;
    r__ = d__1 * d__1;
/*<    10 continue >*/
L10:
/*<          t = 4.0d0 + r >*/
    t = r__ + 4.;
/*<          if (t .eq. 4.0d0) go to 20 >*/
    if (t == 4.) {
        goto L20;
    }
/*<          s = r/t >*/
    s = r__ / t;
/*<          u = 1.0d0 + 2.0d0*s >*/
    u = s * 2. + 1.;
/*<          p = u*p >*/
    p = u * p;
/*<          r = (s/u)**2 * r >*/
/* Computing 2nd power */
    d__1 = s / u;
    r__ = d__1 * d__1 * r__;
/*<       go to 10 >*/
    goto L10;
/*<    20 pythag = p >*/
L20:
    ret_val = p;
/*<       return >*/
    return ret_val;
/*<       end >*/
} /* pythag_ */

#ifdef __cplusplus
        }
#endif