std::comp_ellint_2, std::comp_ellint_2f, std::comp_ellint_2l
| double comp_ellint_2( double arg ); double comp_ellint_2( float arg ); |
(1) | |
| double comp_ellint_2( IntegralType arg ); |
(2) | |
Wie alle speziellen Funktionen ist comp_ellint_2 nur dann in <cmath> garantiert verfügbar, wenn __STDCPP_MATH_SPEC_FUNCS__ von der Implementierung auf einen Wert von mindestens 201003L definiert ist und wenn der Benutzer __STDCPP_WANT_MATH_SPEC_FUNCS__ definiert, bevor er Header der Standardbibliothek einbindet.
Inhalt |
[bearbeiten] Parameter
| arg | - | Wert eines Fließkomma- oder Ganzzahltyps |
[bearbeiten] Rückgabewert
Wenn keine Fehler auftreten, wird der Wert des vollständigen elliptischen Integrals zweiter Art von arg zurückgegeben, d.h. ellint_2(arg, π/2).
[bearbeiten] Fehlerbehandlung
Fehler können wie in math_errhandling angegeben gemeldet werden.
- Wenn das Argument NaN ist, wird NaN zurückgegeben und kein Domänenfehler gemeldet.
- Wenn |arg| > 1, kann ein Definitionsbereichsfehler auftreten.
[bearbeiten] Hinweise
Implementierungen, die TR 29124 nicht unterstützen, aber TR 19768 unterstützen, stellen diese Funktion im Header tr1/cmath und im Namensraum std::tr1 bereit.
Eine Implementierung dieser Funktion ist auch in boost.math verfügbar.
[bearbeiten] Beispiel
(funktioniert wie gezeigt mit gcc 6.0)
#define __STDCPP_WANT_MATH_SPEC_FUNCS__ 1 #include <cmath> #include <iostream> int main() { double hpi = std::acos(-1) / 2; std::cout << "E(0) = " << std::comp_ellint_2(0) << '\n' << "π/2 = " << hpi << '\n' << "E(0.5) = " << std::comp_ellint_2(0.5) << '\n' << "E(0.5, π/2) = " << std::ellint_2(0.5, hpi) << '\n'; }
Ausgabe
E(0) = 1.5708 π/2 = 1.5708 E(0.5) = 1.46746 E(0.5, π/2) = 1.46746
[bearbeiten] Externe Links
Weisstein, Eric W. "Complete Elliptic Integral of the Second Kind." From MathWorld--A Wolfram Web Resource.
[bearbeiten] Siehe auch
| (unvollständiges) elliptisches Integral zweiter Art (Funktion) |