1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-04-30 03:40:34 +02:00

*** empty log message ***

This commit is contained in:
Marius Vollmer 2003-11-18 20:01:57 +00:00
parent f92e85f735
commit bdf26b606b
4 changed files with 99 additions and 0 deletions

42
NEWS
View file

@ -452,6 +452,48 @@ platform supports this, too. The two zeros are equal according to
(eqv? 0.0 (- 0.0)) (eqv? 0.0 (- 0.0))
=> #f => #f
** Guile now has exact rationals.
Guile can now represent fractions such as 1/3 exactly. Computing with
them is also done exactly, of course:
(* 1/3 3/2)
=> 1/2
** 'floor', 'ceiling', 'round' and 'truncate' now return exact numbers
for exact arguments.
For example: (floor 2) now returns an exact 2 where in the past it
returned an inexact 2.0. Likewise, (floor 5/4) returns an exact 1.
** inexact->exact no longer returns only integers.
Without exact rationals, the closest exact number was always an
integer, but now inexact->exact returns the fraction that is exactly
equal to a floating point number. For example:
(inexact->exact 1.234)
=> 694680242521899/562949953421312
When you want the old behavior, use 'round' explicitely:
(inexact->exact (round 1.234))
=> 1
** New function 'rationalize'.
This function finds a simple fraction that is close to a given real
number. For example (and compare with inexact->exact above):
(rationalize 1.234 0.0005)
=> 58/47
** 'odd?' and 'even?' work also for inexact integers.
Previously, (odd? 1.0) would signal an error since only exact integers
were recognized as integers. Now (odd? 1.0) returns #t, (odd? 2.0)
returns #f and (odd? 1.5) signals an error.
** We now have uninterned symbols. ** We now have uninterned symbols.
The new function 'make-symbol' will return a uninterned symbol. This The new function 'make-symbol' will return a uninterned symbol. This

1
THANKS
View file

@ -6,6 +6,7 @@ Contributors since the last release:
Thien-Thi Nguyen Thien-Thi Nguyen
Han-Wen Nienhuys Han-Wen Nienhuys
Kevin Ryde Kevin Ryde
Bill Schottstaedt
Sponsors since the last release: Sponsors since the last release:

View file

@ -1,3 +1,48 @@
2003-11-18 Marius Vollmer <marius.vollmer@uni-dortmund.de>
Support for exact fractions from Bill Schottstaedt! Thanks!
* print.c (scm_iprin1): Handle fractions.
* objects.h (scm_class_fraction): New.
* objects.c (scm_class_fraction): New.
(scm_class_of): Handle fractions.
* hash.c (scm_hasher): Handle fractions.
* numbers.c: New code for handling fraction all over the place.
(scm_odd_p, scm_even_p): Handle inexact integers.
(scm_rational_p): New function, same as scm_real_p.
(scm_round_number, scm_truncate_number, scm_ceiling, scm_floor):
New exact functions that replace the inexact 'dsubr'
implementations.
(scm_numerator, scm_denominator): New.
* numbers.h (SCM_NUMP): Recognize fractions.
(SCM_FRACTIONP, SCM_SLOPPY_FRACTIONP, SCM_FRACTION_NUMERATOR,
SCM_FRACTION_DENOMINATOR, SCM_FRACTION_SET_NUMERATOR,
SCM_FRACTION_SET_DENOMINATOR, SCM_FRACTION_REDUCED_BIT,
SCM_FRACTION_REDUCED_SET, SCM_FRACTION_REDUCED_CLEAR,
SCM_FRACTION_REDUCED): New.
(scm_floor, scm_ceiling, scm_truncate_number, scm_round_number):
New prototypes.
(scm_make_ratio, scm_rationalize, scm_numerator, scm_denominator,
scm_rational_p): New prototypes.
(scm_i_dbl2num, scm_i_fraction2double, scm_i_fraction_equalp,
scm_i_print_fraction): New prototypes.
* goops.c (create_standard_classes): Create "<fraction>" class.
* gc-mark.c (scm_gc_mark_dependencies): Handle fractions.
* gc-card.c (scm_i_sweep_card): Include scm_tc16_fraction as a
case in the switch, but do nothing for now.
* eval.c (SCM_CEVAL, SCM_APPLY, call_dsubr_1): Convert fractions
to doubles when calling 'dsubr' functions.
* eq.c (scm_eqv_p, scm_equal_p): Handle fractions.
2003-11-18 Rob Browning <rlb@defaultvalue.org> 2003-11-18 Rob Browning <rlb@defaultvalue.org>
* gen-scmconfig.c (main): remove public definition of * gen-scmconfig.c (main): remove public definition of

View file

@ -1,3 +1,14 @@
2003-11-18 Marius Vollmer <marius.vollmer@uni-dortmund.de>
* tests/numbers.test ("string->number"): Expect exact rationals
for things like "1/2" and "#e1.2".
("inexact->exact"): Expect overflow error for infs and nans.
* tests/fractions.test: New file from Bill Schottstaedt. Thanks!
* tests/bit-operations.test (fixnum-bit): Round the result so that
fixnum-bit really is an integer.
2003-11-17 Marius Vollmer <mvo@zagadka.de> 2003-11-17 Marius Vollmer <mvo@zagadka.de>
* tests/srfi-17.test: Expect a "Bad variable" error for (set! #f * tests/srfi-17.test: Expect a "Bad variable" error for (set! #f