Namespaces
Variants

std:: atanh, std:: atanhf, std:: atanhl

From cppreference.net
Common mathematical functions
Nearest integer floating point operations
(C++11)
(C++11)
(C++11) (C++11) (C++11)
Floating point manipulation functions
(C++11) (C++11)
(C++11)
(C++11)
Classification and comparison
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Types
(C++11)
(C++11)
(C++11)
Macro constants
Определено в заголовочном файле <cmath>
(1)
float atanh ( float num ) ;

double atanh ( double num ) ;

long double atanh ( long double num ) ;
(до C++23)
/*floating-point-type*/
atanh ( /*floating-point-type*/ num ) ;
(начиная с C++23)
(constexpr начиная с C++26)
float atanhf ( float num ) ;
(2) (начиная с C++11)
(constexpr начиная с C++26)
long double atanhl ( long double num ) ;
(3) (начиная с C++11)
(constexpr начиная с C++26)
SIMD перегрузка (начиная с C++26)
Определено в заголовочном файле <simd>
template < /*math-floating-point*/ V >

constexpr /*deduced-simd-t*/ < V >

atanh ( const V & v_num ) ;
(S) (начиная с C++26)
Определено в заголовочном файле <cmath>
template < class Integer >
double atanh ( Integer num ) ;
(A) (constexpr начиная с C++26)
1-3) Вычисляет гиперболический арктангенс от num . Библиотека предоставляет перегрузки std::atanh для всех cv-неквалифицированных типов с плавающей запятой в качестве типа параметра. (начиная с C++23)
S) Перегрузка SIMD выполняет поэлементное вычисление std::atanh для v_num .
(См. math-floating-point и deduced-simd-t для их определений.)
(since C++26)
A) Дополнительные перегрузки предоставлены для всех целочисленных типов, которые трактуются как double .
(since C++11)

Содержание

Параметры

num - значение с плавающей точкой или целое число

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

Если ошибок не возникает, возвращается обратный гиперболический тангенс num ( tanh -1
(num)
, или artanh(num) ).

Если происходит ошибка области определения, возвращается значение, определяемое реализацией (NaN, если поддерживается).

Если возникает ошибка полюса, ±HUGE_VAL , ±HUGE_VALF , или ±HUGE_VALL возвращается (с правильным знаком).

Если происходит ошибка диапазона из-за потери значимости (underflow), возвращается корректный результат (после округления).

Обработка ошибок

Ошибки сообщаются, как указано в math_errhandling .

Если аргумент не находится на интервале [ - 1 , + 1 ] , возникает ошибка диапазона.

Если аргумент равен ±1, возникает ошибка полюса.

Если реализация поддерживает арифметику с плавающей запятой IEEE (IEC 60559),

  • если аргумент равен ±0, он возвращается без изменений.
  • если аргумент равен ±1, возвращается ±∞ и FE_DIVBYZERO устанавливается.
  • если |num|>1 , возвращается NaN и FE_INVALID устанавливается.
  • если аргумент равен NaN, возвращается NaN.

Примечания

Хотя стандарт C (на который ссылается C++ для этой функции) называет эту функцию «аркгиперболический тангенс», обратные функции гиперболических функций являются ареа-функциями. Их аргумент представляет собой площадь гиперболического сектора, а не дугу. Правильное название — «обратный гиперболический тангенс» (используется в POSIX) или «ареа-гиперболический тангенс».

POSIX определяет , что в случае потери значимости (underflow), num возвращается без изменений, и если это не поддерживается, возвращается определяемое реализацией значение, не превышающее DBL_MIN , FLT_MIN и LDBL_MIN .

Дополнительные перегрузки не обязаны быть предоставлены в точности как (A) . Они лишь должны быть достаточными для обеспечения того, чтобы для их аргумента num целочисленного типа, std :: atanh ( num ) имел тот же эффект, что и std :: atanh ( static_cast < double > ( num ) ) .

Пример

#include <cerrno>
#include <cfenv>
#include <cfloat>
#include <cmath>
#include <cstring>
#include <iostream>
// #pragma STDC FENV_ACCESS ON
int main()
{
    std::cout << "atanh(0) = " << std::atanh(0) << '\n'
              << "atanh(-0) = " << std::atanh(-0.0) << '\n'
              << "atanh(0.9) = " << std::atanh(0.9) << '\n';
    // обработка ошибок
    errno = 0;
    std::feclearexcept(FE_ALL_EXCEPT);
    std::cout << "atanh(-1) = " << std::atanh(-1) << '\n';
    if (errno == ERANGE)
        std::cout << "    errno == ERANGE: " << std::strerror(errno) << '\n';
    if (std::fetestexcept(FE_DIVBYZERO))
        std::cout << "    FE_DIVBYZERO raised\n";
}

Возможный вывод:

atanh(0) = 0
atanh(-0) = -0
atanh(0.9) = 1.47222
atanh(-1) = -inf
    errno == ERANGE: Numerical result out of range
    FE_DIVBYZERO raised

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

(C++11) (C++11) (C++11)
вычисляет обратный гиперболический синус ( arsinh(x) )
(функция)
(C++11) (C++11) (C++11)
вычисляет обратный гиперболический косинус ( arcosh(x) )
(функция)
(C++11) (C++11)
вычисляет гиперболический тангенс ( tanh(x) )
(функция)
вычисляет обратный гиперболический тангенс комплексного числа ( artanh(z) )
(шаблон функции)

Внешние ссылки

Вайсштейн, Эрик В. "Обратный гиперболический тангенс." Из MathWorld — веб-ресурс Wolfram.