std::comp_ellint_1, std::comp_ellint_1f, std::comp_ellint_1l
| double comp_ellint_1( double arg ); double comp_ellint_1( float arg ); |
(1) | |
| double comp_ellint_1( IntegralType arg ); |
(2) | |
Wie alle Spezialfunktionen ist comp_ellint_1 nur garantiert in <cmath> 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 irgendeine Standardbibliotheksheader-Datei einbindet.
Inhalt |
[edit] Parameter
| arg | - | Wert eines Fließkomma- oder Ganzzahltyps |
[edit] Rückgabewert
Wenn keine Fehler auftreten, wird der Wert des vollständigen elliptischen Integrals erster Art von arg zurückgegeben, das ist ellint_1(arg, π/2).
[edit] 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 Domänenfehler auftreten.
[edit] 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.
[edit] 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 << "K(0) = " << std::comp_ellint_1(0) << '\n' << "π/2 = " << hpi << '\n' << "K(0.5) = " << std::comp_ellint_1(0.5) << '\n' << "F(0.5, π/2) = " << std::ellint_1(0.5, hpi) << '\n'; }
Ausgabe
K(0) = 1.5708 π/2 = 1.5708 K(0.5) = 1.68575 F(0.5, π/2) = 1.68575
[edit] Externe Links
Weisstein, Eric W. "Complete Elliptic Integral of the First Kind." Aus MathWorld--A Wolfram Web Resource.
[edit] Siehe auch
| (unvollständiges) elliptisches Integral erster Art (Funktion) |