Annotation of 42BSD/usr.lib/libF77/pow_zi.c, revision 1.1

1.1     ! root        1: /*
        !             2:  *     "@(#)pow_zi.c   1.1"
        !             3:  */
        !             4: 
        !             5: #include "complex"
        !             6: 
        !             7: pow_zi(p, a, b)        /* p = a**b  */
        !             8: dcomplex *p, *a;
        !             9: long int *b;
        !            10: {
        !            11: long int n;
        !            12: double t;
        !            13: dcomplex x;
        !            14: 
        !            15: n = *b;
        !            16: p->dreal = 1;
        !            17: p->dimag = 0;
        !            18: 
        !            19: if(n == 0)
        !            20:        return;
        !            21: if(n < 0)
        !            22:        {
        !            23:        n = -n;
        !            24:        z_div(&x, p, a);
        !            25:        }
        !            26: else
        !            27:        {
        !            28:        x.dreal = a->dreal;
        !            29:        x.dimag = a->dimag;
        !            30:        }
        !            31: 
        !            32: for( ; ; )
        !            33:        {
        !            34:        if(n & 01)
        !            35:                {
        !            36:                t = p->dreal * x.dreal - p->dimag * x.dimag;
        !            37:                p->dimag = p->dreal * x.dimag + p->dimag * x.dreal;
        !            38:                p->dreal = t;
        !            39:                }
        !            40:        if(n >>= 1)
        !            41:                {
        !            42:                t = x.dreal * x.dreal - x.dimag * x.dimag;
        !            43:                x.dimag = 2 * x.dreal * x.dimag;
        !            44:                x.dreal = t;
        !            45:                }
        !            46:        else
        !            47:                break;
        !            48:        }
        !            49: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.