std::sinh(std::valarray)

来自cppreference.com
< cpp‎ | numeric‎ | valarray
 
 
 
 
在标头 <valarray> 定义
template<class T >
valarray<T> sinh(const valarray<T>& va );

va 中的每个元素,计算该元素的双曲正弦。

目录

[编辑]参数

va - 要应用运算的值数组

[编辑]返回值

va 中每个值双曲正弦的值数组。

[编辑]注解

用无限定函数 (sinh) 进行计算。若该函数不可用,则会由于实参依赖查找而使用 std::sinh

函数可以实现为拥有不同于 std::valarray 的返回类型。此时替换它的类型拥有下列属性:

[编辑]可能的实现

template<class T> valarray<T> sinh(const valarray<T>& va){ valarray<T> other = va;for(T& i : other) i = sinh(i);   return other;// 可以返回代理对象}

[编辑]示例

#include <cmath>#include <complex>#include <iomanip>#include <iostream>#include <valarray>   template<typename T>void show(charconst* title, conststd::valarray<T>& va){std::cout<< title <<" : "<<std::right;for(T x : va)std::cout<<std::fixed<< x <<' ';std::cout<<'\n';}   template<typename T>void sinh_for(std::valarray<T>const& z){// 双曲正弦为 sinh(z) = (eᶻ - e⁻ᶻ) / 2。   conststd::valarray<T> sinh_z{std::sinh(z)};conststd::valarray<T> e_z{std::exp(z)};conststd::valarray<T> e_neg_z{std::exp(-z)};conststd::valarray<T> sinh_def{(e_z - e_neg_z)/2.0f};   show("n ", z); show("sinh(n) ", sinh_z); show("(eⁿ-e⁻ⁿ)/2", sinh_def);   std::cout.put('\n');}   int main(){ sinh_for(std::valarray<float>{-.2f, -.1f, 0.f, .1f, .2f, INFINITY}); sinh_for(std::valarray<std::complex<double>>{{-.2,-.1}, {.2,.1}});}

输出:

n  : -0.200000 -0.100000 0.000000 0.100000 0.200000 inf sinh(n)  : -0.201336 -0.100167 0.000000 0.100167 0.201336 inf (eⁿ-e⁻ⁿ)/2 : -0.201336 -0.100167 0.000000 0.100167 0.201336 inf   n  : (-0.200000,-0.100000) (0.200000,0.100000) sinh(n)  : (-0.200330,-0.101837) (0.200330,0.101837) (eⁿ-e⁻ⁿ)/2 : (-0.200330,-0.101837) (0.200330,0.101837)

[编辑]参阅

应用函数 std::coshvalarray 的每个元素
(函数模板)[编辑]
应用函数 std::tanh 到 valarray 的每个元素
(函数模板)[编辑]
(C++11)(C++11)
计算双曲正弦(sinh(x)
(函数)[编辑]
计算复数的双曲正弦(sinh(z)
(函数模板)[编辑]
close