除算や平方根を含む数学ライブラリー関数の結果における相対誤差を定義します。これは C++ 固有のコンテンツです。DPC++ には適用されません。
Linux*: | -fimf-accuracy-bits=bits[:funclist] |
Windows*: | /Qimf-accuracy-bits:bits[:funclist] |
bits |
コンパイラーで使用する正しいビット数を示す正の浮動小数点数です。 数値形式は、[digits] [.digits] [ { e | E }[sign]digits] です。 |
funclist |
属性が適用される 1 つまたは複数の数学ライブラリー関数のリストです (オプション)。複数の関数を指定する場合は、カンマで区切る必要があります。 sin と sinf のように特定の精度向けのバリエーションは異なる関数と見なされるため、単精度と倍精度の両方の正弦関数における相対誤差を指定するには、-fimf-accuracy-bits=23:sin,sinf (または /Qimf-accuracy-bits:23:sin,sinf) を使用する必要があります。 また、単精度除算は /f、倍精度除算は /、拡張精度除算は /l、4 倍精度除算は /q のように、記号を使って指定することもできます。例えば、-fimf-accuracy-bits=10.0:/f または /Qimf-accuracy-bits:10.0:/f のように指定します。 |
-fimf-precision=medium または /Qimf-precision:medium |
コンパイラーは、数学ライブラリー関数を呼び出すときに medium 精度を使用します。ほかのオプションも精度に影響することがあります。詳細は、下記を参照してください。 |
このオプションは、数学ライブラリー関数の結果において、正しいビット数により測定される相対誤差を定義します。
次の数式は、ビットを ulps に変換するのに使用されます: ulps = 2p-1-bits。p はターゲット形式の仮数ビットの数 (24、53、64。順に、単精度、倍精度、長倍精度) です。
このオプションは、実行時のパフォーマンスと結果の精度に影響します。
特定の数学関数の精度を定義する必要がある場合は、その関数名を指定します。例えば、倍精度の正弦関数の場合は sin、単精度の正弦関数の場合は sinf を指定します。そして、次のように指定します。
-fimf-accuracy-bits=23:sinf,cosf,logf または /Qimf-accuracy-bits:23:sinf,cosf,logf (単精度の正弦、余弦、自然対数の場合)
-fimf-accuracy-bits=52:sqrt,/,trunc または /Qimf-accuracy-bits:52:sqrt,/,trunc (倍精度の平方根、除算、切り捨ての場合)
-fimf-accuracy-bits=10:powf または /Qimf-accuracy-bits:10:powf (単精度の累乗の場合)
関数名を指定しない場合、すべての関数 (およびすべての精度) に設定が適用されます。ただし、個々の関数名を指定すると、指定された関数の対応する精度のみに設定が適用されます。例えば、sinf は単精度の正弦関数のみ、sin は倍精度の正弦関数のみ、sinl は拡張精度の正弦関数のみ、というように適用されます。
相対誤差の最大限許容値を指定するオプションは 3 つあります。次のとおりです。
-fimf-precision (Linux*) または /Qimf-precision (Windows*)
-fimf-max-error (Linux*) または /Qimf-max-error (Windows*)
-fimf-accuracy-bits (Linux*) または /Qimf-accuracy-bits (Windows*)
これらのオプションの 2 つ以上が指定された場合は、コマンドラインで最後に指定された相対誤差の最大限許容値がデフォルト値になります。
これらのオプションのいずれも指定されない場合は、次のオプションの設定に応じて、デフォルトの相対誤差の最大限許容値が決定されます。
-fp-model (Linux*) または /fp (Windows*)
LIBM (数学ライブラリー) および SVML (Short Vector Math Library) ライブラリーの多くのルーチンは、互換マイクロプロセッサーよりもインテル製マイクロプロセッサーでより高度に最適化されます。
なし
製品および性能に関する情報 |
---|
性能は、使用状況、構成、その他の要因によって異なります。詳細については、http://www.intel.com/PerformanceIndex/ (英語) を参照してください。 注意事項の改訂 #20201201 |