bc: rename arithmetic calc functions to "z" functions, no code changes
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
c2d15dff42
commit
1aeacefbb3
177
miscutils/bc.c
177
miscutils/bc.c
@ -946,18 +946,17 @@ typedef void (*BcNumDigitOp)(size_t, size_t, bool) FAST_FUNC;
|
|||||||
|
|
||||||
typedef BcStatus (*BcNumBinaryOp)(BcNum *, BcNum *, BcNum *, size_t) FAST_FUNC;
|
typedef BcStatus (*BcNumBinaryOp)(BcNum *, BcNum *, BcNum *, size_t) FAST_FUNC;
|
||||||
|
|
||||||
static BcStatus bc_num_add(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
static BcStatus zbc_num_add(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
||||||
static BcStatus bc_num_sub(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
static BcStatus zbc_num_sub(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
||||||
static BcStatus bc_num_mul(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
static BcStatus zbc_num_mul(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
||||||
static BcStatus bc_num_div(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
static BcStatus zbc_num_div(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
||||||
static BcStatus bc_num_mod(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
static BcStatus zbc_num_mod(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
||||||
static BcStatus bc_num_pow(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
static BcStatus zbc_num_pow(BcNum *a, BcNum *b, BcNum *c, size_t scale) FAST_FUNC;
|
||||||
static BcStatus bc_num_sqrt(BcNum *a, BcNum *b, size_t scale);
|
static BcStatus zbc_num_divmod(BcNum *a, BcNum *b, BcNum *c, BcNum *d,
|
||||||
static BcStatus bc_num_divmod(BcNum *a, BcNum *b, BcNum *c, BcNum *d,
|
|
||||||
size_t scale);
|
size_t scale);
|
||||||
|
|
||||||
static const BcNumBinaryOp bc_program_ops[] = {
|
static const BcNumBinaryOp zbc_program_ops[] = {
|
||||||
bc_num_pow, bc_num_mul, bc_num_div, bc_num_mod, bc_num_add, bc_num_sub,
|
zbc_num_pow, zbc_num_mul, zbc_num_div, zbc_num_mod, zbc_num_add, zbc_num_sub,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void fflush_and_check(void)
|
static void fflush_and_check(void)
|
||||||
@ -1693,7 +1692,7 @@ static BC_STATUS zbc_num_shift(BcNum *n, size_t places)
|
|||||||
# define zbc_num_shift(...) (zbc_num_shift(__VA_ARGS__), BC_STATUS_SUCCESS)
|
# define zbc_num_shift(...) (zbc_num_shift(__VA_ARGS__), BC_STATUS_SUCCESS)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static BcStatus bc_num_inv(BcNum *a, BcNum *b, size_t scale)
|
static BcStatus zbc_num_inv(BcNum *a, BcNum *b, size_t scale)
|
||||||
{
|
{
|
||||||
BcNum one;
|
BcNum one;
|
||||||
BcDig num[2];
|
BcDig num[2];
|
||||||
@ -1702,10 +1701,10 @@ static BcStatus bc_num_inv(BcNum *a, BcNum *b, size_t scale)
|
|||||||
one.num = num;
|
one.num = num;
|
||||||
bc_num_one(&one);
|
bc_num_one(&one);
|
||||||
|
|
||||||
return bc_num_div(&one, a, b, scale);
|
return zbc_num_div(&one, a, b, scale);
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_a(BcNum *a, BcNum *b, BcNum *restrict c, size_t sub)
|
static FAST_FUNC BcStatus zbc_num_a(BcNum *a, BcNum *b, BcNum *restrict c, size_t sub)
|
||||||
{
|
{
|
||||||
BcDig *ptr, *ptr_a, *ptr_b, *ptr_c;
|
BcDig *ptr, *ptr_a, *ptr_b, *ptr_c;
|
||||||
size_t i, max, min_rdx, min_int, diff, a_int, b_int;
|
size_t i, max, min_rdx, min_int, diff, a_int, b_int;
|
||||||
@ -1773,10 +1772,10 @@ static FAST_FUNC BcStatus bc_num_a(BcNum *a, BcNum *b, BcNum *restrict c, size_t
|
|||||||
|
|
||||||
if (carry != 0) c->num[c->len++] = (BcDig) carry;
|
if (carry != 0) c->num[c->len++] = (BcDig) carry;
|
||||||
|
|
||||||
return BC_STATUS_SUCCESS; // can't make void, see bc_num_binary()
|
return BC_STATUS_SUCCESS; // can't make void, see zbc_num_binary()
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_s(BcNum *a, BcNum *b, BcNum *restrict c, size_t sub)
|
static FAST_FUNC BcStatus zbc_num_s(BcNum *a, BcNum *b, BcNum *restrict c, size_t sub)
|
||||||
{
|
{
|
||||||
ssize_t cmp;
|
ssize_t cmp;
|
||||||
BcNum *minuend, *subtrahend;
|
BcNum *minuend, *subtrahend;
|
||||||
@ -1835,10 +1834,10 @@ static FAST_FUNC BcStatus bc_num_s(BcNum *a, BcNum *b, BcNum *restrict c, size_t
|
|||||||
|
|
||||||
bc_num_clean(c);
|
bc_num_clean(c);
|
||||||
|
|
||||||
return BC_STATUS_SUCCESS; // can't make void, see bc_num_binary()
|
return BC_STATUS_SUCCESS; // can't make void, see zbc_num_binary()
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_k(BcNum *restrict a, BcNum *restrict b,
|
static FAST_FUNC BcStatus zbc_num_k(BcNum *restrict a, BcNum *restrict b,
|
||||||
BcNum *restrict c)
|
BcNum *restrict c)
|
||||||
{
|
{
|
||||||
BcStatus s;
|
BcStatus s;
|
||||||
@ -1905,30 +1904,30 @@ static FAST_FUNC BcStatus bc_num_k(BcNum *restrict a, BcNum *restrict b,
|
|||||||
bc_num_split(a, max2, &l1, &h1);
|
bc_num_split(a, max2, &l1, &h1);
|
||||||
bc_num_split(b, max2, &l2, &h2);
|
bc_num_split(b, max2, &l2, &h2);
|
||||||
|
|
||||||
s = bc_num_add(&h1, &l1, &m1, 0);
|
s = zbc_num_add(&h1, &l1, &m1, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_add(&h2, &l2, &m2, 0);
|
s = zbc_num_add(&h2, &l2, &m2, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
s = bc_num_k(&h1, &h2, &z0);
|
s = zbc_num_k(&h1, &h2, &z0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_k(&m1, &m2, &z1);
|
s = zbc_num_k(&m1, &m2, &z1);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_k(&l1, &l2, &z2);
|
s = zbc_num_k(&l1, &l2, &z2);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
s = bc_num_sub(&z1, &z0, &temp, 0);
|
s = zbc_num_sub(&z1, &z0, &temp, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_sub(&temp, &z2, &z1, 0);
|
s = zbc_num_sub(&temp, &z2, &z1, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
s = zbc_num_shift(&z0, max2 * 2);
|
s = zbc_num_shift(&z0, max2 * 2);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = zbc_num_shift(&z1, max2);
|
s = zbc_num_shift(&z1, max2);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_add(&z0, &z1, &temp, 0);
|
s = zbc_num_add(&z0, &z1, &temp, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_add(&temp, &z2, c, 0);
|
s = zbc_num_add(&temp, &z2, c, 0);
|
||||||
|
|
||||||
err:
|
err:
|
||||||
bc_num_free(&temp);
|
bc_num_free(&temp);
|
||||||
@ -1944,7 +1943,7 @@ err:
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_m(BcNum *a, BcNum *b, BcNum *restrict c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_m(BcNum *a, BcNum *b, BcNum *restrict c, size_t scale)
|
||||||
{
|
{
|
||||||
BcStatus s;
|
BcStatus s;
|
||||||
BcNum cpa, cpb;
|
BcNum cpa, cpb;
|
||||||
@ -1966,7 +1965,7 @@ static FAST_FUNC BcStatus bc_num_m(BcNum *a, BcNum *b, BcNum *restrict c, size_t
|
|||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = zbc_num_shift(&cpb, maxrdx);
|
s = zbc_num_shift(&cpb, maxrdx);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_k(&cpa, &cpb, c);
|
s = zbc_num_k(&cpa, &cpb, c);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
maxrdx += scale;
|
maxrdx += scale;
|
||||||
@ -1986,7 +1985,7 @@ err:
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_d(BcNum *a, BcNum *b, BcNum *restrict c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_d(BcNum *a, BcNum *b, BcNum *restrict c, size_t scale)
|
||||||
{
|
{
|
||||||
BcStatus s = BC_STATUS_SUCCESS;
|
BcStatus s = BC_STATUS_SUCCESS;
|
||||||
BcDig *n, *p, q;
|
BcDig *n, *p, q;
|
||||||
@ -2058,7 +2057,7 @@ static FAST_FUNC BcStatus bc_num_d(BcNum *a, BcNum *b, BcNum *restrict c, size_t
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_r(BcNum *a, BcNum *b, BcNum *restrict c,
|
static FAST_FUNC BcStatus zbc_num_r(BcNum *a, BcNum *b, BcNum *restrict c,
|
||||||
BcNum *restrict d, size_t scale, size_t ts)
|
BcNum *restrict d, size_t scale, size_t ts)
|
||||||
{
|
{
|
||||||
BcStatus s;
|
BcStatus s;
|
||||||
@ -2074,14 +2073,14 @@ static FAST_FUNC BcStatus bc_num_r(BcNum *a, BcNum *b, BcNum *restrict c,
|
|||||||
}
|
}
|
||||||
|
|
||||||
bc_num_init(&temp, d->cap);
|
bc_num_init(&temp, d->cap);
|
||||||
s = bc_num_d(a, b, c, scale);
|
s = zbc_num_d(a, b, c, scale);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
if (scale != 0) scale = ts;
|
if (scale != 0) scale = ts;
|
||||||
|
|
||||||
s = bc_num_m(c, b, &temp, scale);
|
s = zbc_num_m(c, b, &temp, scale);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_sub(a, &temp, d, scale);
|
s = zbc_num_sub(a, &temp, d, scale);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
if (ts > d->rdx && d->len) bc_num_extend(d, ts - d->rdx);
|
if (ts > d->rdx && d->len) bc_num_extend(d, ts - d->rdx);
|
||||||
@ -2095,20 +2094,20 @@ err:
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_rem(BcNum *a, BcNum *b, BcNum *restrict c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_rem(BcNum *a, BcNum *b, BcNum *restrict c, size_t scale)
|
||||||
{
|
{
|
||||||
BcStatus s;
|
BcStatus s;
|
||||||
BcNum c1;
|
BcNum c1;
|
||||||
size_t ts = BC_MAX(scale + b->rdx, a->rdx), len = BC_NUM_MREQ(a, b, ts);
|
size_t ts = BC_MAX(scale + b->rdx, a->rdx), len = BC_NUM_MREQ(a, b, ts);
|
||||||
|
|
||||||
bc_num_init(&c1, len);
|
bc_num_init(&c1, len);
|
||||||
s = bc_num_r(a, b, &c1, c, scale, ts);
|
s = zbc_num_r(a, b, &c1, c, scale, ts);
|
||||||
bc_num_free(&c1);
|
bc_num_free(&c1);
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_p(BcNum *a, BcNum *b, BcNum *restrict c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_p(BcNum *a, BcNum *b, BcNum *restrict c, size_t scale)
|
||||||
{
|
{
|
||||||
BcStatus s = BC_STATUS_SUCCESS;
|
BcStatus s = BC_STATUS_SUCCESS;
|
||||||
BcNum copy;
|
BcNum copy;
|
||||||
@ -2130,7 +2129,7 @@ static FAST_FUNC BcStatus bc_num_p(BcNum *a, BcNum *b, BcNum *restrict c, size_t
|
|||||||
if (!b->neg)
|
if (!b->neg)
|
||||||
bc_num_copy(c, a);
|
bc_num_copy(c, a);
|
||||||
else
|
else
|
||||||
s = bc_num_inv(a, c, scale);
|
s = zbc_num_inv(a, c, scale);
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2154,9 +2153,9 @@ static FAST_FUNC BcStatus bc_num_p(BcNum *a, BcNum *b, BcNum *restrict c, size_t
|
|||||||
|
|
||||||
for (powrdx = a->rdx; !(pow & 1); pow >>= 1) {
|
for (powrdx = a->rdx; !(pow & 1); pow >>= 1) {
|
||||||
powrdx <<= 1;
|
powrdx <<= 1;
|
||||||
s = bc_num_mul(©, ©, ©, powrdx);
|
s = zbc_num_mul(©, ©, ©, powrdx);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
// Not needed: bc_num_mul() has a check for ^C:
|
// Not needed: zbc_num_mul() has a check for ^C:
|
||||||
//if (G_interrupt) {
|
//if (G_interrupt) {
|
||||||
// s = BC_STATUS_FAILURE;
|
// s = BC_STATUS_FAILURE;
|
||||||
// goto err;
|
// goto err;
|
||||||
@ -2168,15 +2167,15 @@ static FAST_FUNC BcStatus bc_num_p(BcNum *a, BcNum *b, BcNum *restrict c, size_t
|
|||||||
for (resrdx = powrdx, pow >>= 1; pow != 0; pow >>= 1) {
|
for (resrdx = powrdx, pow >>= 1; pow != 0; pow >>= 1) {
|
||||||
|
|
||||||
powrdx <<= 1;
|
powrdx <<= 1;
|
||||||
s = bc_num_mul(©, ©, ©, powrdx);
|
s = zbc_num_mul(©, ©, ©, powrdx);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
if (pow & 1) {
|
if (pow & 1) {
|
||||||
resrdx += powrdx;
|
resrdx += powrdx;
|
||||||
s = bc_num_mul(c, ©, c, resrdx);
|
s = zbc_num_mul(c, ©, c, resrdx);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
}
|
}
|
||||||
// Not needed: bc_num_mul() has a check for ^C:
|
// Not needed: zbc_num_mul() has a check for ^C:
|
||||||
//if (G_interrupt) {
|
//if (G_interrupt) {
|
||||||
// s = BC_STATUS_FAILURE;
|
// s = BC_STATUS_FAILURE;
|
||||||
// goto err;
|
// goto err;
|
||||||
@ -2184,7 +2183,7 @@ static FAST_FUNC BcStatus bc_num_p(BcNum *a, BcNum *b, BcNum *restrict c, size_t
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (neg) {
|
if (neg) {
|
||||||
s = bc_num_inv(c, c, scale);
|
s = zbc_num_inv(c, c, scale);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2199,7 +2198,7 @@ err:
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static BcStatus bc_num_binary(BcNum *a, BcNum *b, BcNum *c, size_t scale,
|
static BcStatus zbc_num_binary(BcNum *a, BcNum *b, BcNum *c, size_t scale,
|
||||||
BcNumBinaryOp op, size_t req)
|
BcNumBinaryOp op, size_t req)
|
||||||
{
|
{
|
||||||
BcStatus s;
|
BcStatus s;
|
||||||
@ -2322,11 +2321,11 @@ static BC_STATUS zbc_num_printNum(BcNum *n, BcNum *base, size_t width, BcNumDigi
|
|||||||
bc_num_one(&frac_len);
|
bc_num_one(&frac_len);
|
||||||
|
|
||||||
bc_num_truncate(&intp, intp.rdx);
|
bc_num_truncate(&intp, intp.rdx);
|
||||||
s = bc_num_sub(n, &intp, &fracp, 0);
|
s = zbc_num_sub(n, &intp, &fracp, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
while (intp.len != 0) {
|
while (intp.len != 0) {
|
||||||
s = bc_num_divmod(&intp, base, &intp, &digit, 0);
|
s = zbc_num_divmod(&intp, base, &intp, &digit, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = zbc_num_ulong(&digit, &dig);
|
s = zbc_num_ulong(&digit, &dig);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
@ -2341,15 +2340,15 @@ static BC_STATUS zbc_num_printNum(BcNum *n, BcNum *base, size_t width, BcNumDigi
|
|||||||
if (!n->rdx) goto err;
|
if (!n->rdx) goto err;
|
||||||
|
|
||||||
for (radix = true; frac_len.len <= n->rdx; radix = false) {
|
for (radix = true; frac_len.len <= n->rdx; radix = false) {
|
||||||
s = bc_num_mul(&fracp, base, &fracp, n->rdx);
|
s = zbc_num_mul(&fracp, base, &fracp, n->rdx);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = zbc_num_ulong(&fracp, &dig);
|
s = zbc_num_ulong(&fracp, &dig);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
bc_num_ulong2num(&intp, dig);
|
bc_num_ulong2num(&intp, dig);
|
||||||
s = bc_num_sub(&fracp, &intp, &fracp, 0);
|
s = zbc_num_sub(&fracp, &intp, &fracp, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
print(dig, width, radix);
|
print(dig, width, radix);
|
||||||
s = bc_num_mul(&frac_len, base, &frac_len, 0);
|
s = zbc_num_mul(&frac_len, base, &frac_len, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2493,10 +2492,10 @@ static void bc_num_parseBase(BcNum *n, const char *val, BcNum *base)
|
|||||||
|
|
||||||
v = (unsigned long) (c <= '9' ? c - '0' : c - 'A' + 10);
|
v = (unsigned long) (c <= '9' ? c - '0' : c - 'A' + 10);
|
||||||
|
|
||||||
s = bc_num_mul(n, base, &mult, 0);
|
s = zbc_num_mul(n, base, &mult, 0);
|
||||||
if (s) goto int_err;
|
if (s) goto int_err;
|
||||||
bc_num_ulong2num(&temp, v);
|
bc_num_ulong2num(&temp, v);
|
||||||
s = bc_num_add(&mult, &temp, n, 0);
|
s = zbc_num_add(&mult, &temp, n, 0);
|
||||||
if (s) goto int_err;
|
if (s) goto int_err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2512,18 +2511,18 @@ static void bc_num_parseBase(BcNum *n, const char *val, BcNum *base)
|
|||||||
|
|
||||||
v = (unsigned long) (c <= '9' ? c - '0' : c - 'A' + 10);
|
v = (unsigned long) (c <= '9' ? c - '0' : c - 'A' + 10);
|
||||||
|
|
||||||
s = bc_num_mul(&result, base, &result, 0);
|
s = zbc_num_mul(&result, base, &result, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
bc_num_ulong2num(&temp, v);
|
bc_num_ulong2num(&temp, v);
|
||||||
s = bc_num_add(&result, &temp, &result, 0);
|
s = zbc_num_add(&result, &temp, &result, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_mul(&mult, base, &mult, 0);
|
s = zbc_num_mul(&mult, base, &mult, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
s = bc_num_div(&result, &mult, &result, digits);
|
s = zbc_num_div(&result, &mult, &result, digits);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_add(n, &result, n, digits);
|
s = zbc_num_add(n, &result, n, digits);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
if (n->len != 0) {
|
if (n->len != 0) {
|
||||||
@ -2584,44 +2583,44 @@ static BC_STATUS zbc_num_print(BcNum *n, bool newline)
|
|||||||
# define zbc_num_print(...) (zbc_num_print(__VA_ARGS__), BC_STATUS_SUCCESS)
|
# define zbc_num_print(...) (zbc_num_print(__VA_ARGS__), BC_STATUS_SUCCESS)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_add(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_add(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
||||||
{
|
{
|
||||||
BcNumBinaryOp op = (!a->neg == !b->neg) ? bc_num_a : bc_num_s;
|
BcNumBinaryOp op = (!a->neg == !b->neg) ? zbc_num_a : zbc_num_s;
|
||||||
(void) scale;
|
(void) scale;
|
||||||
return bc_num_binary(a, b, c, false, op, BC_NUM_AREQ(a, b));
|
return zbc_num_binary(a, b, c, false, op, BC_NUM_AREQ(a, b));
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_sub(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_sub(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
||||||
{
|
{
|
||||||
BcNumBinaryOp op = (!a->neg == !b->neg) ? bc_num_s : bc_num_a;
|
BcNumBinaryOp op = (!a->neg == !b->neg) ? zbc_num_s : zbc_num_a;
|
||||||
(void) scale;
|
(void) scale;
|
||||||
return bc_num_binary(a, b, c, true, op, BC_NUM_AREQ(a, b));
|
return zbc_num_binary(a, b, c, true, op, BC_NUM_AREQ(a, b));
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_mul(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_mul(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
||||||
{
|
{
|
||||||
size_t req = BC_NUM_MREQ(a, b, scale);
|
size_t req = BC_NUM_MREQ(a, b, scale);
|
||||||
return bc_num_binary(a, b, c, scale, bc_num_m, req);
|
return zbc_num_binary(a, b, c, scale, zbc_num_m, req);
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_div(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_div(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
||||||
{
|
{
|
||||||
size_t req = BC_NUM_MREQ(a, b, scale);
|
size_t req = BC_NUM_MREQ(a, b, scale);
|
||||||
return bc_num_binary(a, b, c, scale, bc_num_d, req);
|
return zbc_num_binary(a, b, c, scale, zbc_num_d, req);
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_mod(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_mod(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
||||||
{
|
{
|
||||||
size_t req = BC_NUM_MREQ(a, b, scale);
|
size_t req = BC_NUM_MREQ(a, b, scale);
|
||||||
return bc_num_binary(a, b, c, scale, bc_num_rem, req);
|
return zbc_num_binary(a, b, c, scale, zbc_num_rem, req);
|
||||||
}
|
}
|
||||||
|
|
||||||
static FAST_FUNC BcStatus bc_num_pow(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
static FAST_FUNC BcStatus zbc_num_pow(BcNum *a, BcNum *b, BcNum *c, size_t scale)
|
||||||
{
|
{
|
||||||
return bc_num_binary(a, b, c, scale, bc_num_p, a->len * b->len + 1);
|
return zbc_num_binary(a, b, c, scale, zbc_num_p, a->len * b->len + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static BcStatus bc_num_sqrt(BcNum *a, BcNum *restrict b, size_t scale)
|
static BcStatus zbc_num_sqrt(BcNum *a, BcNum *restrict b, size_t scale)
|
||||||
{
|
{
|
||||||
BcStatus s;
|
BcStatus s;
|
||||||
BcNum num1, num2, half, f, fprime, *x0, *x1, *temp;
|
BcNum num1, num2, half, f, fprime, *x0, *x1, *temp;
|
||||||
@ -2684,11 +2683,11 @@ static BcStatus bc_num_sqrt(BcNum *a, BcNum *restrict b, size_t scale)
|
|||||||
|
|
||||||
while (cmp != 0 || digs < len) {
|
while (cmp != 0 || digs < len) {
|
||||||
|
|
||||||
s = bc_num_div(a, x0, &f, resrdx);
|
s = zbc_num_div(a, x0, &f, resrdx);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_add(x0, &f, &fprime, resrdx);
|
s = zbc_num_add(x0, &f, &fprime, resrdx);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_mul(&fprime, &half, x1, resrdx);
|
s = zbc_num_mul(&fprime, &half, x1, resrdx);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
cmp = bc_num_cmp(x1, x0);
|
cmp = bc_num_cmp(x1, x0);
|
||||||
@ -2723,7 +2722,7 @@ err:
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
static BcStatus bc_num_divmod(BcNum *a, BcNum *b, BcNum *c, BcNum *d,
|
static BcStatus zbc_num_divmod(BcNum *a, BcNum *b, BcNum *c, BcNum *d,
|
||||||
size_t scale)
|
size_t scale)
|
||||||
{
|
{
|
||||||
BcStatus s;
|
BcStatus s;
|
||||||
@ -2742,7 +2741,7 @@ static BcStatus bc_num_divmod(BcNum *a, BcNum *b, BcNum *c, BcNum *d,
|
|||||||
bc_num_expand(c, len);
|
bc_num_expand(c, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
s = bc_num_r(ptr_a, b, c, d, scale, ts);
|
s = zbc_num_r(ptr_a, b, c, d, scale, ts);
|
||||||
|
|
||||||
if (init) bc_num_free(&num2);
|
if (init) bc_num_free(&num2);
|
||||||
|
|
||||||
@ -2750,7 +2749,7 @@ static BcStatus bc_num_divmod(BcNum *a, BcNum *b, BcNum *c, BcNum *d,
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if ENABLE_DC
|
#if ENABLE_DC
|
||||||
static BcStatus bc_num_modexp(BcNum *a, BcNum *b, BcNum *c, BcNum *restrict d)
|
static BcStatus zbc_num_modexp(BcNum *a, BcNum *b, BcNum *c, BcNum *restrict d)
|
||||||
{
|
{
|
||||||
BcStatus s;
|
BcStatus s;
|
||||||
BcNum base, exp, two, temp;
|
BcNum base, exp, two, temp;
|
||||||
@ -2772,25 +2771,25 @@ static BcStatus bc_num_modexp(BcNum *a, BcNum *b, BcNum *c, BcNum *restrict d)
|
|||||||
two.num[0] = 2;
|
two.num[0] = 2;
|
||||||
bc_num_one(d);
|
bc_num_one(d);
|
||||||
|
|
||||||
s = bc_num_rem(a, c, &base, 0);
|
s = zbc_num_rem(a, c, &base, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
bc_num_copy(&exp, b);
|
bc_num_copy(&exp, b);
|
||||||
|
|
||||||
while (exp.len != 0) {
|
while (exp.len != 0) {
|
||||||
|
|
||||||
s = bc_num_divmod(&exp, &two, &exp, &temp, 0);
|
s = zbc_num_divmod(&exp, &two, &exp, &temp, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
if (BC_NUM_ONE(&temp)) {
|
if (BC_NUM_ONE(&temp)) {
|
||||||
s = bc_num_mul(d, &base, &temp, 0);
|
s = zbc_num_mul(d, &base, &temp, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_rem(&temp, c, d, 0);
|
s = zbc_num_rem(&temp, c, d, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
s = bc_num_mul(&base, &base, &temp, 0);
|
s = zbc_num_mul(&base, &base, &temp, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
s = bc_num_rem(&temp, c, &base, 0);
|
s = zbc_num_rem(&temp, c, &base, 0);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -5631,7 +5630,7 @@ static BcStatus bc_program_op(char inst)
|
|||||||
if (s) return s;
|
if (s) return s;
|
||||||
bc_num_init_DEF_SIZE(&res.d.n);
|
bc_num_init_DEF_SIZE(&res.d.n);
|
||||||
|
|
||||||
s = bc_program_ops[inst - BC_INST_POWER](n1, n2, &res.d.n, G.prog.scale);
|
s = zbc_program_ops[inst - BC_INST_POWER](n1, n2, &res.d.n, G.prog.scale);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
bc_program_binOpRetire(&res);
|
bc_program_binOpRetire(&res);
|
||||||
|
|
||||||
@ -6064,7 +6063,7 @@ static BcStatus bc_program_assign(char inst)
|
|||||||
if (assign)
|
if (assign)
|
||||||
bc_num_copy(l, r);
|
bc_num_copy(l, r);
|
||||||
else
|
else
|
||||||
s = bc_program_ops[inst - BC_INST_ASSIGN_POWER](l, r, l, G.prog.scale);
|
s = zbc_program_ops[inst - BC_INST_ASSIGN_POWER](l, r, l, G.prog.scale);
|
||||||
|
|
||||||
if (s) return s;
|
if (s) return s;
|
||||||
#else
|
#else
|
||||||
@ -6392,7 +6391,7 @@ static BcStatus bc_program_builtin(char inst)
|
|||||||
|
|
||||||
bc_num_init_DEF_SIZE(&res.d.n);
|
bc_num_init_DEF_SIZE(&res.d.n);
|
||||||
|
|
||||||
if (inst == BC_INST_SQRT) s = bc_num_sqrt(num, &res.d.n, G.prog.scale);
|
if (inst == BC_INST_SQRT) s = zbc_num_sqrt(num, &res.d.n, G.prog.scale);
|
||||||
#if ENABLE_BC
|
#if ENABLE_BC
|
||||||
else if (len != 0 && opnd->t == BC_RESULT_ARRAY) {
|
else if (len != 0 && opnd->t == BC_RESULT_ARRAY) {
|
||||||
bc_num_ulong2num(&res.d.n, (unsigned long) ((BcVec *) num)->len);
|
bc_num_ulong2num(&res.d.n, (unsigned long) ((BcVec *) num)->len);
|
||||||
@ -6430,7 +6429,7 @@ static BcStatus bc_program_divmod(void)
|
|||||||
bc_num_init_DEF_SIZE(&res.d.n);
|
bc_num_init_DEF_SIZE(&res.d.n);
|
||||||
bc_num_init(&res2.d.n, n2->len);
|
bc_num_init(&res2.d.n, n2->len);
|
||||||
|
|
||||||
s = bc_num_divmod(n1, n2, &res2.d.n, &res.d.n, G.prog.scale);
|
s = zbc_num_divmod(n1, n2, &res2.d.n, &res.d.n, G.prog.scale);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
bc_program_binOpRetire(&res2);
|
bc_program_binOpRetire(&res2);
|
||||||
@ -6477,7 +6476,7 @@ static BcStatus bc_program_modexp(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
bc_num_init(&res.d.n, n3->len);
|
bc_num_init(&res.d.n, n3->len);
|
||||||
s = bc_num_modexp(n1, n2, n3, &res.d.n);
|
s = zbc_num_modexp(n1, n2, n3, &res.d.n);
|
||||||
if (s) goto err;
|
if (s) goto err;
|
||||||
|
|
||||||
bc_vec_pop(&G.prog.results);
|
bc_vec_pop(&G.prog.results);
|
||||||
@ -6525,7 +6524,7 @@ static BcStatus bc_program_asciify(void)
|
|||||||
bc_num_copy(&n, num);
|
bc_num_copy(&n, num);
|
||||||
bc_num_truncate(&n, n.rdx);
|
bc_num_truncate(&n, n.rdx);
|
||||||
|
|
||||||
s = bc_num_mod(&n, &G.prog.strmb, &n, 0);
|
s = zbc_num_mod(&n, &G.prog.strmb, &n, 0);
|
||||||
if (s) goto num_err;
|
if (s) goto num_err;
|
||||||
s = zbc_num_ulong(&n, &val);
|
s = zbc_num_ulong(&n, &val);
|
||||||
if (s) goto num_err;
|
if (s) goto num_err;
|
||||||
|
Loading…
Reference in New Issue
Block a user