Partilhar via


complex<float>

Descreve um objeto que armazena um par ordenado de objetos do tipo float*,* o primeiro que representa a parte real de um número complexo e a segunda que representa a parte imaginária.

template<>
   class complex<float> {
public:
   complex(
      float _RealVal = 0, 
      float _ImagVal = 0
   );

   complex(
      const complex<float>& _ComplexNum
   );
   complex(
      const complex<double>& _ComplexNum
   );
   complex(
      const complex<long double>& _ComplexNum
   );
   // rest same as template class complex
};

Parâmetros

  • _RealVal
    O valor do tipo float para a parte real do número complexo que está sendo construída.

  • _ImagVal
    O valor do tipo float para a parte imaginária do número complexo que está sendo construída.

  • _ComplexNum
    O número complexo do tipo double ou do tipo long double cujas partes real e imaginária são usados para inicializar um número complexo do tipo float sendo construído.

Valor de retorno

Um número complexo do tipo float.

Comentários

A especialização explícita da classe modelo complexa para uma classe complexa do tipo float difere somente em construtores ele define a classe de modelo.A conversão de float para double pode ser implícito, mas a conversão menos segura de float para long double é necessário para ser explícita.O uso de explícita rege o início com a conversão de tipo usando a sintaxe de atribuição.

Para obter mais informações sobre a classe de modelo complex, consulte complex Class.Para obter uma lista de membros de classe de modelo complex, consulte Membros complexos.

Exemplo

// 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,"
        << "\n 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,"
        << "\n 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:\n arg ( c3 ) = "
        << argc3 << " radians, which is " << argc3 * 180 / pi
        << " degrees." << endl;
}
  

Requisitos

Cabeçalho: <complex>

Namespace: std

Consulte também

Referência

complex Class

Segurança do thread na biblioteca C++ padrão

Outros recursos

<complex> Membros

Membros complexos