1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-05-11 08:10:21 +02:00

* numbers.h. numbers.c (scm_make_ratio): Renamed to

scm_i_make_ratio and made static, replaced uses with scm_divide.
This commit is contained in:
Marius Vollmer 2004-08-03 15:55:42 +00:00
parent 759aa8f9e0
commit cba42c9344
3 changed files with 37 additions and 38 deletions

View file

@ -343,8 +343,8 @@ scm_i_mpz2num (mpz_t b)
/* this is needed when we want scm_divide to make a float, not a ratio, even if passed two ints */ /* this is needed when we want scm_divide to make a float, not a ratio, even if passed two ints */
static SCM scm_divide2real (SCM x, SCM y); static SCM scm_divide2real (SCM x, SCM y);
SCM static SCM
scm_make_ratio (SCM numerator, SCM denominator) scm_i_make_ratio (SCM numerator, SCM denominator)
#define FUNC_NAME "make-ratio" #define FUNC_NAME "make-ratio"
{ {
/* First make sure the arguments are proper. /* First make sure the arguments are proper.
@ -692,7 +692,7 @@ SCM_PRIMITIVE_GENERIC (scm_abs, "abs", 1, 0, 0,
{ {
if (scm_is_false (scm_negative_p (SCM_FRACTION_NUMERATOR (x)))) if (scm_is_false (scm_negative_p (SCM_FRACTION_NUMERATOR (x))))
return x; return x;
return scm_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (x), SCM_UNDEFINED), return scm_i_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (x), SCM_UNDEFINED),
SCM_FRACTION_DENOMINATOR (x)); SCM_FRACTION_DENOMINATOR (x));
} }
else else
@ -2684,7 +2684,7 @@ mem2ureal (const char* mem, size_t len, unsigned int *p_idx,
return SCM_BOOL_F; return SCM_BOOL_F;
/* both are int/big here, I assume */ /* both are int/big here, I assume */
result = scm_make_ratio (uinteger, divisor); result = scm_i_make_ratio (uinteger, divisor);
} }
else if (radix == 10) else if (radix == 10)
{ {
@ -3868,7 +3868,7 @@ scm_sum (SCM x, SCM y)
SCM_COMPLEX_IMAG (y)); SCM_COMPLEX_IMAG (y));
} }
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
return scm_make_ratio (scm_sum (SCM_FRACTION_NUMERATOR (y), return scm_i_make_ratio (scm_sum (SCM_FRACTION_NUMERATOR (y),
scm_product (x, SCM_FRACTION_DENOMINATOR (y))), scm_product (x, SCM_FRACTION_DENOMINATOR (y))),
SCM_FRACTION_DENOMINATOR (y)); SCM_FRACTION_DENOMINATOR (y));
else else
@ -3933,7 +3933,7 @@ scm_sum (SCM x, SCM y)
return scm_make_complex (real_part, SCM_COMPLEX_IMAG (y)); return scm_make_complex (real_part, SCM_COMPLEX_IMAG (y));
} }
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
return scm_make_ratio (scm_sum (SCM_FRACTION_NUMERATOR (y), return scm_i_make_ratio (scm_sum (SCM_FRACTION_NUMERATOR (y),
scm_product (x, SCM_FRACTION_DENOMINATOR (y))), scm_product (x, SCM_FRACTION_DENOMINATOR (y))),
SCM_FRACTION_DENOMINATOR (y)); SCM_FRACTION_DENOMINATOR (y));
else else
@ -3986,11 +3986,11 @@ scm_sum (SCM x, SCM y)
else if (SCM_FRACTIONP (x)) else if (SCM_FRACTIONP (x))
{ {
if (SCM_I_INUMP (y)) if (SCM_I_INUMP (y))
return scm_make_ratio (scm_sum (SCM_FRACTION_NUMERATOR (x), return scm_i_make_ratio (scm_sum (SCM_FRACTION_NUMERATOR (x),
scm_product (y, SCM_FRACTION_DENOMINATOR (x))), scm_product (y, SCM_FRACTION_DENOMINATOR (x))),
SCM_FRACTION_DENOMINATOR (x)); SCM_FRACTION_DENOMINATOR (x));
else if (SCM_BIGP (y)) else if (SCM_BIGP (y))
return scm_make_ratio (scm_sum (SCM_FRACTION_NUMERATOR (x), return scm_i_make_ratio (scm_sum (SCM_FRACTION_NUMERATOR (x),
scm_product (y, SCM_FRACTION_DENOMINATOR (x))), scm_product (y, SCM_FRACTION_DENOMINATOR (x))),
SCM_FRACTION_DENOMINATOR (x)); SCM_FRACTION_DENOMINATOR (x));
else if (SCM_REALP (y)) else if (SCM_REALP (y))
@ -4000,7 +4000,7 @@ scm_sum (SCM x, SCM y)
SCM_COMPLEX_IMAG (y)); SCM_COMPLEX_IMAG (y));
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
/* a/b + c/d = (ad + bc) / bd */ /* a/b + c/d = (ad + bc) / bd */
return scm_make_ratio (scm_sum (scm_product (SCM_FRACTION_NUMERATOR (x), SCM_FRACTION_DENOMINATOR (y)), return scm_i_make_ratio (scm_sum (scm_product (SCM_FRACTION_NUMERATOR (x), SCM_FRACTION_DENOMINATOR (y)),
scm_product (SCM_FRACTION_NUMERATOR (y), SCM_FRACTION_DENOMINATOR (x))), scm_product (SCM_FRACTION_NUMERATOR (y), SCM_FRACTION_DENOMINATOR (x))),
scm_product (SCM_FRACTION_DENOMINATOR (x), SCM_FRACTION_DENOMINATOR (y))); scm_product (SCM_FRACTION_DENOMINATOR (x), SCM_FRACTION_DENOMINATOR (y)));
else else
@ -4041,7 +4041,7 @@ scm_difference (SCM x, SCM y)
return scm_make_complex (-SCM_COMPLEX_REAL (x), return scm_make_complex (-SCM_COMPLEX_REAL (x),
-SCM_COMPLEX_IMAG (x)); -SCM_COMPLEX_IMAG (x));
else if (SCM_FRACTIONP (x)) else if (SCM_FRACTIONP (x))
return scm_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (x), SCM_UNDEFINED), return scm_i_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (x), SCM_UNDEFINED),
SCM_FRACTION_DENOMINATOR (x)); SCM_FRACTION_DENOMINATOR (x));
else else
SCM_WTA_DISPATCH_1 (g_difference, x, SCM_ARG1, s_difference); SCM_WTA_DISPATCH_1 (g_difference, x, SCM_ARG1, s_difference);
@ -4101,7 +4101,7 @@ scm_difference (SCM x, SCM y)
} }
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
/* a - b/c = (ac - b) / c */ /* a - b/c = (ac - b) / c */
return scm_make_ratio (scm_difference (scm_product (x, SCM_FRACTION_DENOMINATOR (y)), return scm_i_make_ratio (scm_difference (scm_product (x, SCM_FRACTION_DENOMINATOR (y)),
SCM_FRACTION_NUMERATOR (y)), SCM_FRACTION_NUMERATOR (y)),
SCM_FRACTION_DENOMINATOR (y)); SCM_FRACTION_DENOMINATOR (y));
else else
@ -4166,7 +4166,7 @@ scm_difference (SCM x, SCM y)
return scm_make_complex (real_part, - SCM_COMPLEX_IMAG (y)); return scm_make_complex (real_part, - SCM_COMPLEX_IMAG (y));
} }
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
return scm_make_ratio (scm_difference (scm_product (x, SCM_FRACTION_DENOMINATOR (y)), return scm_i_make_ratio (scm_difference (scm_product (x, SCM_FRACTION_DENOMINATOR (y)),
SCM_FRACTION_NUMERATOR (y)), SCM_FRACTION_NUMERATOR (y)),
SCM_FRACTION_DENOMINATOR (y)); SCM_FRACTION_DENOMINATOR (y));
else SCM_WTA_DISPATCH_2 (g_difference, x, y, SCM_ARGn, s_difference); else SCM_WTA_DISPATCH_2 (g_difference, x, y, SCM_ARGn, s_difference);
@ -4219,11 +4219,11 @@ scm_difference (SCM x, SCM y)
{ {
if (SCM_I_INUMP (y)) if (SCM_I_INUMP (y))
/* a/b - c = (a - cb) / b */ /* a/b - c = (a - cb) / b */
return scm_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (x), return scm_i_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (x),
scm_product(y, SCM_FRACTION_DENOMINATOR (x))), scm_product(y, SCM_FRACTION_DENOMINATOR (x))),
SCM_FRACTION_DENOMINATOR (x)); SCM_FRACTION_DENOMINATOR (x));
else if (SCM_BIGP (y)) else if (SCM_BIGP (y))
return scm_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (x), return scm_i_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (x),
scm_product(y, SCM_FRACTION_DENOMINATOR (x))), scm_product(y, SCM_FRACTION_DENOMINATOR (x))),
SCM_FRACTION_DENOMINATOR (x)); SCM_FRACTION_DENOMINATOR (x));
else if (SCM_REALP (y)) else if (SCM_REALP (y))
@ -4233,7 +4233,7 @@ scm_difference (SCM x, SCM y)
-SCM_COMPLEX_IMAG (y)); -SCM_COMPLEX_IMAG (y));
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
/* a/b - c/d = (ad - bc) / bd */ /* a/b - c/d = (ad - bc) / bd */
return scm_make_ratio (scm_difference (scm_product (SCM_FRACTION_NUMERATOR (x), SCM_FRACTION_DENOMINATOR (y)), return scm_i_make_ratio (scm_difference (scm_product (SCM_FRACTION_NUMERATOR (x), SCM_FRACTION_DENOMINATOR (y)),
scm_product (SCM_FRACTION_NUMERATOR (y), SCM_FRACTION_DENOMINATOR (x))), scm_product (SCM_FRACTION_NUMERATOR (y), SCM_FRACTION_DENOMINATOR (x))),
scm_product (SCM_FRACTION_DENOMINATOR (x), SCM_FRACTION_DENOMINATOR (y))); scm_product (SCM_FRACTION_DENOMINATOR (x), SCM_FRACTION_DENOMINATOR (y)));
else else
@ -4302,7 +4302,7 @@ scm_product (SCM x, SCM y)
return scm_make_complex (xx * SCM_COMPLEX_REAL (y), return scm_make_complex (xx * SCM_COMPLEX_REAL (y),
xx * SCM_COMPLEX_IMAG (y)); xx * SCM_COMPLEX_IMAG (y));
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
return scm_make_ratio (scm_product (x, SCM_FRACTION_NUMERATOR (y)), return scm_i_make_ratio (scm_product (x, SCM_FRACTION_NUMERATOR (y)),
SCM_FRACTION_DENOMINATOR (y)); SCM_FRACTION_DENOMINATOR (y));
else else
SCM_WTA_DISPATCH_2 (g_product, x, y, SCM_ARGn, s_product); SCM_WTA_DISPATCH_2 (g_product, x, y, SCM_ARGn, s_product);
@ -4337,7 +4337,7 @@ scm_product (SCM x, SCM y)
z * SCM_COMPLEX_IMAG (y)); z * SCM_COMPLEX_IMAG (y));
} }
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
return scm_make_ratio (scm_product (x, SCM_FRACTION_NUMERATOR (y)), return scm_i_make_ratio (scm_product (x, SCM_FRACTION_NUMERATOR (y)),
SCM_FRACTION_DENOMINATOR (y)); SCM_FRACTION_DENOMINATOR (y));
else else
SCM_WTA_DISPATCH_2 (g_product, x, y, SCM_ARGn, s_product); SCM_WTA_DISPATCH_2 (g_product, x, y, SCM_ARGn, s_product);
@ -4396,10 +4396,10 @@ scm_product (SCM x, SCM y)
else if (SCM_FRACTIONP (x)) else if (SCM_FRACTIONP (x))
{ {
if (SCM_I_INUMP (y)) if (SCM_I_INUMP (y))
return scm_make_ratio (scm_product (y, SCM_FRACTION_NUMERATOR (x)), return scm_i_make_ratio (scm_product (y, SCM_FRACTION_NUMERATOR (x)),
SCM_FRACTION_DENOMINATOR (x)); SCM_FRACTION_DENOMINATOR (x));
else if (SCM_BIGP (y)) else if (SCM_BIGP (y))
return scm_make_ratio (scm_product (y, SCM_FRACTION_NUMERATOR (x)), return scm_i_make_ratio (scm_product (y, SCM_FRACTION_NUMERATOR (x)),
SCM_FRACTION_DENOMINATOR (x)); SCM_FRACTION_DENOMINATOR (x));
else if (SCM_REALP (y)) else if (SCM_REALP (y))
return scm_from_double (scm_i_fraction2double (x) * SCM_REAL_VALUE (y)); return scm_from_double (scm_i_fraction2double (x) * SCM_REAL_VALUE (y));
@ -4411,7 +4411,7 @@ scm_product (SCM x, SCM y)
} }
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
/* a/b * c/d = ac / bd */ /* a/b * c/d = ac / bd */
return scm_make_ratio (scm_product (SCM_FRACTION_NUMERATOR (x), return scm_i_make_ratio (scm_product (SCM_FRACTION_NUMERATOR (x),
SCM_FRACTION_NUMERATOR (y)), SCM_FRACTION_NUMERATOR (y)),
scm_product (SCM_FRACTION_DENOMINATOR (x), scm_product (SCM_FRACTION_DENOMINATOR (x),
SCM_FRACTION_DENOMINATOR (y))); SCM_FRACTION_DENOMINATOR (y)));
@ -4482,14 +4482,14 @@ scm_i_divide (SCM x, SCM y, int inexact)
{ {
if (inexact) if (inexact)
return scm_from_double (1.0 / (double) xx); return scm_from_double (1.0 / (double) xx);
else return scm_make_ratio (SCM_I_MAKINUM(1), x); else return scm_i_make_ratio (SCM_I_MAKINUM(1), x);
} }
} }
else if (SCM_BIGP (x)) else if (SCM_BIGP (x))
{ {
if (inexact) if (inexact)
return scm_from_double (1.0 / scm_i_big2dbl (x)); return scm_from_double (1.0 / scm_i_big2dbl (x));
else return scm_make_ratio (SCM_I_MAKINUM(1), x); else return scm_i_make_ratio (SCM_I_MAKINUM(1), x);
} }
else if (SCM_REALP (x)) else if (SCM_REALP (x))
{ {
@ -4519,7 +4519,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
} }
} }
else if (SCM_FRACTIONP (x)) else if (SCM_FRACTIONP (x))
return scm_make_ratio (SCM_FRACTION_DENOMINATOR (x), return scm_i_make_ratio (SCM_FRACTION_DENOMINATOR (x),
SCM_FRACTION_NUMERATOR (x)); SCM_FRACTION_NUMERATOR (x));
else else
SCM_WTA_DISPATCH_1 (g_divide, x, SCM_ARG1, s_divide); SCM_WTA_DISPATCH_1 (g_divide, x, SCM_ARG1, s_divide);
@ -4543,7 +4543,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
{ {
if (inexact) if (inexact)
return scm_from_double ((double) xx / (double) yy); return scm_from_double ((double) xx / (double) yy);
else return scm_make_ratio (x, y); else return scm_i_make_ratio (x, y);
} }
else else
{ {
@ -4558,7 +4558,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
{ {
if (inexact) if (inexact)
return scm_from_double ((double) xx / scm_i_big2dbl (y)); return scm_from_double ((double) xx / scm_i_big2dbl (y));
else return scm_make_ratio (x, y); else return scm_i_make_ratio (x, y);
} }
else if (SCM_REALP (y)) else if (SCM_REALP (y))
{ {
@ -4593,7 +4593,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
} }
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
/* a / b/c = ac / b */ /* a / b/c = ac / b */
return scm_make_ratio (scm_product (x, SCM_FRACTION_DENOMINATOR (y)), return scm_i_make_ratio (scm_product (x, SCM_FRACTION_DENOMINATOR (y)),
SCM_FRACTION_NUMERATOR (y)); SCM_FRACTION_NUMERATOR (y));
else else
SCM_WTA_DISPATCH_2 (g_divide, x, y, SCM_ARGn, s_divide); SCM_WTA_DISPATCH_2 (g_divide, x, y, SCM_ARGn, s_divide);
@ -4641,7 +4641,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
{ {
if (inexact) if (inexact)
return scm_from_double (scm_i_big2dbl (x) / (double) yy); return scm_from_double (scm_i_big2dbl (x) / (double) yy);
else return scm_make_ratio (x, y); else return scm_i_make_ratio (x, y);
} }
} }
} }
@ -4681,7 +4681,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
scm_remember_upto_here_2 (x, y); scm_remember_upto_here_2 (x, y);
return scm_from_double (dbx / dby); return scm_from_double (dbx / dby);
} }
else return scm_make_ratio (x, y); else return scm_i_make_ratio (x, y);
} }
} }
} }
@ -4701,7 +4701,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
goto complex_div; goto complex_div;
} }
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
return scm_make_ratio (scm_product (x, SCM_FRACTION_DENOMINATOR (y)), return scm_i_make_ratio (scm_product (x, SCM_FRACTION_DENOMINATOR (y)),
SCM_FRACTION_NUMERATOR (y)); SCM_FRACTION_NUMERATOR (y));
else else
SCM_WTA_DISPATCH_2 (g_divide, x, y, SCM_ARGn, s_divide); SCM_WTA_DISPATCH_2 (g_divide, x, y, SCM_ARGn, s_divide);
@ -4813,12 +4813,12 @@ scm_i_divide (SCM x, SCM y, int inexact)
scm_num_overflow (s_divide); scm_num_overflow (s_divide);
else else
#endif #endif
return scm_make_ratio (SCM_FRACTION_NUMERATOR (x), return scm_i_make_ratio (SCM_FRACTION_NUMERATOR (x),
scm_product (SCM_FRACTION_DENOMINATOR (x), y)); scm_product (SCM_FRACTION_DENOMINATOR (x), y));
} }
else if (SCM_BIGP (y)) else if (SCM_BIGP (y))
{ {
return scm_make_ratio (SCM_FRACTION_NUMERATOR (x), return scm_i_make_ratio (SCM_FRACTION_NUMERATOR (x),
scm_product (SCM_FRACTION_DENOMINATOR (x), y)); scm_product (SCM_FRACTION_DENOMINATOR (x), y));
} }
else if (SCM_REALP (y)) else if (SCM_REALP (y))
@ -4837,7 +4837,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
goto complex_div; goto complex_div;
} }
else if (SCM_FRACTIONP (y)) else if (SCM_FRACTIONP (y))
return scm_make_ratio (scm_product (SCM_FRACTION_NUMERATOR (x), SCM_FRACTION_DENOMINATOR (y)), return scm_i_make_ratio (scm_product (SCM_FRACTION_NUMERATOR (x), SCM_FRACTION_DENOMINATOR (y)),
scm_product (SCM_FRACTION_NUMERATOR (y), SCM_FRACTION_DENOMINATOR (x))); scm_product (SCM_FRACTION_NUMERATOR (y), SCM_FRACTION_DENOMINATOR (x)));
else else
SCM_WTA_DISPATCH_2 (g_divide, x, y, SCM_ARGn, s_divide); SCM_WTA_DISPATCH_2 (g_divide, x, y, SCM_ARGn, s_divide);
@ -5324,7 +5324,7 @@ scm_magnitude (SCM z)
{ {
if (scm_is_false (scm_negative_p (SCM_FRACTION_NUMERATOR (z)))) if (scm_is_false (scm_negative_p (SCM_FRACTION_NUMERATOR (z))))
return z; return z;
return scm_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (z), SCM_UNDEFINED), return scm_i_make_ratio (scm_difference (SCM_FRACTION_NUMERATOR (z), SCM_UNDEFINED),
SCM_FRACTION_DENOMINATOR (z)); SCM_FRACTION_DENOMINATOR (z));
} }
else else
@ -5417,10 +5417,10 @@ SCM_DEFINE (scm_inexact_to_exact, "inexact->exact", 1, 0, 0,
mpq_init (frac); mpq_init (frac);
mpq_set_d (frac, SCM_REAL_VALUE (z)); mpq_set_d (frac, SCM_REAL_VALUE (z));
q = scm_make_ratio (scm_i_mpz2num (mpq_numref (frac)), q = scm_i_make_ratio (scm_i_mpz2num (mpq_numref (frac)),
scm_i_mpz2num (mpq_denref (frac))); scm_i_mpz2num (mpq_denref (frac)));
/* When scm_make_ratio throws, we leak the memory allocated /* When scm_i_make_ratio throws, we leak the memory allocated
for frac... for frac...
*/ */
mpq_clear (frac); mpq_clear (frac);

View file

@ -267,7 +267,6 @@ SCM_API SCM scm_i_long2big (long n);
SCM_API SCM scm_i_ulong2big (unsigned long n); SCM_API SCM scm_i_ulong2big (unsigned long n);
/* ratio functions */ /* ratio functions */
SCM_API SCM scm_make_ratio (SCM num, SCM den);
SCM_API SCM scm_rationalize (SCM x, SCM err); SCM_API SCM scm_rationalize (SCM x, SCM err);
SCM_API SCM scm_numerator (SCM z); SCM_API SCM scm_numerator (SCM z);
SCM_API SCM scm_denominator (SCM z); SCM_API SCM scm_denominator (SCM z);

View file

@ -2599,8 +2599,8 @@ scm_init_unif ()
scm_set_smob_free (scm_tc16_array, array_free); scm_set_smob_free (scm_tc16_array, array_free);
scm_set_smob_print (scm_tc16_array, scm_raprin1); scm_set_smob_print (scm_tc16_array, scm_raprin1);
scm_set_smob_equalp (scm_tc16_array, scm_array_equal_p); scm_set_smob_equalp (scm_tc16_array, scm_array_equal_p);
exactly_one_third = scm_permanent_object (scm_make_ratio (scm_from_int (1), exactly_one_third = scm_permanent_object (scm_divide (scm_from_int (1),
scm_from_int (3))); scm_from_int (3)));
scm_add_feature ("array"); scm_add_feature ("array");
#include "libguile/unif.x" #include "libguile/unif.x"
} }