complex<float>
Describe un objeto que almacena un par ordenado de objetos, ambos de tipo float
, donde el primero representa la parte real de un número complejo y el segundo representa la parte imaginaria.
Sintaxis
template <>
class complex<float> {
public:
constexpr complex(
float _RealVal = 0,
float _ImagVal = 0);
constexpr complex(
const complex<float>& complexNum);
constexpr complex(
const complex<double>& complexNum);
constexpr complex(
const complex<long double>& complexNum);
// rest same as class template complex
};
Parámetros
_RealVal
Valor de tipo float
de la parte real del número complejo que se está construyendo.
_ImagVal
Valor de tipo float
de la parte imaginaria del número complejo que se está construyendo.
complexNum
Número complejo de tipo double
o long double
cuyas partes real e imaginaria se usan para inicializar un número complejo de tipo float
que se está construyendo.
Valor devuelto
Número complejo de tipo float
.
Comentarios
La especialización explícita de la plantilla de clase compleja para una clase compleja de tipo float
solo se distingue de la plantilla de clase en los constructores que define. Se permite que la conversión de float
a double
sea implícita, pero la conversión de float
a long double
debe ser explicit
. El uso de explicit
descarta el inicio con conversión de tipos mediante sintaxis de asignación.
Para obtener más información sobre la plantilla de clase complex
, vea complex (Clase). Para obtener una lista de miembros de la plantilla de clase complex
, vea .
Ejemplo
// complex_comp_flt.cpp
// compile with: /EHsc
#include <complex>
#include <iostream>
int main( )
{
using namespace std;
double pi = 3.14159265359;
// The first constructor specifies real & imaginary parts
complex <float> c1 ( 4.0 , 5.0 );
cout << "Specifying initial real & imaginary parts,\n"
<< " as type float gives c1 = " << c1 << endl;
// The second constructor initializes values of the real &
// imaginary parts using those of complex number of type double
complex <double> c2double ( 1.0 , 3.0 );
complex <float> c2float ( c2double );
cout << "Implicit conversion from type double to type float,"
<< endl << "gives c2float = " << c2float << endl;
// The third constructor initializes values of the real &
// imaginary parts using those of a complex number
// of type long double
complex <long double> c3longdouble ( 3.0 , 4.0 );
complex <float> c3float ( c3longdouble );
cout << "Explicit conversion from type long double to type float,"
<< endl << "gives c3float = " << c3float << endl;
// The modulus and argument of a complex number can be recovered
double absc3 = abs ( c3float);
double argc3 = arg ( c3float);
cout << "The modulus of c3 is recovered from c3 using: abs ( c3 ) = "
<< absc3 << endl;
cout << "Argument of c3 is recovered from c3 using:"
<< endl << "arg ( c3 ) = "
<< argc3 << " radians, which is " << argc3 * 180 / pi
<< " degrees." << endl;
}
/* Output:
Specifying initial real & imaginary parts,
as type float gives c1 = (4,5)
Implicit conversion from type double to type float,
gives c2float = (1,3)
Explicit conversion from type long double to type float,
gives c3float = (3,4)
The modulus of c3 is recovered from c3 using: abs ( c3 ) = 5
Argument of c3 is recovered from c3 using:
arg ( c3 ) = 0.927295 radians, which is 53.1301 degrees.
*/
Requisitos
Encabezado: <complex>
Espacio de nombres: std
Consulte también
complex (Clase)
Seguridad para subprocesos en la biblioteca estándar de C++