名前空間
変種
操作

標準ライブラリヘッダー <complex>

From cppreference.com
 
 
標準ライブラリヘッダー
アルゴリズム
<algorithm>
<numeric>
文字列
<cctype>
<cstring>
<cuchar> (C++11)
<cwchar>
<cwctype>
<string_view> (C++17)
<string>
テキスト処理
<clocale>
<codecvt> (C++11/17/26*)
<locale>
<regex> (C++11)
<text_encoding> (C++26)   
数値
<cfenv> (C++11)
<cmath>
<complex>
<linalg> (C++26)
<numbers> (C++20)
<random> (C++11)
<simd> (C++26)
<valarray>
時間
<chrono> (C++11)
<ctime>
C互換
<ccomplex> (C++11/17/20*)
<ciso646> (C++20 まで)
<cstdalign> (C++11/17/20*)
<cstdbool> (C++11/17/20*)
<ctgmath> (C++11/17/20*)
 

このヘッダーは数値ライブラリの一部です。

目次

[編集] クラス

複素数型
(クラステンプレート)

[編集] 関数

操作
複素数に単項演算子を適用する
(関数テンプレート) [編集]
2つの複素数値、または複素数とスカラ値の複素数演算を実行する
(関数テンプレート) [編集]
(C++20で削除)
2つの複素数、または複素数とスカラ値を比較する
(関数テンプレート) [編集]
複素数をシリアライズ・デシリアライズする
(関数テンプレート) [編集]
実部を返す
(関数テンプレート) [編集]
虚部を返す
(関数テンプレート) [編集]
複素数の大きさを返す
(関数テンプレート) [編集]
偏角を返す
(関数テンプレート) [編集]
大きさの2乗を返す
(関数テンプレート) [編集]
複素共役を返す
(関数テンプレート) [編集]
(C++11)
リーマン球面への射影を返す
(関数テンプレート) [編集]
大きさと偏角から複素数を構築する
(関数テンプレート) [編集]
指数関数
複素数の底eの指数関数
(関数テンプレート) [編集]
複素数の自然対数、分枝切断は負の実軸に沿う
(関数テンプレート) [編集]
複素数の常用対数、分枝切断は負の実軸に沿う
(関数テンプレート) [編集]
べき乗関数
複素数のべき乗、引数の一方または両方が複素数
(関数テンプレート) [編集]
複素数の平方根、右半平面の範囲
(関数テンプレート) [編集]
三角関数
複素数の正弦 (サイン) を計算する (sin(z))
(関数テンプレート) [編集]
複素数の余弦 (コサイン) を計算する (cos(z))
(関数テンプレート) [編集]
複素数の正接 (タンジェント) を計算する (tan(z))
(関数テンプレート) [編集]
複素数の逆正弦 (アークサイン) を計算する (arcsin(z))
(関数テンプレート) [編集]
複素数の逆余弦 (アークコサイン) を計算する (arccos(z))
(関数テンプレート) [編集]
複素数の逆正接 (アークタンジェント) を計算する (arctan(z))
(関数テンプレート) [編集]
双曲線関数
複素数の双曲線正弦 (ハイパボリックサイン) を計算する (sinh(z))
(関数テンプレート) [編集]
複素数の双曲線余弦 (ハイパボリックコサイン) を計算する (cosh(z))
(関数テンプレート) [編集]
複素数の双曲線正接 (ハイパボリックタンジェント) を計算する (tanh(z))
(関数テンプレート) [編集]
複素数の逆双曲線正弦 (エリアハイパボリックサイン) を計算する (arsinh(z))
(関数テンプレート) [編集]
複素数の逆双曲線余弦 (エリアハイパボリックコサイン) を計算する (arcosh(z))
(関数テンプレート) [編集]
複素数の逆双曲線正接 (エリアハイパボリックタンジェント) を計算する (artanh(z))
(関数テンプレート) [編集]
リテラル
純虚数を表す std::complex リテラル
(関数) [編集]

[編集] 概要

namespace std {
    template<class T> class complex;
 
    template<> class complex<float>;
    template<> class complex<double>;
    template<> class complex<long double>;
 
    // operators:
    template<class T> constexpr complex<T> operator+(
        const complex<T>&, const complex<T>&);
    template<class T> constexpr complex<T> operator+(const complex<T>&, const T&);
    template<class T> constexpr complex<T> operator+(const T&, const complex<T>&);
 
    template<class T> constexpr complex<T> operator-(
        const complex<T>&, const complex<T>&);
    template<class T> constexpr complex<T> operator-(const complex<T>&, const T&);
    template<class T> constexpr complex<T> operator-(const T&, const complex<T>&);
 
    template<class T> constexpr complex<T> operator*(
        const complex<T>&, const complex<T>&);
    template<class T> constexpr complex<T> operator*(const complex<T>&, const T&);
    template<class T> constexpr complex<T> operator*(const T&, const complex<T>&);
 
    template<class T> constexpr complex<T> operator/(
        const complex<T>&, const complex<T>&);
    template<class T> constexpr complex<T> operator/(const complex<T>&, const T&);
    template<class T> constexpr complex<T> operator/(const T&, const complex<T>&);
 
