| Common mathematical functions | |||||||||||||||||||||||||||||||
| Mathematical special functions(C++17) | |||||||||||||||||||||||||||||||
| Mathematical constants(C++20) | |||||||||||||||||||||||||||||||
| Basic linear algebra algorithms(C++26) | |||||||||||||||||||||||||||||||
| Data-parallel types (SIMD)(C++26) | |||||||||||||||||||||||||||||||
| Floating-point environment(C++11) | |||||||||||||||||||||||||||||||
| Complex numbers | |||||||||||||||||||||||||||||||
Numeric array (valarray) | |||||||||||||||||||||||||||||||
| Pseudo-random number generation | |||||||||||||||||||||||||||||||
| Bit manipulation(C++20) | |||||||||||||||||||||||||||||||
| Saturation arithmetic(C++26) | |||||||||||||||||||||||||||||||
| Factor operations | |||||||||||||||||||||||||||||||
|
| ||||||||||||||||||||||||||||||
| Interpolations | |||||||||||||||||||||||||||||||
|
| ||||||||||||||||||||||||||||||
| Generic numeric operations | |||||||||||||||||||||||||||||||
| |||||||||||||||||||||||||||||||
| C-style checked integer arithmetic | |||||||||||||||||||||||||||||||
| |||||||||||||||||||||||||||||||
Defined in header <complex> | ||
| (1) | ||
template<class T> T imag(conststd::complex<T>& z); | (until C++14) | |
template<class T> constexpr T imag(conststd::complex<T>& z); | (since C++14) | |
Additional overloads(since C++11) | ||
Defined in header <complex> | ||
| (A) | ||
float imag(float f); double imag(double f); | (until C++14) | |
constexprfloat imag(float f); constexprdouble imag(double f); | (since C++14) (until C++23) | |
template<class FloatingPoint> FloatingPoint imag( FloatingPoint f); | (since C++23) | |
| (B) | ||
template<class Integer> double imag( Integer i); | (until C++14) | |
template<class Integer> constexprdouble imag( Integer i); | (since C++14) | |
A,B) Additional overloads are provided for all integer and floating-point types, which are treated as complex numbers with zero imaginary part. | (since C++11) |
Contents |
| z | - | complex value |
| f | - | floating-point value |
| i | - | integer value |
The additional overloads are not required to be provided exactly as(A,B). They only need to be sufficient to ensure that for their argumentnum:
T, thenstd::imag(num) has the same effect asstd::imag(std::complex<T>(num)).| accesses the imaginary part of the complex number (public member function)[edit] | |
| returns the real part (function template)[edit] | |
C documentation forcimag | |