std::numeric_limits<T>:: tinyness_before
|
static
const
bool
tinyness_before
;
|
(C++11 이전) | |
|
static
constexpr
bool
tinyness_before
;
|
(C++11 이후) | |
std::
numeric_limits
<
T
>
::
tinyness_before
의 값은
true
입니다. 이는 반올림 전에 부동 소수점 표현식의 결과에 대한 언더플로우를 테스트하는 모든 부동 소수점 타입
T
에 해당합니다.
목차 |
표준 특수화
T
|
std:: numeric_limits < T > :: tinyness_before 의 값 |
| /* non-specialized */ | 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 | 구현 정의 |
참고 사항
표준을 준수하는 IEEE 754 부동 소수점 구현은 부동 소수점 언더플로우를 감지해야 하며, 이를 수행할 수 있는 두 가지 대안 상황이 있습니다
- 언더플로우는 (그리고 FE_UNDERFLOW 가 발생할 수 있음) 계산 결과의 절대값이 지수 범위와 정밀도가 무한하다고 가정하고 계산했을 때 std:: numeric_limits < T > :: min ( ) 보다 작은 경우 발생합니다. 이러한 구현은 반올림 전에 아주 작은 값(tinyness)을 감지합니다 (예: UltraSparc, POWER).
- 언더플로우는 (그리고 FE_UNDERFLOW 가 발생할 수 있음) 결과를 대상 부동 소수점 타입으로 반올림한 후 (즉, std:: numeric_limits < T > :: digits 비트로 반올림), 결과의 절대값이 std:: numeric_limits < T > :: min ( ) 보다 작은 경우 발생합니다. 형식적으로, 지수 범위가 무한하다고 가정하고 계산된 0이 아닌 결과의 절대값이 std:: numeric_limits < T > :: min ( ) 보다 작은 경우입니다. 이러한 구현은 반올림 후에 아주 작은 값(tinyness)을 감지합니다 (예: SuperSparc).
예제
가장 큰 서브노멀 수에 1.0보다 머신 엡실론 하나만큼 큰 수를 곱하면 반올림 전에는 0x0.fffffffffffff8p-1022라는 아주 작은 값을 가지지만, 반올림 후에는 1p-1022라는 정규 값을 가집니다. 이 테스트를 실행하는 데 사용된 구현( IBM Power7 )은 반올림 전에 tinyness를 감지합니다.
#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
참고 항목
|
[static]
|
부동소수점 타입이 정밀도 손실을 부정확한 결과가 아닌 비정규화 손실로 감지하는지 식별
(public static member constant) |
|
[static]
|
부동소수점 타입이 사용하는 비정규화 스타일을 식별
(public static member constant) |