Namespaces
Variants

std:: asin (std::valarray)

From cppreference.net
ヘッダーで定義 <valarray>
template < class T >
valarray < T > asin ( const valarray < T > & va ) ;

va 内の各要素について、要素の値の逆正弦を計算します。

目次

翻訳の説明: - 「Contents」を「目次」に翻訳しました - C++関連の専門用語(Parameters、Return value、Notes、Possible implementation、Example、See also)は原文のまま保持しました - HTMLタグ、属性、クラス名、ID、リンク先は一切変更していません - 数値や書式設定は完全に保持されています

パラメータ

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

戻り値

va 内の値のアークサインを含む値配列。

注記

修飾されていない関数 ( asin ) が計算の実行に使用されます。そのような関数が利用できない場合、 std:: asin argument-dependent lookup により使用されます。

この関数は、戻り値の型が std::valarray と異なる型で実装される場合があります。この場合、置換型は以下の特性を持ちます:

実装例

template<class T>
valarray<T> asin(const valarray<T>& va)
{
    valarray<T> other = va;
    for (T& i : other)
        i = asin(i);
    return other; // プロキシオブジェクトが返される可能性があります
}

#include <cmath>
#include <iostream>
#include <numbers>
#include <valarray>
int main()
{
    // 単位円から一般的なy値を取得
    const double s22 = std::sqrt(2.0) / 2.0;
    const double s32 = std::sqrt(3.0) / 2.0;
    const std::valarray<double> v1 =
        {-1.0, -s32, -s22, -0.5,  0.0,  0.5, s22,  s32,  1.0};
    // ラジアンから度への変換結果を格納
    const std::valarray<double> v2 = 
        std::asin(v1) * 180.0 / std::numbers::pi;
    for (std::cout << std::showpos; double n : v2)
        std::cout << n << "° ";
    std::cout << '\n';
}

出力:

-90° -60° -45° -30° +0° +30° +45° +60° +90°

関連項目

valarrayの各要素に関数 std::acos を適用する
(関数テンプレート)
valarrayの各要素に関数 std::atan を適用する
(関数テンプレート)
valarrayと値に関数 std::atan2 を適用する
(関数テンプレート)
valarrayの各要素に関数 std::sin を適用する
(関数テンプレート)
(C++11) (C++11)
アークサインを計算する ( arcsin(x) )
(関数)
複素数のアークサインを計算する ( arcsin(z) )
(関数テンプレート)