Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
なぜfloatで丸め誤差が生じるのか ~decimalとの違いを理解しよう~
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Haruki Yoshida
September 08, 2023
Technology
4
2.1k
なぜfloatで丸め誤差が生じるのか ~decimalとの違いを理解しよう~
float型で誤差が生じる理由を2進数と小数の観点から解説しています。
Haruki Yoshida
September 08, 2023
Tweet
Share
More Decks by Haruki Yoshida
See All by Haruki Yoshida
Docker再入門 ~コンテナ・イメージ編~
yoshiyoshiharu
38
16k
トランザクションに歩み寄る ~はじめの第1歩編~
yoshiyoshiharu
6
2.9k
曳光弾型開発のススメ
yoshiyoshiharu
3
1.9k
Other Decks in Technology
See All in Technology
Cosmos World Foundation Model Platform for Physical AI
takmin
0
980
Claude Code for NOT Programming
kawaguti
PRO
1
110
GitHub Issue Templates + Coding Agentで簡単みんなでIaC/Easy IaC for Everyone with GitHub Issue Templates + Coding Agent
aeonpeople
1
260
【Ubie】AIを活用した広告アセット「爆速」生成事例 | AI_Ops_Community_Vol.2
yoshiki_0316
1
120
コンテナセキュリティの最新事情 ~ 2026年版 ~
kyohmizu
7
2.5k
10Xにおける品質保証活動の全体像と改善 #no_more_wait_for_test
nihonbuson
PRO
2
340
22nd ACRi Webinar - NTT Kawahara-san's slide
nao_sumikawa
0
120
広告の効果検証を題材にした因果推論の精度検証について
zozotech
PRO
0
210
AzureでのIaC - Bicep? Terraform? それ早く言ってよ会議
torumakabe
1
620
ブロックテーマでサイトをリニューアルした話 / 2026-01-31 Kansai WordPress Meetup
torounit
0
480
今日から始めるAmazon Bedrock AgentCore
har1101
4
420
外部キー制約の知っておいて欲しいこと - RDBMSを正しく使うために必要なこと / FOREIGN KEY Night
soudai
PRO
12
5.6k
Featured
See All Featured
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.1k
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.2k
16th Malabo Montpellier Forum Presentation
akademiya2063
PRO
0
53
HU Berlin: Industrial-Strength Natural Language Processing with spaCy and Prodigy
inesmontani
PRO
0
230
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
54k
Embracing the Ebb and Flow
colly
88
5k
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
0
2.4k
Bootstrapping a Software Product
garrettdimon
PRO
307
120k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
0
440
What does AI have to do with Human Rights?
axbom
PRO
0
2k
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
96
Transcript
なぜfloat で丸め誤差が生じるのか decimalとの違いを理解しよう
Agenda 2進数と小数 Float型の仕組み 丸め誤差 Decimal型の仕組み まとめ
2 進数と小数
2 進数と小数 コンピュータは2進数でデータを持つ 10 進数を2 進数で表すときは、 の足し合わせで表現 10進数に変換 2n ex)
2 進数と小数 10進数は の足し合わせで表現する 2n すべての整数は2進数で正確に表現できる
2 進数と小数 10進数は の足し合わせで表現する 2n すべての整数は2進数で正確に表現できる じゃあ小数はどうなの?
2 進数と小数 これらを足し合わせて小数点以下を表現 改めて、2 進数で10 進数を表すには の足し合わせで表現する 小数部分は、n = -1,
-2, -3... で表現 2n
2 進数と小数 2 進数で小数は正確に表現できたり、できなかったりする 正確に表現できるとき 正確に表現できないとき 無限に続く
指数表記 非常に大きい or 小さい数を表現する際に、メモリを節約できる 2進数の場合 2 進数と小数
2 進数と小数 ここまでのまとめ 10進数は の足し合わせで表現する 2n 整数は2進数で正確に表現できる 小数は2進数で正確に表現できたり、できなかったりする
float 型の仕組み
の値 符号部 指数部 仮数部 float 型の仕組み float 型(32 ビット) 符号部(1
ビット) 指数部(8 ビット) 仮数部(23 ビット)
の値 符号部 指数部 仮数部 float 型の仕組み double 型(64 ビット) 実はRuby
のFloat クラスはこっち 符号部(1 ビット) 指数部(11 ビット) 仮数部(52 ビット)
丸め誤差
丸め誤差 小数は2 進数で正確に表せないときがある 小数は有限の桁数で近似する( 丸める)
丸め誤差 double 型での例 52 ビット 四捨五入 指数表記
丸め誤差 Ruby で試す 浮動小数点数は近似されている( 丸められている) ことがわかる
丸め誤差 誤差による計算のずれ ex) 切り捨てや切り上げ 260.7100 を小数4 桁目を切り捨て ↓ 260.710 になるべきだが、260.709
になる
decimal 型の仕組み
の値 符号部 指数部 仮数部 decimal 型の仕組み 符号部(1 ビット) 指数部(7 ビット)
仮数部(96 ビット) decimal 型(128 ビット)
の値 符号部 指数部 仮数部 3 decimal 型の仕組み 整数 整数では誤差が生じないため、 decimal
型では丸め誤差は生じない 0 0 0 0 0 0 1 1 1 1 1 1 1 1 0 ※ 空白部は0 123 ex)
decimal 型の仕組み decimal 型のデメリット メモリ使用量が大きい 計算のパフォーマンスが遅い
まとめ 小数を2 進数で正確に表せないことが多い float やdouble で2 進数のまま表すと、丸め誤差が生じる decimal 型は10 進数で表現するので、丸め誤差が生じない
参考文献 https://www.cc.kyoto- su.ac.jp/~yamada/programming/float.html https://learn.microsoft.com/ja-jp/dotnet/visual- basic/language-reference/data-types/decimal-data-type