Namespaces
Variants

std:: acos (std::valarray)

From cppreference.net
헤더 파일에 정의됨 <valarray>
template < class T >
valarray < T > acos ( const valarray < T > & va ) ;

va 내 각 요소에 대해 해당 요소 값의 아크 코사인을 계산합니다.

목차

매개변수

va - 연산을 적용할 값 배열

반환값

va 에 있는 값들의 아크 코사인을 포함하는 값 배열.

참고 사항

정규화되지 않은 함수 ( acos )가 계산을 수행하는 데 사용됩니다. 해당 함수를 사용할 수 없는 경우, std:: acos 인수 종속 lookup 에 의해 사용됩니다.

이 함수는 반환 타입이 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 <numbers>
#include <valarray>
int main()
{
    // 단위원에서 일반적인 x값 취하기
    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 함수를 적용합니다
(함수 템플릿)
valarray의 각 요소에 std::atan 함수를 적용합니다
(함수 템플릿)
valarray와 값에 std::atan2 함수를 적용합니다
(함수 템플릿)
valarray의 각 요소에 std::cos 함수를 적용합니다
(함수 템플릿)
(C++11) (C++11)
아크 코사인을 계산합니다 ( arccos(x) )
(함수)
복소수의 아크 코사인을 계산합니다 ( arccos(z) )
(함수 템플릿)