Namespaces
Variants

std:: polar (std::complex)

From cppreference.net
Definiert im Header <complex>
template < class T >
std:: complex < T > polar ( const T & r, const T & theta = T ( ) ) ;

Gibt eine komplexe Zahl mit dem Betrag r und dem Phasenwinkel theta zurück.

Das Verhalten ist undefiniert, wenn r negativ oder NaN ist, oder wenn theta unendlich ist.

Inhaltsverzeichnis

Parameter

r - Betrag
theta - Phasenwinkel

Rückgabewert

Eine komplexe Zahl, bestimmt durch r und theta .

Hinweise

std :: polar ( r, theta ) entspricht einem der folgenden Ausdrücke:

  • r * std:: exp ( theta * 1i )
  • r * ( cos ( theta ) + sin ( theta ) * 1i )
  • std:: complex ( r * cos ( theta ) , r * sin ( theta ) ) .
*Hinweis: Da der gesamte Text innerhalb von ` ` Tags liegt (was Code darstellt) und gemäß den Anweisungen nicht übersetzt werden darf, bleibt der gesamte Inhalt unverändert. Die einzigen übersetzbaren Elemente wären Text außerhalb dieser Code-Blöcke, der in diesem Beispiel nicht vorhanden ist.*

Die Verwendung von polar anstelle von exp kann in vektorisierten Schleifen etwa 4,5-mal schneller sein.

Beispiel

#include <cmath>
#include <complex>
#include <iomanip>
#include <iostream>
#include <numbers>
using namespace std::complex_literals;
int main()
{
    constexpr auto π_2{std::numbers::pi / 2.0};
    constexpr auto mag{1.0};
    std::cout 
        << std::fixed << std::showpos << std::setprecision(1)
        << "   θ: │ polar:      │ exp:        │ complex:    │ trig:\n";
    for (int n{}; n != 4; ++n)
    {
        const auto θ{n * π_2};
        std::cout << std::setw(4) << 90 * n << "° │ "
                  << std::polar(mag, θ) << " │ "
                  << mag * std::exp(θ * 1.0i) << " │ "
                  << std::complex(mag * cos(θ), mag * sin(θ)) << " │ "
                  << mag * (cos(θ) + 1.0i * sin(θ)) << '\n';
    }
}

Ausgabe:

   θ: │ polar:      │ exp:        │ complex:    │ trig:
  +0° │ (+1.0,+0.0) │ (+1.0,+0.0) │ (+1.0,+0.0) │ (+1.0,+0.0)
 +90° │ (+0.0,+1.0) │ (+0.0,+1.0) │ (+0.0,+1.0) │ (+0.0,+1.0)
+180° │ (-1.0,+0.0) │ (-1.0,+0.0) │ (-1.0,+0.0) │ (-1.0,+0.0)
+270° │ (-0.0,-1.0) │ (-0.0,-1.0) │ (-0.0,-1.0) │ (-0.0,-1.0)

Fehlerberichte

Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR Angewendet auf Verhalten wie veröffentlicht Korrektes Verhalten
LWG 2459 C++98 Verhalten für einige Eingaben unklar als undefiniert festgelegt
LWG 2870 C++98 Standardwert des Parameters theta nicht abhängig als abhängig festgelegt

Siehe auch

gibt den Betrag einer komplexen Zahl zurück
(Funktions-Template)
gibt den Phasenwinkel zurück
(Funktions-Template)
komplexe Basis- e -Exponentialfunktion
(Funktions-Template)