std::atan(std::valarray)
From cppreference.com
| ヘッダ <valarray> で定義 |
||
| template< class T > valarray<T> atan( const valarray<T>& va ); |
||
va の各要素について、その値の逆正接 (アークタンジェント) を計算します。
目次 |
[編集] パラメータ
| va | - | 操作を適用する値の配列 |
[編集] 戻り値
va の値の逆正接を含む値配列。
[編集] ノート
計算を実行するために、修飾されていない関数 (atan) が使用されます。そのような関数が利用できない場合、引数依存の名前探索により、std::atan が使用されます。
この関数は、std::valarray とは異なる戻り値型で実装される場合があります。その場合、代替型は以下のプロパティを持ちます。
- std::valarray のすべての const メンバ関数が提供されます。
- std::valarray、std::slice_array、std::gslice_array、std::mask_array、および std::indirect_array は、代替型から構築できます。
- 2つの const std::valarray<T>& 引数を受け取るすべての関数について、代替型を受け取る同一の関数が追加されます(begin() および end() を除く)。
- 2つの const std::valarray<T>& 引数を受け取るすべての関数について、const std::valarray<T>& と代替型のすべての組み合わせを受け取る同一の関数が追加されます。
- 戻り値型は、最も深くネストされた引数型に対して、2レベル以上のテンプレートネストを追加しません。
[編集] 実装例
template<class T> valarray<T> atan(const valarray<T>& va) { valarray<T> other = va; for (T& i : other) i = atan(i); return other; // proxy object may be returned } |
[編集] 例
このコードを実行
#include <algorithm> #include <cmath> #include <iostream> #include <valarray> auto show = [](char const* title, const std::valarray<float>& va) { std::cout << title << " :"; std::for_each(std::begin(va), std::end(va), [](const float x) { std::cout << " " << std::fixed << x; }); std::cout << '\n'; }; int main() { const std::valarray<float> x = {.1f, .3f, .6f, .9f}; const std::valarray<float> f = std::atan(x); const std::valarray<float> g = std::tan(f); show("x ", x); show("f = atan(x)", f); show("g = tan(f) ", g); }
出力
x : 0.100000 0.300000 0.600000 0.900000 f = atan(x) : 0.099669 0.291457 0.540420 0.732815 g = tan(f) : 0.100000 0.300000 0.600000 0.900000
[編集] 関連項目
| valarrayの各要素に関数std::asinを適用する (function template) | |
| valarrayの各要素に関数std::acosを適用する (function template) | |
| valarrayと値に関数std::atan2を適用する (function template) | |
| valarrayの各要素に関数std::tanを適用する (function template) | |
| (C++11)(C++11) |
逆正接を計算する (arctan(x)) (関数) |
| (C++11) |
複素数の逆正接 (アークタンジェント) を計算する (arctan(z)) (関数テンプレート) |