Namensräume
Varianten
Aktionen

std::asin(std::complex)

Von cppreference.com
< cpp‎ | numeric‎ | complex
 
 
 
 
Definiert in der Header-Datei <complex>
template< class T >
std::complex<T> asin( const std::complex<T>& z );
(seit C++11)

Berechnet den komplexen Arkussinus eines komplexen Werts z. Der Astschnitt liegt außerhalb des Intervalls [−1, +1] entlang der reellen Achse.

Inhalt

[bearbeiten] Parameter

z - komplexer Wert

[bearbeiten] Rückgabewert

Wenn keine Fehler auftreten, wird der komplexe Arkussinus von z zurückgegeben, im Bereich eines Streifens, der entlang der imaginären Achse unbeschränkt ist, und im Intervall [−π/2, +π/2] entlang der reellen Achse.

Fehler und Sonderfälle werden behandelt, als ob die Operation implementiert wäre durch -i * std::asinh(i * z), wobei i die imaginäre Einheit ist.

[bearbeiten] Hinweise

Der inverse Sinus (oder Arkussinus) ist eine mehrdeutige Funktion und erfordert einen Astschnitt auf der komplexen Ebene. Der Astschnitt wird konventionell an den Liniensegmenten (-∞,-1) und (1,∞) der reellen Achse platziert.

Die mathematische Definition des Hauptwerts des Arkussinus ist arcsin z = -iln(iz + 1-z2
)
.

Für jedes z gilt asin(z) = acos(-z) -
π
2
.

[bearbeiten] Beispiel

#include <cmath>
#include <complex>
#include <iostream>
 
int main()
{
    std::cout << std::fixed;
    std::complex<double> z1(-2.0, 0.0);
    std::cout << "asin" << z1 << " = " << std::asin(z1) << '\n';
 
    std::complex<double> z2(-2.0, -0.0);
    std::cout << "asin" << z2 << " (the other side of the cut) = "
              << std::asin(z2) << '\n';
 
    // for any z, asin(z) = acos(−z) − pi / 2
    const double pi = std::acos(-1);
    std::complex<double> z3 = std::acos(z2) - pi / 2;
    std::cout << "sin(acos" << z2 << " - pi / 2) = " << std::sin(z3) << '\n';
}

Ausgabe

asin(-2.000000,0.000000) = (-1.570796,1.316958)
asin(-2.000000,-0.000000) (the other side of the cut) = (-1.570796,-1.316958)
sin(acos(-2.000000,-0.000000) - pi / 2) = (2.000000,0.000000)

[bearbeiten] Siehe auch

berechnet den Arkuskosinus einer komplexen Zahl (arccos(z))
(function template) [edit]
berechnet den Arkustangens einer komplexen Zahl (arctan(z))
(function template) [edit]
berechnet den Sinus einer komplexen Zahl (sin(z))
(function template) [edit]
(C++11)(C++11)
berechnet Arkussinus (arcsin(x))
(Funktion) [bearbeiten]
wendet die Funktion std::asin auf jedes Element des Valarrays an
(function template) [edit]
C-Dokumentation für casin