std::exp(std::valarray)
提供: cppreference.com
ヘッダ <valarray> で定義 | ||
template<class T > valarray<T> exp(const valarray<T>& va ); | ||
va
内のそれぞれの要素について、その要素の値に等しい指数を e に乗じた値を計算します。
目次 |
[編集]引数
va | - | 操作を適用する値配列 |
[編集]戻り値
e に va
内の値を乗じた値を格納する値配列。
[編集]ノート
計算を行うために非修飾名の関数 (exp) が使用されます。 そのような関数が利用可能でない場合は、実引数依存の名前探索により std::exp が使用されます。
関数は std::valarray と異なる戻り値の型を使用して実装することができます。 この場合、その置換型は以下の性質を持ちます。
- std::valarray のすべての const メンバ関数が提供されます。
- 置換型から std::valarray、 std::slice_array、 std::gslice_array、 std::mask_array および std::indirect_array が構築できます。
- conststd::valarray& 型の引数を取るすべての関数 ( begin() と end() を除く)(C++11以上) は置換型も受理するべきです。
- conststd::valarray& 型の引数を2つ取るすべての関数は conststd::valarray& と置換型のすべての組み合わせを受理するべきです。
- 戻り値の型は最も深くネストした引数型より3段以上ネストしたテンプレートを追加しません。
[編集]実装例
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} |
[編集]例
この例はオイラーの等式 eiπ
= -1 および関連する指数をデモンストレーションします。
Run this code
#include <iostream>#include <complex>#include <valarray> int main(){constdouble pi =std::acos(-1);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(auto n : v2){std::cout<<std::showpos<<std::fixed<< n <<'\n';}}
出力:
(+1.000000,+0.000000) (+0.000000,+1.000000) (-1.000000,+0.000000) (-0.000000,-1.000000) (+1.000000,-0.000000)
[編集]関連項目
valarray の各要素に関数 std::log を適用します (関数テンプレート) | |
(C++11)(C++11) | e の x 乗 (ex) を計算します (関数) |
e を底とする複素指数関数 (関数テンプレート) |