File: pow_zi.c

package info (click to toggle)
insighttoolkit 3.20.1%2Bgit20120521-3
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 80,652 kB
  • sloc: cpp: 458,133; ansic: 196,223; fortran: 28,000; python: 3,839; tcl: 1,811; sh: 1,184; java: 583; makefile: 430; csh: 220; perl: 193; xml: 20
file content (60 lines) | stat: -rw-r--r-- 1,407 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
#include "v3p_f2c.h"
#ifdef __cplusplus
extern "C" {
#endif

#ifdef KR_headers
VOID pow_zi(p, a, b)    /* p = a**b  */
 doublecomplex *p, *a; integer *b;
#else
extern void z_div(doublecomplex*, doublecomplex*, doublecomplex*);
void pow_zi(doublecomplex *p, doublecomplex *a, integer *b)     /* p = a**b  */
#endif
{
        integer n;
        unsigned long u;
        double t;
        doublecomplex q, x;
        static doublecomplex one = {1.0, 0.0}; /* constant */

        n = *b;
        q.r = 1;
        q.i = 0;

        if(n == 0)
                goto done;
        if(n < 0)
                {
                n = -n;
                z_div(&x, &one, a);
                }
        else
                {
                x.r = a->r;
                x.i = a->i;
                }

        for(u = n; ; )
                {
                if(u & 01)
                        {
                        t = q.r * x.r - q.i * x.i;
                        q.i = q.r * x.i + q.i * x.r;
                        q.r = t;
                        }
                if(u >>= 1)
                        {
                        t = x.r * x.r - x.i * x.i;
                        x.i = 2 * x.r * x.i;
                        x.r = t;
                        }
                else
                        break;
                }
 done:
        p->i = q.i;
        p->r = q.r;
        }
#ifdef __cplusplus
}
#endif