| 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 real(conststd::complex<T>& z); | (until C++14) | |
template<class T> constexpr T real(conststd::complex<T>& z); | (since C++14) | |
Additional overloads(since C++11) | ||
Defined in header <complex> | ||
| (A) | ||
float real(float f); double real(double f); | (until C++14) | |
constexprfloat real(float f); constexprdouble real(double f); | (since C++14) (until C++23) | |
template<class FloatingPoint> constexpr FloatingPoint real( FloatingPoint f); | (since C++23) | |
| (B) | ||
template<class Integer> double real( Integer i); | (until C++14) | |
template<class Integer> constexprdouble real( 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::real(num) has the same effect asstd::real(std::complex<T>(num)).| accesses the real part of the complex number (public member function)[edit] | |
| returns the imaginary part (function template)[edit] | |
C documentation forcreal | |