std:: acos, std:: acosf, std:: acosl
|
Определено в заголовке
<cmath>
|
||
| (1) | ||
|
float
acos
(
float
num
)
;
double
acos
(
double
num
)
;
|
(до C++23) | |
|
/*floating-point-type*/
acos ( /*floating-point-type*/ num ) ; |
(начиная с C++23)
(constexpr начиная с C++26) |
|
|
float
acosf
(
float
num
)
;
|
(2) |
(начиная с C++11)
(constexpr начиная с C++26) |
|
long
double
acosl
(
long
double
num
)
;
|
(3) |
(начиная с C++11)
(constexpr начиная с C++26) |
|
SIMD перегрузка
(начиная с C++26)
|
||
|
Определено в заголовке
<simd>
|
||
|
template
<
/*math-floating-point*/
V
>
constexpr
/*deduced-simd-t*/
<
V
>
|
(S) | (начиная с C++26) |
|
Дополнительные перегрузки
(начиная с C++11)
|
||
|
Определено в заголовке
<cmath>
|
||
|
template
<
class
Integer
>
double acos ( Integer num ) ; |
(A) | (constexpr начиная с C++26) |
std::acos
для всех неквалифицированных cv типов с плавающей запятой в качестве типа параметра.
(since C++23)
|
S)
Перегрузка SIMD выполняет поэлементное вычисление
std::acos
для
v_num
.
|
(since C++26) |
|
A)
Дополнительные перегрузки предоставляются для всех целочисленных типов, которые трактуются как
double
.
|
(since C++11) |
Содержание |
Параметры
| num | - | значение с плавающей точкой или целое число |
Возвращаемое значение
Если ошибок не возникает, возвращается арккосинус num ( arccos(num) ) в диапазоне [0, π] .
Если происходит ошибка области определения, возвращается значение, определяемое реализацией (NaN, если поддерживается).
Если происходит ошибка диапазона из-за потери значимости (underflow), возвращается корректный результат (после округления).
Обработка ошибок
Ошибки сообщаются, как указано в math_errhandling .
Ошибка домена возникает, если
num
находится вне диапазона
[
-
1.0
,
1.0
]
.
Если реализация поддерживает арифметику с плавающей запятой IEEE (IEC 60559),
-
Если аргумент равен
+1
, возвращается значение
+0. - Если |num| > 1 , возникает ошибка домена и возвращается NaN.
- Если аргумент равен NaN, возвращается NaN.
Примечания
Дополнительные перегрузки не обязаны быть предоставлены в точности как (A) . Они лишь должны быть достаточными для обеспечения того, чтобы для их аргумента num целочисленного типа, std :: acos ( num ) имел тот же эффект, что и std :: acos ( static_cast < double > ( num ) ) .
Пример
#include <cerrno> #include <cfenv> #include <cmath> #include <cstring> #include <iostream> // #pragma STDC FENV_ACCESS ON int main() { std::cout << "acos(-1) = " << std::acos(-1) << '\n' << "acos(0.0) = " << std::acos(0.0) << '\n' << "2*acos(0.0) = " << 2 * std::acos(0) << '\n' << "acos(0.5) = " << std::acos(0.5) << '\n' << "3*acos(0.5) = " << 3 * std::acos(0.5) << '\n' << "acos(1) = " << std::acos(1) << '\n'; // обработка ошибок errno = 0; std::feclearexcept(FE_ALL_EXCEPT); std::cout << "acos(1.1) = " << std::acos(1.1) << '\n'; if (errno == EDOM) std::cout << " errno == EDOM: " << std::strerror(errno) << '\n'; if (std::fetestexcept(FE_INVALID)) std::cout << " FE_INVALID raised" << '\n'; }
Вывод:
acos(-1) = 3.14159
acos(0.0) = 1.5708
2*acos(0.0) = 3.14159
acos(0.5) = 1.0472
3*acos(0.5) = 3.14159
acos(1) = 0
acos(1.1) = nan
errno == EDOM: Numerical argument out of domain
FE_INVALID raised
Смотрите также
|
(C++11)
(C++11)
|
вычисляет арксинус (
arcsin(x)
)
(функция) |
|
(C++11)
(C++11)
|
вычисляет арктангенс (
arctan(x)
)
(функция) |
|
(C++11)
(C++11)
|
арктангенс с использованием знаков для определения квадрантов
(функция) |
|
(C++11)
(C++11)
|
вычисляет косинус (
cos(x)
)
(функция) |
|
(C++11)
|
вычисляет арккосинус комплексного числа (
arccos(z)
)
(шаблон функции) |
|
применяет функцию
std::acos
к каждому элементу valarray
(шаблон функции) |
|
|
Документация C
для
acos
|
|