std:: atan (std::valarray)
From cppreference.net
|
헤더에 정의됨
<valarray>
|
||
|
template
<
class
T
>
valarray < T > atan ( const valarray < T > & va ) ; |
||
va 내 각 요소에 대해 해당 요소 값의 아크 탄젠트를 계산합니다.
목차 |
매개변수
| va | - | 작업을 적용할 값 배열 |
반환값
va 내 값들의 아크 탄젠트를 포함하는 값 배열.
참고 사항
정규화되지 않은 함수 ( atan )가 계산 수행에 사용됩니다. 해당 함수를 사용할 수 없는 경우, std:: atan 가 인수 종속 lookup 에 의해 사용됩니다.
이 함수는 반환 타입이 std::valarray 와 다르게 구현될 수 있습니다. 이 경우, 대체 타입은 다음과 같은 속성을 가집니다:
-
- const 멤버 함수 전부가 std::valarray 에 제공됩니다.
- std::valarray , std::slice_array , std::gslice_array , std::mask_array 및 std::indirect_array 을 대체 타입으로부터 생성할 수 있습니다.
- const std:: valarray < T > & 를 받는 모든 함수에 대해 begin() 과 end() 를 제외하고 (C++11부터) 동일한 함수들이 대체 타입들을 받도록 추가되어야 합니다;
- 두 개의 const std:: valarray < T > & 인자를 받는 모든 함수에 대해, const std:: valarray < T > & 과 대체 타입들의 모든 조합을 받는 동일한 함수들이 추가되어야 합니다.
- 반환 타입은 가장 깊이 중첩된 인자 타입에 대해 두 수준 이상의 템플릿 중첩을 추가하지 않습니다.
가능한 구현
template<class T> valarray<T> atan(const valarray<T>& va) { valarray<T> other = va; for (T& i : other) i = atan(i); return other; // 프록시 객체가 반환될 수 있음 } |
예제
이 코드 실행
#include <algorithm> #include <cmath> #include <iostream> #include <valarray> auto show = [](char const* title, const std::valarray<float>& va) { std::cout << title << " :"; std::for_each(std::begin(va), std::end(va), [](const float x) { std::cout << " " << std::fixed << x; }); std::cout << '\n'; }; int main() { const std::valarray<float> x = {.1f, .3f, .6f, .9f}; const std::valarray<float> f = std::atan(x); const std::valarray<float> g = std::tan(f); show("x ", x); show("f = atan(x)", f); show("g = tan(f) ", g); }
출력:
x : 0.100000 0.300000 0.600000 0.900000 f = atan(x) : 0.099669 0.291457 0.540420 0.732815 g = tan(f) : 0.100000 0.300000 0.600000 0.900000
참고 항목
|
valarray의 각 요소에 함수
std::asin
을 적용합니다
(함수 템플릿) |
|
|
valarray의 각 요소에 함수
std::acos
을 적용합니다
(함수 템플릿) |
|
|
valarray와 값에 함수
std::atan2
을 적용합니다
(함수 템플릿) |
|
|
valarray의 각 요소에 함수
std::tan
을 적용합니다
(함수 템플릿) |
|
|
(C++11)
(C++11)
|
아크탄젠트를 계산합니다 (
arctan(x)
)
(함수) |
|
(C++11)
|
복소수의 아크탄젠트를 계산합니다 (
arctan(z)
)
(함수 템플릿) |