$30 off During Our Annual Pro Sale. View Details »
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
No Error Conversion of Floating Points
Search
K Yamaguchi
November 22, 2008
Technology
0
19
No Error Conversion of Floating Points
K Yamaguchi
November 22, 2008
Tweet
Share
Other Decks in Technology
See All in Technology
Python 3.14 Overview
lycorptech_jp
PRO
1
120
mairuでつくるクレデンシャルレス開発環境 / Credential-less development environment using Mailru
mirakui
5
540
AI時代のワークフロー設計〜Durable Functions / Step Functions / Strands Agents を添えて〜
yakumo
3
230
シニアソフトウェアエンジニアになるためには
kworkdev
PRO
3
180
たまに起きる外部サービスの障害に備えたり備えなかったりする話
egmc
0
250
AWSを使う上で最低限知っておきたいセキュリティ研修を社内で実施した話 ~みんなでやるセキュリティ~
maimyyym
2
1.7k
2025年 開発生産「可能」性向上報告 サイロ解消からチームが能動性を獲得するまで/ 20251216 Naoki Takahashi
shift_evolve
PRO
1
200
AlmaLinux + KVM + Cockpit で始めるお手軽仮想化基盤 ~ 開発環境などでの利用を想定して ~
koedoyoshida
0
110
AWS CLIの新しい認証情報設定方法aws loginコマンドの実態
wkm2
6
750
GitHub Copilotを使いこなす 実例に学ぶAIコーディング活用術
74th
3
3.4k
JEDAI認定プログラム JEDAI Order 2026 エントリーのご案内 / JEDAI Order 2026 Entry
databricksjapan
0
140
SQLだけでマイグレーションしたい!
makki_d
0
550
Featured
See All Featured
Designing for humans not robots
tammielis
254
26k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.6k
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Optimising Largest Contentful Paint
csswizardry
37
3.5k
Statistics for Hackers
jakevdp
799
230k
Music & Morning Musume
bryan
46
7k
Typedesign – Prime Four
hannesfritz
42
2.9k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
46
2.6k
The Cult of Friendly URLs
andyhume
79
6.7k
It's Worth the Effort
3n
187
29k
For a Future-Friendly Web
brad_frost
180
10k
Transcript
浮動⼩数点演算の無誤差変換 と ⾼精度計算 のおはなし quintia 2008/11/22
今回のお題 このつぶやきで決めました
元ネタ p数学セミナー 2008年11⽉号 特集記事 (⽇本評論社) pD.E.Knuth: The Art of Computer
Programming, Vol.2, 1969.
浮動⼩数点演算について p浮動⼩数点表現の限界 pどういう意味なのか? pKnuth先⽣のお⾔葉
浮動⼩数点表現の限界 p (1+260) - 260 正解は 1 p浮動⼩数点(単精度)で演算すると…… fl( 1
+260 ) = 260 fl( 260-260 ) = 0 p 0 になってしまう! fl( ) は 「実数での演算じゃないよ 浮動⼩数点での演算だよ」 という印
どういう意味なのか? p浮動⼩数点演算では「結合法則」が 成⽴しない場合がある、ということ fl( (a + b) + c )
≠ fl( a + (b + c) ) p fl( ) の中⾝は 「括弧を外して書いてはいけない」 のだ!
Knuth先⽣のお⾔葉 p「a1 +a2 +a3 」(略)などの数学的記法は, もともと結合法則が成り⽴つことを前 提として作ってある.プログラマは, 結合法則が成り⽴つ暗黙の前提で考え ないように,特に注意しなければなら ない.
The Art of Computer Programming 2 第3版 ⽇本語版 p217
無誤差変換 p無誤差変換の概念 p浮動⼩数点演算の誤差を計算する p誤差計算式の妙 pKnuth先⽣のお⾔葉 ふたたび
無誤差変換の概念 p無誤差変換というよりは、実数演算の解と、 浮動⼩数点演算の解との誤差という感覚 a + b = fl( a +
b ) + x p x の部分が計算によって⽣じる誤差 pしかし、これを計算できるのか……?
浮動⼩数点演算の誤差を計算する p計算できる! (D.E.Knuth, 1969) fl( (a - ((a + b)
- (a - b))) + (b - (a - b)) ) p乗算については T.J.Dekker, (1971) によって ⽰された式がある
誤差計算式の妙(1) fl( (a - ((a + b) - (a -
b))) + (b - (a - b)) ) p実数計算ならば括弧をはらえるので ちょっと試してみる a-a-b+a-b+b-a+b = 0 p実数計算では必ず0になる式!
誤差計算式の妙(2) fl( (a - ((a + b) - (a -
b))) + (b - (a - b)) ) 結合法則が成⽴ 値が0 誤差が⽣じなかった 結合法則が成⽴しない 値が0以外 誤差が⽣じた
Knuth先⽣のお⾔葉 ふたたび p「a1 +a2 +a3 」(略)などの数学的記法は, もともと結合法則が成り⽴つことを前 提として作ってある.プログラマは, 結合法則が成り⽴つ暗黙の前提で考え ないように,特に注意しなければなら
ない. The Art of Computer Programming 2 第3版 ⽇本語版 p217
⾼精度計算の例を簡単に (1+260) - 260 1+260 解 260 誤差 1 260
- 260 解 0 誤差 0 解が0 誤差の総和が1 p概念としては、解が1ということ
実際にコードを書いてみた pJavaで書いてみた pJavaの⼩数計算 pDelphiで書いてみた
Javaで書いてみた public static void main(String[] args) { float a =
1; float b = (float)Math.pow(2, 127); System.out.println("b: "+b); float u = a + b; float c = a - b; float v = (a-(u-c)) + (b-c); System.out.println("u: "+u); System.out.println("v: "+v); } 結果 b: 1.7014118E38 u: 1.7014118E38 v: NaN NaNが出てきた!
Javaの⼩数計算 pFloat や Double に以下の様な定義がある p POSITIVE_INFINITY (正の無限⼤ ) p
NEGATIVE_INIFINITY(負の無限⼤) p NaN(⾮数) p+0.0 と -0.0 が区別されている p1.0 / +0.0 > POSITIVE_INFINITY p1.0 / -0.0 > NEGATIVE_INFINITY p0.0 / 0.0 > NaN
Delphiで書いてみた p計画通り!! var a,b,c,u,v: Single; begin a:=1.0; b:=Power(2.0, 60.0); u:=a+b;
c:=a-b; v:=(a-(u-c))+(b-c); ShowMessage(Format('%f , %f', [u, v])); end; 結果: 1.15292150460684698E18 , 1.00 誤差 1 近似解 260
ありがとうございました