[#10226] 組み込み Ruby — Kazuhiro Yoshida <moriq.kazuhiro@...>

もりきゅうです。

17 messages 2000/07/05
[#10230] Re: 組み込み Ruby — matz@... (Yukihiro Matsumoto) 2000/07/05

まつもと ゆきひろです

[#10231] Re: 組み込み Ruby — Kazuhiro Yoshida <moriq.kazuhiro@...> 2000/07/05

もりきゅうです。

[#10237] Re: 組み込み Ruby — matz@... (Yukihiro Matsumoto) 2000/07/06

まつもと ゆきひろです

[#10278] Re: environment variables — WATANABE Hirofumi <eban@...>

わたなべです.

162 messages 2000/07/11
[#10285] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/07/11

なかだです。

[#10306] Re: environment variables — nobu.nakada@... 2000/07/12

なかだです。

[#10355] Re: environment variables — nobu.nakada@... 2000/07/20

なかだです。

[#10359] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/23

小松です。

[#10360] Re: environment variables — nobu.nakada@... 2000/07/23

なかだです。

[#10361] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/23

小松です。

[#10370] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/07/24

なかだです。

[#10374] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/24

小松です。

[#10376] Re: environment variables — nobu.nakada@... 2000/07/24

なかだです。

[#10380] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/25

小松です。

[#10381] Re: environment variables — matz@... (Yukihiro Matsumoto) 2000/07/25

まつもと ゆきひろです

[#10386] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/07/25

なかだです。

[#10397] Re: environment variables — matz@... (Yukihiro Matsumoto) 2000/07/25

まつもと ゆきひろです

[#10399] Re: environment variables — nobu.nakada@... 2000/07/25

なかだです。

[#10407] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/26

小松です。

[#10409] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/26

小松です。

[#10416] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/07/26

なかだです。

[#10421] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/26

小松です。

[#10435] Re: environment variables — nobu.nakada@... 2000/07/27

なかだです。

[#10442] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/28

小松です。

[#10444] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/07/28

なかだです。

[#10446] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/28

小松です。

[#10453] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/07/31

なかだです。

[#10459] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/31

小松です。

[#10464] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/07/31

なかだです。

[#10466] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/07/31

小松です。

[#10472] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/01

小松です。

[#10474] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/01

なかだです。

[#10475] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/01

小松です。

[#10476] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/01

小松です。

[#10480] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/01

なかだです。

[#10483] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/01

小松です。

[#10485] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/01

なかだです。

[#10489] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/01

小松です。

[#10490] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/01

なかだです。

[#10491] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/01

小松です。

[#10492] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/01

なかだです。

[#10493] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/01

小松です。

[#10494] Re: environment variables — matz@... (Yukihiro Matsumoto) 2000/08/01

まつもと ゆきひろです

[#10495] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/02

なかだです。

[#10506] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/02

小松です。

[#10507] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/02

なかだです。

[#10508] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/02

小松です。

[#10509] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/02

なかだです。

[#10511] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/02

小松です。

[#10512] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/02

小松です。

[#10515] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/03

なかだです。

[#10516] Re: environment variables — Katsuyuki Komatsu <komatsu@...> 2000/08/03

小松です。

[#10518] Re: environment variables — matz@... (Yukihiro Matsumoto) 2000/08/03

まつもと ゆきひろです

[#10531] Re: environment variables — "Shigeo Kobayashi" <shigeo@...> 2000/08/03

小林です。

[#10547] Re: environment variables — Satoshi Nojo <nojo@...> 2000/08/03

能條といいます.

[#10549] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/04

なかだです。

[#10555] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/08/04

なかだです。

[#10558] Re: environment variables — matz@... (Yukihiro Matsumoto) 2000/08/04

まつもと ゆきひろです

[#10364] Re: environment variables — matz@... (Yukihiro Matsumoto) 2000/07/24

まつもと ゆきひろです

[#10365] Re: environment variables — WATANABE Hirofumi <eban@...> 2000/07/24

わたなべです.

[#10368] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/07/24

なかだです。

[#10369] Re: environment variables — WATANABE Hirofumi <eban@...> 2000/07/24

わたなべです.

[#10371] Re: environment variables — "Nobuyoshi.Nakada" <nobu.nakada@...> 2000/07/24

なかだです。

[#10372] Re: environment variables — WATANABE Hirofumi <eban@...> 2000/07/24

わたなべです.

[#10384] ruby 1.4.6 preview — matz@... (Yukihiro Matsumoto)

まつもと ゆきひろです

24 messages 2000/07/25

[ruby-dev:10214] Re: modulo and remainder

From: matz@... (Yukihiro Matsumoto)
Date: 2000-07-05 04:51:16 UTC
List: ruby-dev #10214
まつもと ゆきひろです

In message "[ruby-dev:10204] Re: modulo and remainder"
    on 00/07/04, Tadayoshi Funaba <tadf@kt.rim.or.jp> writes:

|実は、僕もまつもとさんの意図がよくわからないかもしれないです。僕は、簡
|単に一貫性も互換性も確保できると思っているのですが、まつもとさんは、そ
|う思ってないのかなあ。僕の考えが浅はかなのかしら。そもそも、これまでの
|問題も、仕様の問題なのか、実装の課題を解決できなかったのか、よくわから
|ないままです。

最大の問題は

 v = x / y
 w = x % y

または

 v, w = x.divmod(y)

としたときに

  y * v + w = x

が成立していなかったことです。

次の問題はFloat/Rational/Integerでdivmodの挙動が異なってい
たことです。

どちらを解決するためにも現状の振舞を変更する必要があります。

で、前者を満たす方法はふたつあります。ひとつはfloorで丸める
moduloとtruncate(0方向への丸め)で丸めるremainderです。で、後
者を解決するため、すべての数クラスでこの挙動を揃える必要があ
ります。

で、今回の変更で私はremaidnerに揃えることを選んだというわけ
です。なにか強いポリシーがあってremainderの方を選んだわけで
はないのです。私は負の数を含むmodulo/remainderを使ったことは
ありませんし、残念なことに実際に変更が行われるまで「どっちで
も一緒」という意見しか聞けなかったので、それを疑う余地はなく、
ただ実装がより簡単な方を選んだだけです。

moduloを用意しなかったことは不適切だったと思いますが、modulo 
という名前のメソッドだけ追加することは難しくありません。

|で、僕が一番困るのが、modulo がまったくなくなってしまうことです。大抵
|の場合、僕が必要なのは、modulo のほうです。単純に、一利用者として困る
|のです。Common Lisp なら mod、Scheme なら modulo、Python、Perl、Ruby 
|では、% で提供されていると認識しています (正しい?)。

正しいと思います。いずれにせよなんらかの形でmoduloを得る方法
は提供します。

|つぎに、% の振舞いが変り、remainder がなくなるのは、互換性を損うので、
|望ましくないと思います。僕もすでに書いたコードを調べなきゃならないです。
|ただ、僕は、remainder のほうをつかった憶えはないです。なので、
|remainder がなくなっても、それはあまり気にしないかもしれないです。

すでに述べた理由によりどこかで振舞が変わるのは不可避だと思い
ます。どれが一番望ましいか、あるいは非互換性が問題にならない
かという違いはあるでしょうが、残念ながら私には判断できません。

|僕としては、最後の Common Lisp 流 mod、rem メソッドを導入、% を どちら
|かの別名とする、が一番ありがたく、その場合は、% が mod (modulo) の別名
|であれば、この上ないです。

了解です。その線を検討します。

|とりあえず、この Common Lisp を基にした仕様で、まつもとさんが、望む一
|貫性なりなんなりが、確保できないものかと思うのですが、数学な人達はどう
|思うかしら。

私も知りたいです。というか、いろんな人の意見が聞きたいんです
けどねえ。

|でも、Ruby では、整数は floor に応答しません。ここで、Ruby は負けてい
|ると思います。いちいち、型を検査すべきなのでしょうか。でも、それはより
|一般的なコードを書くことの妨げにしかならないように思います。
|
|一利用者としては、すべての数値クラスで、floor、ceil trunc, round がつ
|かえて、to_i は trunc の別名ということになれば、すっきりすると思うので
|すが。

むむ、たしかに総称的に扱えるようにより高いクラスでfloor,
ceil, round, truncate使えるようにした方が良いでしょうね。こ
れも考えてみます。

                                まつもと ゆきひろ /:|}

In This Thread