std::acos(std::valarray) - cppreference.com
提供: cppreference.com
<tbody> </tbody>
|
|
||
va 内のそれぞれの要素について、その要素の値の逆余弦を計算します。
引数
戻り値
va 内の値の逆余弦を格納する値配列。
ノート
計算を行うために非修飾名の関数 (acos) が使用されます。 そのような関数が利用可能でない場合は、実引数依存の名前探索により std::acos が使用されます。
関数は std::valarray と異なる戻り値の型を使用して実装することができます。 この場合、その置換型は以下の性質を持ちます。
- std::valarray のすべての
constメンバ関数が提供されます。 - 置換型から std::valarray、
std::slice_array、std::gslice_array、std::mask_arrayおよびstd::indirect_arrayが構築できます。 const std::valarray&型の引数を取るすべての関数 ( begin() と end() を除く) (C++11以上) は置換型も受理するべきです。const std::valarray&型の引数を2つ取るすべての関数はconst std::valarray&と置換型のすべての組み合わせを受理するべきです。- 戻り値の型は最も深くネストした引数型より3段以上ネストしたテンプレートを追加しません。
- std::valarray のすべての
実装例
template<class T> valarray<T> acos(const valarray<T>& va) { valarray<T> other = va; for (T &i : other) { i = acos(i); } return other; }
例
#include <cmath> #include <iostream> #include <valarray> const double pi = 4.0 * atan(1.0); int main() { // take common x-values from unit circle std::valarray<double> v1 = {-1.0, -sqrt(3.0)/2.0, -sqrt(2.0)/2.0, -0.5, 0.0, 0.5, sqrt(2.0)/2.0, sqrt(3.0)/2.0, 1.0}; std::valarray<double> v2 = std::acos(v1) * 180.0 / pi;; for(double n : v2) std::cout << std::fixed << n << ' '; std::cout << '\n'; }
出力:
180.000000 150.000000 135.000000 120.000000 90.000000 60.000000 45.000000 30.000000 0.000000
関連項目
| valarray の各要素に関数 std::asin を適用します (関数テンプレート) [edit] | |
| valarray の各要素に関数 std::atan を適用します (関数テンプレート) [edit] | |
| valarray と値に関数 std::atan2 を適用します (関数テンプレート) [edit] | |
| valarray の各要素に関数 std::cos を適用します (関数テンプレート) [edit] | |
(C++11)(C++11) |
逆余弦 (arccos(x)) を計算します (関数) [edit] |
(C++11) |
複素数の逆余弦 (arccos(z)) を計算します (関数テンプレート) [edit] |