std::acos(std::valarray)
From cppreference.com
| ヘッダ <valarray> で定義 |
||
| template< class T > valarray<T> acos( const valarray<T>& va ); |
||
va の各要素について、その要素の値の逆余弦(アークコサイン)を計算します。
目次 |
[編集] 引数
| va | - | 操作を適用する値の配列 |
[編集] 戻り値
va の各要素の逆余弦を含む値配列。
[編集] 注記
計算には、修飾されていない関数(acos)が使用されます。そのような関数が利用できない場合、引数依存探索により std::acos が使用されます。
この関数は、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> acos(const valarray<T>& va) { valarray<T> other = va; for (T& i : other) i = acos(i); return other; // proxy object may be returned } |
[編集] 例
このコードを実行
#include <cmath> #include <iostream> #include <numbers> #include <valarray> int main() { // take common x-values from unit circle const double s32 = std::sqrt(3.0) / 2.0; const double s22 = std::sqrt(2.0) / 2.0; std::valarray<double> v1 = {-1.0, -s32, -s22, -0.5, 0.0, 0.5, s22, s32, 1.0}; std::valarray<double> v2 = std::acos(v1) * 180.0 / std::numbers::pi; for (double n : v2) std::cout << n << "° "; std::cout << '\n'; }
出力
180° 150° 135° 120° 90° 60° 45° 30° 0°
[編集] 関連項目
| valarrayの各要素に関数std::asinを適用する (function template) | |
| valarrayの各要素に関数std::atanを適用する (function template) | |
| valarrayと値に関数std::atan2を適用する (function template) | |
| valarrayの各要素に関数std::cosを適用する (function template) | |
| (C++11)(C++11) |
逆余弦を計算する (arccos(x)) (関数) |
| (C++11) |
複素数の逆余弦 (アークコサイン) を計算する (arccos(z)) (関数テンプレート) |