operator+,-,*,/ (std::complex) - cppreference.com
De cppreference.com
</tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody>
| (1) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (2) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (3) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (4) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (5) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (6) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (7) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (8) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (9) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (10) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (11) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
| (12) | ||
|
|
(hasta C++20) | |
|
|
(desde C++20) | |
Implementa los operadores binarios para aritmética compleja y para aritmética escalar/compleja mixta. Los argumentos escalares se tratan como números complejos con la parte real igual al argumento y la parte imaginaria igual a cero.
1-3) Devuelve la suma de sus argumentos.
4-6) Devuelve el resultado de restar rhs de lhs.
7-9) Multiplica sus argumentos.
10-12) Divide lhs entre rhs.
Parámetros
| lhs, rhs | - | Los argumentos: ambos números complejos o un complejo y un escalar de tipo coincidente (float, double, long double).
|
Valor de retorno
1-3) std::complex<T>(lhs) += rhs
4-6) std::complex<T>(lhs) -= rhs
7-9) std::complex<T>(lhs) *= rhs
10-12) std::complex<T>(lhs) /= rhs
Notas
Debido a que la deducción de argumentos de plantilla no considera conversiones implícitas, estos operadores no se pueden usar para aritmética mixta de enteros/complejos. En todos los casos, el escalar debe tener el mismo tipo que el tipo subyacente del número complejo.
El indicador GCC -fcx-limited-range (incluido por -ffast-math) cambia el comportamiento de la multiplicación/división compleja eliminando las comprobaciones para los casos de borde de punto flotante. Esto afecta la vectorización del bucle.
Ejemplo
#include <iostream> #include <complex> int main() { std::complex<double> c2(2, 0); std::complex<double> ci(0, 1); std::cout << ci << " + " << c2 << " = " << ci+c2 << '\n' << ci << " * " << ci << " = " << ci*ci << '\n' << ci << " + " << c2 << " / " << ci << " = " << ci+c2/ci << '\n' << 1 << " / " << ci << " = " << 1./ci << '\n'; // std::cout << 1.f/ci; // error en tiempo de compilación // std::cout << 1/ci; // error en tiempo de compilación }
Salida:
(0,1) + (2,0) = (2,1) (0,1) * (0,1) = (-1,0) (0,1) + (2,0) / (0,1) = (0,-1) 1 / (0,1) = (0,-1)