    template<class T> constexpr complex<T> operator+(const complex<T>&);
    template<class T> constexpr complex<T> operator-(const complex<T>&);
 
    template<class T> constexpr bool operator==(const complex<T>&, const complex<T>&);
    template<class T> constexpr bool operator==(const complex<T>&, const T&);
    template<class T> constexpr bool operator==(const T&, const complex<T>&);
 
    template<class T> constexpr bool operator!=(const complex<T>&, const complex<T>&);
    template<class T> constexpr bool operator!=(const complex<T>&, const T&);
    template<class T> constexpr bool operator!=(const T&, const complex<T>&);
 
    template<class T, class CharT, class Traits>
    basic_istream<CharT, Traits>&
    operator>>(basic_istream<CharT, Traits>&, complex<T>&);
 
    template<class T, class CharT, class Traits>
    basic_ostream<CharT, Traits>&
    operator<<(basic_ostream<CharT, Traits>&, const complex<T>&);
 
    // values:
    template<class T> constexpr T real(const complex<T>&);
    template<class T> constexpr T imag(const complex<T>&);
 
    template<class T> T abs(const complex<T>&);
    template<class T> T arg(const complex<T>&);
    template<class T> constexpr T norm(const complex<T>&);
 
    template<class T> constexpr complex<T> conj(const complex<T>&);
    template<class T> complex<T> proj(const complex<T>&);
    template<class T> complex<T> polar(const T&, const T& = 0);
 
    // transcendentals:
    template<class T> complex<T> acos(const complex<T>&);
    template<class T> complex<T> asin(const complex<T>&);
    template<class T> complex<T> atan(const complex<T>&);
 
    template<class T> complex<T> acosh(const complex<T>&);
    template<class T> complex<T> asinh(const complex<T>&);
    template<class T> complex<T> atanh(const complex<T>&);
 
    template<class T> complex<T> cos  (const complex<T>&);
    template<class T> complex<T> cosh (const complex<T>&);
    template<class T> complex<T> exp  (const complex<T>&);
    template<class T> complex<T> log  (const complex<T>&);
    template<class T> complex<T> log10(const complex<T>&);
 
    template<class T> complex<T> pow(const complex<T>&, const T&);
    template<class T> complex<T> pow(const complex<T>&, const complex<T>&);
    template<class T> complex<T> pow(const T&, const complex<T>&);
 
    template<class T> complex<T> sin (const complex<T>&);
    template<class T> complex<T> sinh(const complex<T>&);
    template<class T> complex<T> sqrt(const complex<T>&);
    template<class T> complex<T> tan (const complex<T>&);
    template<class T> complex<T> tanh(const complex<T>&);
 
    // tuple interface:
    template<class T> struct tuple_size;
    template<size_t I, class T> struct tuple_element;
    template<class T> struct tuple_size<complex<T>>;
    template<size_t I, class T> struct tuple_element<I, complex<T>>;
    template<size_t I, class T>
      constexpr T& get(complex<T>&) noexcept;
    template<size_t I, class T>
      constexpr T&& get(complex<T>&&) noexcept;
    template<size_t I, class T>
      constexpr const T& get(const complex<T>&) noexcept;
    template<size_t I, class T>
      constexpr const T&& get(const complex<T>&&) noexcept;
 
    // complex literals:
    inline namespace literals {
        inline namespace complex_literals {
            constexpr complex<long double> operator""il(long double);
            constexpr complex<long double> operator""il(unsigned long long);
            constexpr complex<double> operator""i(long double);
            constexpr complex<double> operator""i(unsigned long long);
            constexpr complex<float> operator""if(long double);
            constexpr complex<float> operator""if(unsigned long long);
        }
    }
}

[編集] クラス std::complex

template<class T>
class complex {
public:
    typedef T value_type;
    constexpr complex(const T& re = T(), const T& im = T());
    constexpr complex(const complex&) = default;
    template<class X> constexpr explicit(/* see constructor page */)
        complex(const complex<X>&);
 
    constexpr T real() const;
    constexpr void real(T);
    constexpr T imag() const;
    constexpr void imag(T);
 
    constexpr complex<T>& operator= (const T&);
    constexpr complex<T>& operator+=(const T&);
    constexpr complex<T>& operator-=(const T&);
    constexpr complex<T>& operator*=(const T&);
    constexpr complex<T>& operator/=(const T&);
 
    constexpr complex& operator=(const complex&);
    template<class X> constexpr complex<T>& operator= (const complex<X>&);
    template<class X> constexpr complex<T>& operator+=(const complex<X>&);
    template<class X> constexpr complex<T>& operator-=(const complex<X>&);
    template<class X> constexpr complex<T>& operator*=(const complex<X>&);
    template<class X> constexpr complex<T>& operator/=(const complex<X>&);
};

[編集] 欠陥報告

以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。

DR 適用対象 公開された動作 正しい動作
LWG 79 C++98 第2パラメータのデフォルト引数
polarの概要に不足していた
追加された
English 日本語 中文(简体) 中文(繁體)