Namespaces
Variants

std:: atan (std::valarray)

From cppreference.net
Определено в заголовке <valarray>
template < class T >
valarray < T > atan ( const valarray < T > & va ) ;

Для каждого элемента в va вычисляет арктангенс значения элемента.

Содержание

Параметры

va - массив значений, к которому применяется операция

Возвращаемое значение

Массив значений, содержащий арктангенсы значений в va .

Примечания

Для выполнения вычислений используется неквалифицированная функция ( atan ). Если такая функция недоступна, std:: atan используется благодаря поиску, зависящему от аргументов .

Функция может быть реализована с возвращаемым типом, отличным от 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

Смотрите также

применяет функцию std::asin к каждому элементу valarray
(шаблон функции)
применяет функцию std::acos к каждому элементу valarray
(шаблон функции)
применяет функцию std::atan2 к valarray и значению
(шаблон функции)
применяет функцию std::tan к каждому элементу valarray
(шаблон функции)
(C++11) (C++11)
вычисляет арктангенс ( arctan(x) )
(функция)
вычисляет арктангенс комплексного числа ( arctan(z) )
(шаблон функции)