ack/lang/fortran/lib/libF77/pow_ri.c
1991-10-07 16:59:33 +00:00

37 lines
319 B
C

#include "f2c.h"
double pow_ri(ap, bp)
real *ap;
integer *bp;
{
double pow, x;
integer n;
pow = 1;
x = *ap;
n = *bp;
if(n != 0)
{
if(n < 0)
{
if(x == 0)
{
return(pow);
}
n = -n;
x = 1/x;
}
for( ; ; )
{
if(n & 01)
pow *= x;
if(n >>= 1)
x *= x;
else
break;
}
}
return(pow);
}