Codebase list libf2c2 / c9e37887-a36e-4428-ab31-967b3d1ea548/main pow_di.c
c9e37887-a36e-4428-ab31-967b3d1ea548/main

Tree @c9e37887-a36e-4428-ab31-967b3d1ea548/main (Download .tar.gz)

pow_di.c @c9e37887-a36e-4428-ab31-967b3d1ea548/mainraw · history · blame

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

#ifdef KR_headers
double pow_di(ap, bp) doublereal *ap; integer *bp;
#else
double pow_di(doublereal *ap, integer *bp)
#endif
{
double pow, x;
integer n;
unsigned long u;

pow = 1;
x = *ap;
n = *bp;

if(n != 0)
	{
	if(n < 0)
		{
		n = -n;
		x = 1/x;
		}
	for(u = n; ; )
		{
		if(u & 01)
			pow *= x;
		if(u >>= 1)
			x *= x;
		else
			break;
		}
	}
return(pow);
}
#ifdef __cplusplus
}
#endif