http://oshiete1.goo.ne.jp/kotaeru.php3?q=88809
の質問に関連して、質問します。
arataさんの回答にありました参考URL
http://www.microsoft.com/mscorp/worldwide/japan/ …
を見ました。
そこにあった記述でわからないことがありました。「数値の丸め」の項に
「Visual Basic 4.0 で数値の丸めが発生するケースは、主に代入と
Format 関数があります。
代入する値が代入先のデータ型の有効けたを超える場合に丸めが行われます。
ここでの丸めは IEEE (米国電気電子技術者協会) 規格のうちでもっとも
一般的である "いちばん近い偶数に丸める" という方法をとっています。
例えば整数型への代入では、1.5 は 2、2.5 も 2、3.5 は 4 に変換されます。
これは四捨五入より結果に片寄りが少なく、誤差の累積が最も少ない方法の
ひとつです。」
この「いちばん近い偶数」を選ぶ理由は何でしょうか?
なぜ奇数はダメなのか?ご存知の方、教えてください。
No.3ベストアンサー
- 回答日時:
四捨五入の場合
0.1,0.2,0.3,0.4の4つの値が小さく
0.5,0.6,0.7,0.8,0.9の5つの値が大きくなります。
均等に値が発生するとして、値の変化は
-0.1-0.2-0.3-0.4=-1
0.5+0.4+0.3+0.2+0.1=1.5
ですから、0~99の間で、100個の値が発生する場合、0~1毎に0.5ずれるのですから、+0.5*10で+5ずれる可能性が高いわけです。これは結構大きな値ですね。
IEEEの丸めの場合
奇数では、0.5は切上げ、偶数では切り捨てられますから、
誤差の累積が0に近いわけですね。
ですから、合計値の誤差を問題にする場合は、後者の方が、合理的ですね。ちなみに、前者を算術型、後者を銀行型の丸めといいます。
本当かどうか知りませんが、アメリカの銀行では後者を使用していると聞いています。
で、偶数か、奇数かですが、どちらでも同じだと思います。どっちでもよくて、偶数に決めたのでは?
No.2
- 回答日時:
推測ですが、これは少数を記録する方式の問題だと思います。
少数は0.xxxxx×10^xxという方式で、xxの部分をすべて2進数で記録するので、2の倍数にするのが都合がよく、奇数にすると誤差が増えてしまうのでしょう。
これはおそらく、浮動小数点型という少数の記録方式を理解すれば、わかることだと思います。
私はあまり突っ込んでいませんが、調べてみては?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Borland C++ Compiler 5.5の警...
-
エラーの意味は? Lvalue req...
-
VBAでダブルコーテーション入り...
-
processing エラーで、 "cannot...
-
EXCEL/VBA 変数の値をクリップ...
-
python の 連鎖代入の文法
-
整数xxxが大き過ぎますというエ...
-
クラス中でコンストラクタを使...
-
プログラミングで変数と関数の...
-
Excel VBAでイコール二回使えま...
-
コマンド実行結果を変数に代入...
-
引数とは なんですか?
-
def partition(fn, ls): a, b =...
-
for the first timeとfirst tim...
-
フォームを開くときに、コンボ...
-
足して100になるような乱数のア...
-
C言語でCLAMP(a,b,c)
-
配列の値を置換するにはどうす...
-
C#の問題で2つの整数a,bの...
-
VBSで特定の文字列が含まれる場...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAでダブルコーテーション入り...
-
EXCEL/VBA 変数の値をクリップ...
-
エラーの意味は? Lvalue req...
-
jsp~jspにhiddenを使って変数...
-
Variant型で宣言してるのにEmpt...
-
[VBS]変数を定数に変換する方法...
-
テキストボックスの値を変数に...
-
processing エラーで、 "cannot...
-
整数xxxが大き過ぎますというエ...
-
【VBA】複合代入演算子
-
JavaScriptをURLから直接実行し...
-
VB6.0での条件文にある#の意味
-
だれがとけるの?
-
インクリメント演算子の前置(+...
-
プログラミングで変数と関数の...
-
datagridviewに行...
-
C言語 列挙型(enum型)変数について
-
verilog HDLの[=]と[<=]の使い分け
-
「%」を使って、偶数か奇数かを...
-
i++と++i ってどう違うのですか?
おすすめ情報