1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-05-07 18:30:25 +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 */
static SCM scm_divide2real (SCM x, SCM y);
SCM
scm_make_ratio (SCM numerator, SCM denominator)
static SCM
scm_i_make_ratio (SCM numerator, SCM denominator)
#define FUNC_NAME "make-ratio"
{
/* 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))))
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));
}
else
@ -2684,7 +2684,7 @@ mem2ureal (const char* mem, size_t len, unsigned int *p_idx,
return SCM_BOOL_F;
/* both are int/big here, I assume */
result = scm_make_ratio (uinteger, divisor);
result = scm_i_make_ratio (uinteger, divisor);
}
else if (radix == 10)
{
@ -3868,7 +3868,7 @@ scm_sum (SCM x, SCM y)
SCM_COMPLEX_IMAG (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_FRACTION_DENOMINATOR (y));
else
@ -3933,7 +3933,7 @@ scm_sum (SCM x, SCM y)
return scm_make_complex (real_part, SCM_COMPLEX_IMAG (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_FRACTION_DENOMINATOR (y));
else
@ -3986,11 +3986,11 @@ scm_sum (SCM x, SCM y)
else if (SCM_FRACTIONP (x))
{
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_FRACTION_DENOMINATOR (x));
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_FRACTION_DENOMINATOR (x));
else if (SCM_REALP (y))
@ -4000,7 +4000,7 @@ scm_sum (SCM x, SCM y)
SCM_COMPLEX_IMAG (y));
else if (SCM_FRACTIONP (y))
/* 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_DENOMINATOR (x), SCM_FRACTION_DENOMINATOR (y)));
else
@ -4041,7 +4041,7 @@ scm_difference (SCM x, SCM y)
return scm_make_complex (-SCM_COMPLEX_REAL (x),
-SCM_COMPLEX_IMAG (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));
else
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))
/* 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_DENOMINATOR (y));
else
@ -4166,7 +4166,7 @@ scm_difference (SCM x, SCM y)
return scm_make_complex (real_part, - SCM_COMPLEX_IMAG (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_DENOMINATOR (y));
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))
/* 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_FRACTION_DENOMINATOR (x));
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_FRACTION_DENOMINATOR (x));
else if (SCM_REALP (y))
@ -4233,7 +4233,7 @@ scm_difference (SCM x, SCM y)
-SCM_COMPLEX_IMAG (y));
else if (SCM_FRACTIONP (y))
/* 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_DENOMINATOR (x), SCM_FRACTION_DENOMINATOR (y)));
else
@ -4302,7 +4302,7 @@ scm_product (SCM x, SCM y)
return scm_make_complex (xx * SCM_COMPLEX_REAL (y),
xx * SCM_COMPLEX_IMAG (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));
else
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));
}
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));
else
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))
{
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));
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));
else if (SCM_REALP (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))
/* 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_product (SCM_FRACTION_DENOMINATOR (x),
SCM_FRACTION_DENOMINATOR (y)));
@ -4482,14 +4482,14 @@ scm_i_divide (SCM x, SCM y, int inexact)
{
if (inexact)
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))
{
if (inexact)
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))
{
@ -4519,7 +4519,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
}
}
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));
else
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)
return scm_from_double ((double) xx / (double) yy);
else return scm_make_ratio (x, y);
else return scm_i_make_ratio (x, y);
}
else
{
@ -4558,7 +4558,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
{
if (inexact)
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))
{
@ -4593,7 +4593,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
}
else if (SCM_FRACTIONP (y))
/* 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));
else
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)
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);
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;
}
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));
else
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);
else
#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));
}
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));
}
else if (SCM_REALP (y))
@ -4837,7 +4837,7 @@ scm_i_divide (SCM x, SCM y, int inexact)
goto complex_div;
}
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)));
else
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))))
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));
}
else
@ -5417,10 +5417,10 @@ SCM_DEFINE (scm_inexact_to_exact, "inexact->exact", 1, 0, 0,
mpq_init (frac);
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)));
/* When scm_make_ratio throws, we leak the memory allocated
/* When scm_i_make_ratio throws, we leak the memory allocated
for 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);
/* 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_numerator (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_print (scm_tc16_array, scm_raprin1);
scm_set_smob_equalp (scm_tc16_array, scm_array_equal_p);
exactly_one_third = scm_permanent_object (scm_make_ratio (scm_from_int (1),
scm_from_int (3)));
exactly_one_third = scm_permanent_object (scm_divide (scm_from_int (1),
scm_from_int (3)));
scm_add_feature ("array");
#include "libguile/unif.x"
}