operator+,-,*,/ (std::complex)

Implements the binary operators for complex arithmetic and for mixed complex/scalar arithmetic. Scalar arguments are treated as complex numbers with the real part equal to the argument and the imaginary part set to zero.

# Declarations

template< class T >
std::complex<T> operator+( const std::complex<T>& lhs,
const std::complex<T>& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator+( const std::complex<T>& lhs,
const std::complex<T>& rhs );

(since C++20)

template< class T >
std::complex<T> operator+( const std::complex<T>& lhs,
const T& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator+( const std::complex<T>& lhs,
const T& rhs );

(since C++20)

template< class T >
std::complex<T> operator+( const T& lhs,
const std::complex<T>& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator+( const T& lhs,
const std::complex<T>& rhs );

(since C++20)

template< class T >
std::complex<T> operator-( const std::complex<T>& lhs,
const std::complex<T>& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator-( const std::complex<T>& lhs,
const std::complex<T>& rhs );

(since C++20)

template< class T >
std::complex<T> operator-( const std::complex<T>& lhs,
const T& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator-( const std::complex<T>& lhs,
const T& rhs );

(since C++20)

template< class T >
std::complex<T> operator-( const T& lhs,
const std::complex<T>& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator-( const T& lhs,
const std::complex<T>& rhs );

(since C++20)

template< class T >
std::complex<T> operator*( const std::complex<T>& lhs,
const std::complex<T>& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator*( const std::complex<T>& lhs,
const std::complex<T>& rhs );

(since C++20)

template< class T >
std::complex<T> operator*( const std::complex<T>& lhs,
const T& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator*( const std::complex<T>& lhs,
const T& rhs );

(since C++20)

template< class T >
std::complex<T> operator*( const T& lhs,
const std::complex<T>& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator*( const T& lhs,
const std::complex<T>& rhs );

(since C++20)

template< class T >
std::complex<T> operator/( const std::complex<T>& lhs,
const std::complex<T>& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator/( const std::complex<T>& lhs,
const std::complex<T>& rhs );

(since C++20)

template< class T >
std::complex<T> operator/( const std::complex<T>& lhs,
const T& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator/( const std::complex<T>& lhs,
const T& rhs );

(since C++20)

template< class T >
std::complex<T> operator/( const T& lhs,
const std::complex<T>& rhs );

(until C++20)

template< class T >
constexpr std::complex<T> operator/( const T& lhs,
const std::complex<T>& rhs );

(since C++20)

# Parameters

# Notes

Because template argument deduction does not consider implicit conversions, these operators cannot be used for mixed integer/complex arithmetic. In all cases, the scalar must have the same type as the underlying type of the complex number.

The GCC flag “-fcx-limited-range” (included by “-ffast-math”) changes the behavior of complex multiply/division by removing checks for floating point edge cases. This impacts loop vectorization.

# Example

#include <complex>
#include <iostream>
 
int main()
{
    std::complex<double> c2(2.0, 0.0);
    std::complex<double> ci(0.0, 1.0);
 
    std::cout << ci << " + " << c2 << " = " << ci + c2 << '\n'
              << ci << " * " << ci << " = " << ci * ci << '\n'
              << ci << " + " << c2 << " / " << ci << " = " << ci + c2 / ci << '\n'
              << 1  << " / " << ci << " = " << 1.0 / ci << '\n';
 
//    std::cout << 1.0f / ci; // compile error
//    std::cout << 1 / ci; // compile error
}

# See also