名稱空間
變體
操作

std::numeric_limits<T>::tinyness_before

來自 cppreference.com
< cpp‎ | 型別‎ | 數值限制
 
 
 
 
 
static const bool tinyness_before;
(C++11 前)
static constexpr bool tinyness_before;
(C++11 起)

對於所有浮點型別 T,如果浮點表示式在舍入之前測試下溢結果,則 std::numeric_limits<T>::tinyness_before 的值為 true

目錄

[edit] 標準特化

T std::numeric_limits<T>::tinyness_before 的值
/* 未特化 */ false
bool false
char false
signed char false
unsigned char false
wchar_t false
char8_t (C++20起) false
char16_t (C++11起) false
char32_t (C++11起) false
short false
unsigned short false
int false
unsigned int false
long false
unsigned long false
long long (C++11起) false
unsigned long long (C++11起) false
float 實現定義
double 實現定義
long double 實現定義

[edit] 注意

符合標準的 IEEE 754 浮點實現要求檢測浮點下溢,並且可以在兩種替代情況下完成此操作

  1. 如果計算結果的絕對值(在指數範圍和精度都無限的情況下計算)小於 std::numeric_limits<T>::min(),則發生下溢(並且可能引發 FE_UNDERFLOW)。此類實現會在舍入之前檢測到“微小性”(例如 UltraSparc、POWER)。
  2. 如果將結果舍入到目標浮點型別(即舍入到 std::numeric_limits<T>::digits 位)後,結果的絕對值小於 std::numeric_limits<T>::min(),則發生下溢(並且可能引發 FE_UNDERFLOW)。形式上,非零結果的絕對值(在指數範圍無限的情況下計算)小於 std::numeric_limits<T>::min()。此類實現會在舍入之後檢測到“微小性”(例如 SuperSparc)。

[edit] 示例

將最大的非規範化數乘以比 1.0 大一個機器 epsilon 的數,在舍入之前得到微小值 0x0.fffffffffffff8p-1022,但在舍入之後得到正常值 1p-1022。用於執行此測試的實現(IBM Power7)在舍入之前檢測到“微小性”。

#include <iostream>
#include <limits>
#include <cmath>
#include <cfenv>
 
int main()
{
    std::cout << "Tinyness before: " << std::boolalpha
              << std::numeric_limits<double>::tinyness_before << '\n';
 
    double denorm_max = std::nextafter(std::numeric_limits<double>::min(), 0);
    double multiplier = 1 + std::numeric_limits<double>::epsilon();
 
    std::feclearexcept(FE_ALL_EXCEPT);
 
    double result = denorm_max * multiplier; // Underflow only if tinyness_before
 
    if (std::fetestexcept(FE_UNDERFLOW))
        std::cout << "Underflow detected\n";
 
    std::cout << std::hexfloat << denorm_max << " x " << multiplier  <<  " = "
              << result << '\n';
}

可能的輸出

Tinyness before: true
Underflow detected
0xf.ffffffffffffp-1030 x 0x1.0000000000001p+0 = 0x1p-1022

[edit] 另請參閱

確定將精度損失檢測為非正規化損失而非不精確結果的浮點型別
(public static member constant) [edit]
[靜態]
確定浮點型別所用的非正規化樣式
(public static member constant) [edit]