名前空間
変種

std::acos(std::valarray)

提供: cppreference.com
 
 
 
 
<tbody> </tbody>
ヘッダ <valarray> で定義
template< class T > valarray<T> acos( const valarray<T>& va );

va 内のそれぞれの要素について、その要素の値の逆余弦を計算します。

引数

va - 操作を適用する値配列

戻り値

va 内の値の逆余弦を格納する値配列。

ノート

計算を行うために非修飾名の関数 (acos) が使用されます。 そのような関数が利用可能でない場合は、実引数依存の名前探索により std::acos が使用されます。

関数は std::valarray と異なる戻り値の型を使用して実装することができます。 この場合、その置換型は以下の性質を持ちます。

  • std::valarray のすべての const メンバ関数が提供されます。
  • 置換型から std::valarraystd::slice_arraystd::gslice_arraystd::mask_array および std::indirect_array が構築できます。
  • const std::valarray& 型の引数を取るすべての関数 ( begin()end() を除く) (C++11以上) は置換型も受理するべきです。
  • const std::valarray& 型の引数を2つ取るすべての関数は const std::valarray& と置換型のすべての組み合わせを受理するべきです。
  • 戻り値の型は最も深くネストした引数型より3段以上ネストしたテンプレートを追加しません。

実装例

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]
複素数の逆余弦 (arccos(z)) を計算します
(関数テンプレート) [edit]