Namespaces
Variants

std:: isinf

From cppreference.net
Common mathematical functions
Nearest integer floating point operations
(C++11)
(C++11)
(C++11) (C++11) (C++11)
Floating point manipulation functions
(C++11) (C++11)
(C++11)
(C++11)
Classification and comparison
(C++11)
(C++11)
isinf
(C++11)
(C++11)
(C++11)
(C++11)
Types
(C++11)
(C++11)
(C++11)
Macro constants
ヘッダーで定義 <cmath>
(1)
bool isinf ( float num ) ;

bool isinf ( double num ) ;

bool isinf ( long double num ) ;
(C++11以降)
(C++23まで)
constexpr bool isinf ( /*floating-point-type*/ num ) ;
(C++23以降)
ヘッダーで定義 <simd>
template < /*math-floating-point*/ V >

constexpr typename /*deduced-simd-t*/ < V > :: mask_type

isinf ( const V & v_num ) ;
(S) (C++26以降)
ヘッダーで定義 <cmath>
template < class Integer >
bool isinf ( Integer num ) ;
(A) (C++11以降)
(C++23以降 constexpr)
1) 指定された浮動小数点数 num が正または負の無限大であるかどうかを判定する。 ライブラリはパラメータ num の型として、すべてのcv修飾されていない浮動小数点型に対するオーバーロードを提供する。 (C++23以降)
S) SIMDオーバーロードは v_num に対して要素ごとの std::isinf を実行します。
(定義については math-floating-point および deduced-simd-t を参照)
(C++26以降)
A) すべての整数型に対して追加のオーバーロードが提供されており、これらは double として扱われます。

目次

パラメータ

num - 浮動小数点または整数値
v_num - 要素型が浮動小数点型である std::basic_simd 特殊化のデータ並列オブジェクト

戻り値

1) true num が無限大の場合、 false それ以外の場合。
S) データ並列マスクオブジェクトで、範囲 [ 0 , v_num. size ( ) ) 内の全ての i について、i 番目 の要素が true となるのは v_num [ i ] が無限大の場合であり、それ以外の場合は false となる。

注記

GCC および Clang -ffinite-math オプション( -ffast-math によって暗黙的に含まれる)をサポートしており、これにより各コンパイラはNaN、無限大、負のゼロなどの特殊なIEEE-754浮動小数点値が存在しないと仮定することができます。言い換えれば、このオプション下では std::isinf は常に false を返すと仮定されます。

追加のオーバーロードは (A) と完全に同一である必要はありません。それらは、整数型の引数 num に対して、 std :: isinf ( num ) std :: isinf ( static_cast < double > ( num ) ) と同じ効果を持つことを保証するのに十分であればよいのです。

#include <cfloat>
#include <cmath>
#include <iostream>
#include <limits>
int main()
{
    const double max = std::numeric_limits<double>::max();
    const double inf = std::numeric_limits<double>::infinity();
    std::cout << std::boolalpha
              << "isinf(NaN) = " << std::isinf(NAN) << '\n'
              << "isinf(Inf) = " << std::isinf(INFINITY) << '\n'
              << "isinf(max) = " << std::isinf(max) << '\n'
              << "isinf(inf) = " << std::isinf(inf) << '\n'
              << "isinf(0.0) = " << std::isinf(0.0) << '\n'
              << "isinf(exp(800)) = " << std::isinf(std::exp(800)) << '\n'
              << "isinf(DBL_MIN/2.0) = " << std::isinf(DBL_MIN / 2.0) << '\n';
}

出力:

isinf(NaN) = false
isinf(Inf) = true
isinf(max) = false
isinf(inf) = true
isinf(0.0) = false
isinf(exp(800)) = true
isinf(DBL_MIN/2.0) = false

関連項目

(C++11)
指定された浮動小数点値を分類する
(関数)
(C++11)
指定された数値が有限値を持つかどうかをチェックする
(関数)
(C++11)
指定された数値がNaNかどうかをチェックする
(関数)
(C++11)
指定された数値が正規化数かどうかをチェックする
(関数)