std:: exp (std::valarray)
|
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:
-
- Alle const Memberfunktionen von std::valarray werden bereitgestellt.
- std::valarray , std::slice_array , std::gslice_array , std::mask_array und std::indirect_array können aus dem Ersatztyp konstruiert werden.
- Für jede Funktion, die ein const std:: valarray < T > & außer begin() und end() (seit C++11) akzeptiert, müssen identische Funktionen hinzugefügt werden, die die Ersatztypen akzeptieren;
- Für jede Funktion, die zwei const std:: valarray < T > & Argumente akzeptiert, müssen identische Funktionen hinzugefügt werden, die jede Kombination von const std:: valarray < T > & und Ersatztypen akzeptieren.
- Der Rückgabetyp fügt nicht mehr als zwei Ebenen von Template-Verschachtelung über dem am tiefsten verschachtelten Argumenttyp hinzu.
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
iπ
= -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) |