[#8824] [REQ] Integer#{hex,dec,oct,bin}, String#bin — gotoken@... (GOTO Kentaro)

ごとけんです

38 messages 2000/01/05
[#8839] Re: [REQ] Integer#{hex,dec,oct,bin}, String#bin — matz@... (Yukihiro Matsumoto) 2000/01/06

まつもと ゆきひろです

[#8842] Re: [REQ] Integer#{hex,dec,oct,bin}, String#bin — gotoken@... (GOTO Kentaro) 2000/01/06

ごとけんです

[#8843] Re: [REQ] Integer#{hex,dec,oct,bin}, String#bin — matz@... (Yukihiro Matsumoto) 2000/01/06

まつもと ゆきひろです

[#8844] Re: [REQ] Integer#{hex,dec,oct,bin}, String#bin — gotoken@... (GOTO Kentaro) 2000/01/06

ごとけんです

[#8846] Re: [REQ] Integer#{hex,dec,oct,bin}, String#bin — matz@... (Yukihiro Matsumoto) 2000/01/06

まつもと ゆきひろです

[#8847] Re: [REQ] Integer#{hex,dec,oct,bin}, String#bin — gotoken@... (GOTO Kentaro) 2000/01/06

ごとけんです

[#8893] Re: [ruby-list:20142] Re: Range expansion? — Akinori MUSHA aka knu <knu@...>

 knuです。ruby-listから舞台を移しました。

13 messages 2000/01/09

[#8980] 1.4.3 patch for near-future *BSD IPv6 support — Jun-ichiro itojun Hagino <itojun@...>

近い将来の{Net,Free,Open}BSDにはKAME IPv6 stackが統合されています。

17 messages 2000/01/20
[#8981] Re: 1.4.3 patch for near-future *BSD IPv6 support — Jun-ichiro itojun Hagino <itojun@...> 2000/01/20

> それから、

[ruby-dev:8870] Re: DoubleFloat

From: EGUCHI Osamu <eguchi@...>
Date: 2000-01-07 06:52:36 UTC
List: ruby-dev #8870
えぐち@エスアンドイー です。

>>> In message [ruby-dev:8869] Re: DoubleFloat
    On Fri, 7 Jan 2000 15:08:06 +0900, gotoken@math.sci.hokudai.ac.jp (GOTO Kentaro) said:

ご> In message "[ruby-dev:8867] Re: DoubleFloat"
ご>     on 00/01/07, EGUCHI Osamu <eguchi@cagiva.shizuokanet.ne.jp> writes:
ご> >ところで、SigleFloat の存在理由ってどういう物がありますか?
ご> >SingleFloat の特徴を考えると、、
ご> >
ご> > + メモリ消費量は殆んど変わらない
ご> > + 演算速度は殆んど変わらない
ご> >   (C 言語が float を double に昇格して演算するので)
ご> > + 精度か落ちる
ご> >
ご> >の様に思え、これだけを見ると存在価値に少々疑問を感じます。
ご> >#むしろ C の long double に対応するクラスが望まれているかも、
ご> 
ご> 主に精度の問題です。実測データの多くは1に十分近い値であり、
ご> なおかつ精度も高々4桁くらいしかありません。そのため数値デー
ご> タはfloatのビットマップとして扱うことが通例であるという点が
ご> まず1点。それから多くのfortranのライブラリ関数は単精度のイン
ご> ターフェイスを持っていますが、毎度キャストするのは効率が悪い
ご> 上に、精度的に問題があります。

いまの Float が必要以上の精度を持っている(局面がある)
と言う事については同感ですが、かといって、、
  精度を落しても、メモリ消費や演算速度に良い影響が期待できない以上、
  系を複雑にしてまで、導入する動機は希薄に思える。
と言うのが私の意見です。

それとも、低精度の実数の「精度が低い事」そのもの価値を
見い出しているのでしょうか?

また C では、float -> double -> float の2回の型変換で、
精度が失われない事を処理系に要求していますので、これ自体が
現状で精度に問題を生じてはいないと思います。

#内部表現は float でも演算の度に double に昇格するのが
#C 言語の仕様ですので、(暗黙の)キャストは不可避です。

ご> これらの点を昔まつもとさんに認められて実装は自分でしてねって
ご> ことでお墨付をいただいた次第です。

「お墨付」には弱いのですが(笑)
上の理由で、SingleFloat の必要性や有用性に若干の疑問を感じます。

ご> >#むしろ C の long double に対応するクラスが望まれているかも、
ご> 
ご> long double というか拡張倍精度形式に自由度があって処理系依存
ご> 性が高いので低速なソフトウェア実現をしないといけないでしょう。

処理系への依存性は確かに高いですが、たとえば、

  #include <stdio.h>
  main()
  {
    printf("%u\n", sizeof (long double));
  }

って大体今の処理系では通りませんか?
#ただ、例えば printf() が "%lf" をサポートしているか等は微妙!
また、long double をサポートしていない処理系では、
ソフトウェアによる実装よりも、未サポート例外か、Float で代替
が良いように思えます。

ご> >まだ実装には移していませんが、この種のアプローチ(高速低精度な実数)に
ご> >需要はあるでしょうか?
ご> 
ご> 数値の需要は高速性よりも、ポータビリティの要求が大きいです。
ご> その点でいうと、浮動小数点数ではなく2バイト整数というのが欲
ご> しい局面は結構あります。ちなみに整数の規約はCのレベルにしか
ご> 存在しないためにずっと緩いので、2バイト整数の実装は面倒です。

あぁ、なるほど、結局 C の float や short の挙動と完全に一致する
クラスを(データの)ポータビリティの為に欲しいと言う事ですね。
特に精度についての互換性を要求している様に思えますが、
この理解であってますか?

	えぐち

In This Thread