std:: acos (std::valarray)
From cppreference.net
|
定义于头文件
<valarray>
|
||
|
template
<
class
T
>
valarray < T > acos ( const valarray < T > & va ) ; |
||
对于 va 中的每个元素,计算该元素值的反余弦值。
目录 |
参数
| va | - | 要应用操作的值数组 |
返回值
包含 va 中数值反余弦值的数组。
注释
使用非限定函数( acos )执行计算。若该函数不可用,由于 实参依赖查找 机制,将使用 std:: acos 。
该函数可以实现为返回类型不同于 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> 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)
)
(函数) |
|
(C++11)
|
计算复数的反余弦(
arccos(z)
)
(函数模板) |