diff options
| author | L Jonas Olsson <ljo@FreeBSD.org> | 1994-10-26 18:17:41 +0000 |
|---|---|---|
| committer | L Jonas Olsson <ljo@FreeBSD.org> | 1994-10-26 18:17:41 +0000 |
| commit | 09c656ca68c8876f0dddec7eda2626d8dc897f2e (patch) | |
| tree | acab27bd987cb8ba603a6389fb43d9b4df06310b /lib/libF77/pow_ii.c | |
| parent | 876f9d834708020dda68772a4812b6143bbbc16e (diff) | |
Notes
Diffstat (limited to 'lib/libF77/pow_ii.c')
| -rw-r--r-- | lib/libF77/pow_ii.c | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/lib/libF77/pow_ii.c b/lib/libF77/pow_ii.c new file mode 100644 index 000000000000..e7948776e6c7 --- /dev/null +++ b/lib/libF77/pow_ii.c @@ -0,0 +1,31 @@ +#include "f2c.h" + +#ifdef KR_headers +integer pow_ii(ap, bp) integer *ap, *bp; +#else +integer pow_ii(integer *ap, integer *bp) +#endif +{ + integer pow, x, n; + + x = *ap; + n = *bp; + + if (n <= 0) { + if (n == 0 || x == 1) + return 1; + if (x != -1) + return x == 0 ? 1/x : 0; + n = -n; + } + for(pow = 1; ; ) + { + if(n & 01) + pow *= x; + if(n >>= 1) + x *= x; + else + break; + } + return(pow); + } |
