std::exp(std::complex)
来自 cppreference.com
定义于头文件 <complex> |
||
template< class T > std::complex<T> exp( const std::complex<T>& z ); |
||
计算 z 的以 e 为底的指数,即 e(欧拉数,2.7182818
)的 z 次方。
内容 |
[编辑] 参数
z | - | 复数值 |
[编辑] 返回值
如果未发生错误,则返回 e 的 z 次方,ez
。
[编辑] 错误处理和特殊值
错误报告与 math_errhandling 一致。
如果实现支持 IEEE 浮点运算,
- std::exp(std::conj(z)) == std::conj(std::exp(z))
- 如果 z 是
(±0,+0)
,则结果为(1,+0)
- 如果 z 是
(x,+∞)
(对于任何有限的 x),则结果为(NaN,NaN)
,并且会引发 FE_INVALID。 - 如果 z 是
(x,NaN)
(对于任何有限的 x),则结果为(NaN,NaN)
,并且可能会引发 FE_INVALID。 - 如果 z 是
(+∞,+0)
,则结果为(+∞,+0)
- 如果 z 是
(-∞,y)
(对于任何有限的 y),则结果为+0cis(y)
- 如果 z 是
(+∞,y)
(对于任何有限的非零 y),则结果为+∞cis(y)
- 如果 z 是
(-∞,+∞)
,则结果为(±0,±0)
(符号未指定) - 如果 z 是
(+∞,+∞)
,则结果为(±∞,NaN)
,并且会引发 FE_INVALID(实部的符号未指定) - 如果 z 是
(-∞,NaN)
,则结果为(±0,±0)
(符号未指定) - 如果 z 是
(+∞,NaN)
,则结果为(±∞,NaN)
(实部的符号未指定) - 如果 z 是
(NaN,+0)
,则结果为(NaN,+0)
- 如果 z 是
(NaN,y)
(对于任何非零 y),则结果为(NaN,NaN)
,并且可能会引发 FE_INVALID - 如果 z 是
(NaN,NaN)
,则结果为(NaN,NaN)
其中 cis(y) 是 cos(y) + i sin(y)。
[编辑] 备注
复数指数函数 ez
对于 z = x+iy 等于 ex
cis(y),或 ex
(cos(y) + i sin(y))。
指数函数是复数平面上的一个整函数,没有分支切割。
当实部为 0 时,以下结果等效
- std::exp(std::complex<float>(0, theta))
- std::complex<float>(cosf(theta), sinf(theta))
- std::polar(1.f, theta)
在这种情况下,exp
可能慢约 4.5 倍。应使用其他形式,而不是使用实部为文字 0 的参数调用 exp
。尽管如此,尝试使用 z.real() == 0 的运行时检查来避免 exp
并无益处。
[编辑] 示例
运行此代码
#include <cmath> #include <complex> #include <iostream> int main() { const double pi = std::acos(-1.0); const std::complex<double> i(0.0, 1.0); std::cout << std::fixed << " exp(i * pi) = " << std::exp(i * pi) << '\n'; }
输出
exp(i * pi) = (-1.000000,0.000000)
[编辑] 另请参阅
复数自然对数,其分支割线沿负实轴 (函数模板) | |
(C++11)(C++11) |
返回 e 的给定次方 (ex) (函数) |
将函数 std::exp 应用于 valarray 的每个元素 (函数模板) | |
从幅度和相位角构建一个复数 (函数模板) | |
C 文档 for cexp
|