GNU bug report logs -
#14905
rationalize not returning the simplest rational
Previous Next
Reported by: Göran Weinholt <goran <at> weinholt.se>
Date: Fri, 19 Jul 2013 11:26:01 UTC
Severity: normal
Done: Mark H Weaver <mhw <at> netris.org>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
[Message part 1 (text/plain, inline)]
Your bug report
#14905: rationalize not returning the simplest rational
which was filed against the guile package, has been closed.
The explanation is attached below, along with your original report.
If you require more details, please reply to 14905 <at> debbugs.gnu.org.
--
14905: http://debbugs.gnu.org/cgi/bugreport.cgi?bug=14905
GNU Bug Tracking System
Contact help-debbugs <at> gnu.org with problems
[Message part 2 (message/rfc822, inline)]
Göran Weinholt <goran <at> weinholt.se> writes:
> the procedure (rationalize x1 x2) from (rnrs) takes a number x1 and
> returns the simplest rational that doesn't differ from x1 by more than
> x2. The implementation in guile has this behavior:
>
> scheme@(guile-user)> (rationalize #e-0.67 1/4)
> $1 = -2/3
>
> The problem here is that -1/2 is simpler than -2/3 (since 1<2 and 2<3)
> and it also doesn't differ from #e-0.67 by more than 1/4 (even though
> the difference is larger than for -2/3, it is still less than 1/4). So
> the result from the expression above should be -1/2.
Fixed in 620c13e8fc02060e0af8fa38398ee4de745d41e9.
Thanks!
Mark
[Message part 3 (message/rfc822, inline)]
[Message part 4 (text/plain, inline)]
Hello schemers,
the procedure (rationalize x1 x2) from (rnrs) takes a number x1 and
returns the simplest rational that doesn't differ from x1 by more than
x2. The implementation in guile has this behavior:
scheme@(guile-user)> (rationalize #e-0.67 1/4)
$1 = -2/3
The problem here is that -1/2 is simpler than -2/3 (since 1<2 and 2<3)
and it also doesn't differ from #e-0.67 by more than 1/4 (even though
the difference is larger than for -2/3, it is still less than 1/4). So
the result from the expression above should be -1/2.
Tested with Guile 2.0.9.40-824b-dirty.
Regards,
--
Göran Weinholt <goran <at> weinholt.se>
"On your own and though you feel alone you are alive.
Don't you know it's just another day." -- You Are Alive, Fragma
[Message part 5 (application/pgp-signature, inline)]
This bug report was last modified 11 years and 309 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.