Using mpq_t for aggregating currencies with wildly varying ranges

bodrato at mail.dm.unipi.it bodrato at mail.dm.unipi.it
Fri Apr 18 10:28:19 UTC 2014


Ciao,

May I throw in another idea?

Since you know in advance that den is in the form $2^m 5^n$,
once you have obtained $m$ using mpz_scan1, you can compute $n$ just
looking at the bit size of the part $5^n$.

Il Mer, 16 Aprile 2014 9:26 pm, Donovan Hide ha scritto:
> void format_rational(mpq_t r,char *result,unsigned long *length){
[...]
> mp_bitcnt_t m = mpz_scan1(den,0);
> mp_bitcnt_t n = mpz_remove(den,den,five);

try instead
n = mpz_sizeinbase (den, 2) - m;
n = ((n + 1) * 3 + n / 68) / 7;

Or simply (n+1)*3/7, valid in a smaller range, or some more clever
division-free formula like the DIGITS_IN_BASEGT2_FROM_BITS macro in the
sources of GMP (in gmp-impl.h).

It will for sure be faster than mpz_remove.

Best regards,
m

-- 
http://bodrato.it/



More information about the gmp-discuss mailing list