計算機イプシロン

提供: testwiki
ナビゲーションに移動 検索に移動

計算機イプシロン(けいさんきイプシロン、テンプレート:Lang-en-short)は、浮動小数点数において、「1より大きい最小の数」と1との差のことである[1]機械イプシロン(きかいイプシロン)とも言う。また、それぞれの「イプシロン」はエプシロンとも表記されるテンプレート:Efn

概要

コンピュータで扱われる浮動小数点数は、指数部と仮数部に分かれており、単に小さい数を表すだけであれば指数部を小さくすれば表現が可能である。一方、「1より大きい最小の数」のような場合は、仮数部を使って微小な差を表現することとなる。その限界が計算機イプシロンである。

b 進法で仮数部 p 桁の浮動小数点数の場合、計算機イプシロンはb1pとなる[1]。 例えば、IEEE 754のbinary32(単精度)では、b=2p=24テンプレート:Efnなので、ϵ=2124=1.192×107となる。 同様にIEEE 754のbinary64(倍精度)ではϵ=2153=2.220×1016となり、binary128(四倍精度)ではϵ=21113=1.926×1034となる。一部の環境では拡張倍精度浮動小数点数がサポートされており、80ビット実装の場合はϵ=2164=1.084×1019となる。

定義の混乱

元来の定義では上述のとおりとなっているが、一部では「1+x1 となる最小の x」という定義、あるいは説明をしている例が存在する[2]。後者の定義では、浮動小数点演算の丸め処理の定義に依存して値が変化してしまう[1]ため、厳密には同じでない。

.NET

Microsoftの.NET Frameworkおよび.NET基本クラスライブラリに、System.Double.Epsilonという定数フィールドが定義されている[3]が、これは浮動小数点方式で表現可能な最小の正の非正規化数であり、計算機イプシロンではない[4]System.Single.Epsilonも同様である[5]。これらはC11/C++17DBL_TRUE_MINFLT_TRUE_MINに相当する[6][7]

歴史的に、「epsilon」は異なる言語において様々な概念を指す用語として使われており、混乱やバグを誘発しやすい[8]

各プログラミング言語での対応

C言語

C言語においては、<float.h>FLT_EPSILONDBL_EPSILONLDBL_EPSILONというマクロ定数が定義されており、それぞれfloat型、double型、long double型の計算機イプシロンの値となっている[1]

C++

C++ではテンプレートを利用したstd::numeric_limits<T>::epsilon()関数が定義されている[9]。返却される値は前述のC言語の定数と同値である。

Python

PythonではCのDBL_EPSILONに準ずる値がsys.float_info.epsilonとして定義されている[10]

JavaScript

JavaScriptではNumber.EPSILONが定義されている[11]

Julia

Julia は標準で計算機イプシロンを取得する関数があり eps(Float32) のように使用する。

Swift

SwiftではFloatingPointプロトコル(抽象型)に型プロパティulpOfOneが定義されている[8]。CのFLT_EPSILONDBL_EPSILONLDBL_EPSILONに相当する実装は、それぞれFloat.ulpOfOneDouble.ulpOfOneFloat80.ulpOfOneである[12][13][14]。ただしFloat80はIntel (x86) プロセッサ環境でのみ利用可能であり、AppleシリコンARMアーキテクチャ)では利用できない[15]

脚注

注釈

テンプレート:Notelist

出典

テンプレート:Reflist

関連項目

テンプレート:Computer-stub