std:: tan (std::valarray)
From cppreference.net
|
定义于头文件
<valarray>
|
||
|
template
<
class
T
>
valarray < T > tan ( const valarray < T > & va ) ; |
||
对 va 中的每个元素计算其值的正切函数结果。
目录 |
参数
| va | - | 要应用操作的值数组 |
返回值
包含 va 中数值正切值的数组。
注释
使用非限定函数( tan )执行计算。若该函数不可用,由于 实参依赖查找 机制,将使用 std:: tan 。
该函数可以实现为返回类型不同于 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> tan(const valarray<T>& va) { valarray<T> other = va; for (T& i : other) i = tan(i); return other; // 可能返回代理对象 } |
示例
运行此代码
#include <cmath> #include <iostream> #include <valarray> auto show = [](char const* title, const std::valarray<double>& va) { std::cout << title << " :"; for (auto x : va) std::cout << " " << std::fixed << x; std::cout << '\n'; }; int main() { const std::valarray<double> x = {.0, .1, .2, .3}; const std::valarray<double> y = std::tan(x); const std::valarray<double> z = std::atan(y); show("x ", x); show("y = tan(x) ", y); show("z = atan(y)", z); }
输出:
x : 0.000000 0.100000 0.200000 0.300000 y = tan(x) : 0.000000 0.100335 0.202710 0.309336 z = atan(y) : 0.000000 0.100000 0.200000 0.300000
参见
|
对 valarray 的每个元素应用函数
std::sin
(函数模板) |
|
|
对 valarray 的每个元素应用函数
std::cos
(函数模板) |
|
|
对 valarray 的每个元素应用函数
std::atan
(函数模板) |
|
|
(C++11)
(C++11)
|
计算正切值 (
tan(x)
)
(函数) |
|
计算复数的正切值 (
tan(z)
)
(函数模板) |