[#30743] 大きな数の大まかな割り算 — Yukihiro Matsumoto <matz@...>
まつもと ゆきひろです
17 messages
2007/05/01
[#30753] Re: 大きな数の大まかな割り算
— Nobuyoshi Nakada <nobu@...>
2007/05/02
なかだです。
[#30754] Re: 大きな数の大まかな割り算
— Yukihiro Matsumoto <matz@...>
2007/05/02
まつもと ゆきひろです
[#30755] Re: 大きな数の大まかな割り算
— Nobuyoshi Nakada <nobu@...>
2007/05/02
なかだです。
[#30757] Re: 大きな数の大まかな割り算
— Yukihiro Matsumoto <matz@...>
2007/05/02
まつもと ゆきひろです
[#30765] Re: [ruby-cvs:19483] Ruby:r12247: * lib/date/format.rb (Format::Bag#method_missing): get rid of — Tadayoshi Funaba <tadf@...>
> Log:
4 messages
2007/05/06
[#30767] Re: [ruby-cvs:19483] Ruby:r12247: * lib/date/format.rb (Format::Bag#method_missing): get rid of
— Yukihiro Matsumoto <matz@...>
2007/05/06
まつもと ゆきひろです
[#30783] Fwd: ruby-mode — Seiji Zenitani <zenitani@...>
こんにちは。
13 messages
2007/05/14
[#30813] Re: Fwd: ruby-mode
— Seiji Zenitani <zenitani@...>
2007/05/25
重ねて失礼いたします。
[#30784] [BUG on Ruby??] Ruby/Tk on Ruby1.8.[56] is too slow on Windows — Hidetoshi NAGAI <nagai@...>
永井@知能.九工大です.
7 messages
2007/05/16
[#30785] Re: [BUG on Ruby??] Ruby/Tk on Ruby1.8.[56] is too slow on Windows
— "U.Nakamura" <usa@...>
2007/05/17
こんにちは、なかむら(う)です。
[#30786] Re: [BUG on Ruby??] Ruby/Tk on Ruby1.8.[56] is too slow on Windows
— Hidetoshi NAGAI <nagai@...>
2007/05/17
永井@知能.九工大です.
[#30800] tail call optimization — SASADA Koichi <ko1@...>
ささだです.
6 messages
2007/05/21
[#30810] Re: FileUtils.rm_rf misfeature? — Nobuyoshi Nakada <nobu@...>
なかだです。
5 messages
2007/05/24
[#30827] Supporting Fiber — SASADA Koichi <ko1@...>
ささだです。
22 messages
2007/05/27
[#30828] Re: Supporting Fiber
— Shugo Maeda <shugo@...>
2007/05/28
前田です。
[#30924] Re: Supporting Fiber
— "Yusuke ENDOH" <mame@...>
2007/06/07
遠藤です。
[#30925] Re: Supporting Fiber
— SASADA Koichi <ko1@...>
2007/06/07
ささだです。
[#30941] Re: Supporting Fiber
— "Yusuke ENDOH" <mame@...>
2007/06/09
遠藤です。
[#30832] callcc, each and local val — sheepman <sheepman@...>
こんばんは、sheepman です。
5 messages
2007/05/29
[ruby-dev:30746] Re: 大きな数の大まかな割り算
From:
keiju@... (石塚圭樹)
Date:
2007-05-02 02:11:47 UTC
List:
ruby-dev #30746
けいじゅ@いしつかです.
In [ruby-dev:30743] the message: "[ruby-dev:30743] 大きな数の大まかな
割り算", on May/02 08:56(JST) Yukihiro Matsumoto writes:
>まつもと ゆきひろです
>
>[ruby-core:11069]で報告があったのですが、rationalの分子分母
>があまりに大きいとFloatに変換できず、本来有限の値なのに結果
>がNaNになってしまうようです。
>というシンプルなものであるせいなのですが、Float(double)の範
>囲内で収まるような割り算を行うアルゴリズムをご存じの人はいま
>せんか?
私の方の版では,
class Rational
def to_f
m = Float.prec_size
e = m - abs.log2floor
Math.ldexp((self * 2**e).floor.to_f,-e)
end
end
class Integer
def log2floor
raise RangeError, "not defined for self <= 0" if self <= 0
return 0 if self==1
return self.div(2).log2floor + 1 if size==4
self.div(2**(8*(size-4))).log2floor + 8*(size-4)
end
end
となっていました.
これだと, 結果の指数部がFloatの範囲に入っていれば動作します.
ただ, Fload.prec_size がどこにあるのかわからない...
__
---------------------------------------------------->> 石塚 圭樹 <<---
---------------------------------->> e-mail: keiju@ishitsuka.com <<---