Defined in header <valarray> | ||
|---|---|---|
template< class T > valarray<T> exp( const valarray<T>& va ); |
For each element in va computes e raised to the power equal to the value of the element.
| va | - | value array to apply the operation to |
Value array containing e raised by the values in va.
Unqualified function (exp) is used to perform the computation. If such function is not available, std::exp is used due to argument-dependent lookup.
The function can be implemented with the return type different from std::valarray. In this case, the replacement type has the following properties:
std::valarray are provided. std::valarray, std::slice_array, std::gslice_array, std::mask_array and std::indirect_array can be constructed from the replacement type. begin() and end() (since C++11) should also accept the replacement type. template< class T >
valarray<T> exp( const valarray<T>& va )
{
valarray<T> other = va;
for (T &i : other)
i = exp(i);
return other; // proxy object may be returned
} |
This example demonstrates the Euler's identity eiπ
= -1 and the related exponents.
#include <iostream>
#include <complex>
#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';
}
}Output:
(+1.000000,+0.000000) (+0.000000,+1.000000) (-1.000000,+0.000000) (-0.000000,-1.000000) (+1.000000,-0.000000)
applies the function std::log to each element of valarray (function template) |
|
|
(C++11)(C++11) | returns e raised to the given power (\({\small e^x}\)ex) (function) |
| complex base e exponential (function template) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/numeric/valarray/exp