Namespaces
Variants

std:: exp (std::valarray)

From cppreference.net
Definiert in Header <valarray>
template < class T >
valarray < T > exp ( const valarray < T > & va ) ;

Für jedes Element in va berechnet e hoch dem Wert des Elements.

Inhaltsverzeichnis

Parameter

va - Wert-Array, auf das die Operation angewendet werden soll

Rückgabewert

Wertearray, das e hoch die Werte in va enthält.

Hinweise

Die unqualifizierte Funktion ( exp ) wird zur Berechnung verwendet. Falls keine solche Funktion verfügbar ist, std:: exp wird aufgrund von Argument-Dependent Lookup verwendet.

Die Funktion kann mit einem Rückgabetyp implementiert werden, der sich von std::valarray unterscheidet. In diesem Fall hat der Ersatztyp die folgenden Eigenschaften:

Mögliche Implementierung

template<class T>
valarray<T> exp(const valarray<T>& va)
{
    valarray<T> other = va;
    for (T& i : other)
        i = exp(i);
    return other; // Proxy-Objekt kann zurückgegeben werden
}

Beispiel

Dieses Beispiel demonstriert die Euler-Identität e
= -1
und die zugehörigen Exponenten.

#include <complex>
#include <iostream>
#include <numbers>
#include <valarray>
int main()
{
    const double pi = std::numbers::pi;
    std::valarray<std::complex<double>> v =
    {
        {0, 0}, {0, pi / 2}, {0, pi}, {0, 3 * pi / 2}, {0, 2 * pi}
    };
    std::valarray<std::complex<double>> v2 = std::exp(v);
    for (std::cout << std::showpos << std::fixed; auto n : v2)
        std::cout << n << '\n';
}

Ausgabe:

(+1.000000,+0.000000)
(+0.000000,+1.000000)
(-1.000000,+0.000000)
(-0.000000,-1.000000)
(+1.000000,-0.000000)

Siehe auch

wendet die Funktion std::log auf jedes Element des valarray an
(Funktions-Template)
(C++11) (C++11)
liefert e hoch dem gegebenen Exponenten ( e x )
(Funktion)
komplexe Basis- e Exponentialfunktion
(Funktions-Template)