Namensräume
Varianten
Aktionen

std::arg(std::complex)

Von cppreference.com
< cpp‎ | numeric‎ | complex
 
 
 
 
Definiert in der Header-Datei <complex>
template< class T >
T           arg( const std::complex<T>& z );
(1)
Definiert in der Header-Datei <complex>
(A)
float       arg( float f );

double      arg( double f );

long double arg( long double f );
(bis C++23)
template< class FloatingPoint >

Gleitkommazahl

            arg( Gleitkommazahl f );
(seit C++23)
template< class Integer >
double      arg( Ganzzahl i );
(B)
1) Berechnet den Phasenwinkel (in Radiant) der komplexen Zahl z.
A,B) Zusätzliche Überladungen sind für alle ganzzahligen und Gleitkommatypen vorhanden, die als komplexe Zahlen mit Null-Imaginärteil behandelt werden.
(seit C++11)

Inhalt

[edit] Parameter

z - komplexer Wert
f - Gleitkommawert
i - ganzzahliger Wert

[edit] Rückgabewert

1) std::atan2(std::imag(z), std::real(z)). Wenn keine Fehler auftreten, ist dies der Phasenwinkel von z im Intervall [−π; π].
A) Null, wenn f positiv oder +0 ist, π, wenn f negativ oder -0 ist, andernfalls NaN.
B) Null, wenn i nicht negativ ist, π, wenn es negativ ist.

[edit] Anmerkungen

Die zusätzlichen Überladungen müssen nicht exakt wie in (A,B) angegeben bereitgestellt werden. Sie müssen nur ausreichen, um sicherzustellen, dass für ihr Argument num

  • Wenn num vom Typ Standard(bis C++23) Gleitkommazahl T ist, dann hat std::arg(num) denselben Effekt wie std::arg(std::complex<T>(num)).
  • Andernfalls, wenn num einen Ganzzahltyp hat, dann hat std::arg(num) denselben Effekt wie std::arg(std::complex<double>(num)).

[edit] Beispiel

#include <complex>
#include <iostream>
 
int main() 
{
    std::complex<double> z1(1, 0);
    std::complex<double> z2(0, 0);
    std::complex<double> z3(0, 1);
    std::complex<double> z4(-1, 0);
    std::complex<double> z5(-1, -0.0);
    double f = 1.;
    int i = -1;
 
    std::cout << "phase angle of " << z1 << " is " << std::arg(z1) << '\n'
              << "phase angle of " << z2 << " is " << std::arg(z2) << '\n'
              << "phase angle of " << z3 << " is " << std::arg(z3) << '\n'
              << "phase angle of " << z4 << " is " << std::arg(z4) << '\n'
              << "phase angle of " << z5 << " is " << std::arg(z5) << " "
                 "(the other side of the cut)\n"
              << "phase angle of " << f << " is " << std::arg(f) << '\n'
              << "phase angle of " << i << " is " << std::arg(i) << '\n';
 
}

Ausgabe

phase angle of (1,0) is 0
phase angle of (0,0) is 0
phase angle of (0,1) is 1.5708
phase angle of (-1,0) is 3.14159
phase angle of (-1,-0) is -3.14159 (the other side of the cut)
phase angle of 1 is 0
phase angle of -1 is 3.14159

[edit] Siehe auch

gibt den Betrag einer komplexen Zahl zurück
(function template) [edit]
konstruiert eine komplexe Zahl aus Betrag und Phasenwinkel
(function template) [edit]
(C++11)(C++11)
Arkustangens, verwendet Vorzeichen zur Bestimmung der Quadranten
(Funktion) [bearbeiten]
wendet die Funktion std::atan2 auf ein Valarray und einen Wert an
(function template) [edit]
C-Dokumentation für carg