|
DataMuseum.dkPresents historical artifacts from the history of: Commodore CBM-900 |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about Commodore CBM-900 Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - download
Length: 799 (0x31f) Types: TextFile Notes: UNIX file Names: »rpow.c«
└─⟦f27320a65⟧ Bits:30001972 Commodore 900 hard disk image with partial source code └─⟦f4b8d8c84⟧ UNIX Filesystem └─⟦this⟧ »libmp/rpow.c«
#include "mprec.h" /* * Rpow sets the mint pointed to by "c" to the mint pointed to by "a" * raised to the mint pointed to by "b" power. If "b" is negative then * mperr is called with the appropriate error message. * Note that no assumption is made as to the distinctness of "a", "b" and * "c". */ void rpow(a, b, c) register mint *a, *b, *c; { mint al, bl; int rem; if (!ispos(b)) mperr("negative power"); /* make local copies of a and b */ minit(&al); mcopy(a, &al); minit(&bl); mcopy(b, &bl); /* form actual power */ sdiv(&bl, 2, &bl, &rem); if (rem != 0) mcopy(&al, c); else mcopy(mone, c); while (!zerop(&bl)) { mult(&al, &al, &al); sdiv(&bl, 2, &bl, &rem); if (rem != 0) mult(c, &al, c); } /* clean up garbage */ mpfree(al.val); mpfree(bl.val); }