std::atan(std::complex)
From cppreference.com
| ヘッダ <complex> で定義 |
||
| template< class T > complex<T> atan( const complex<T>& z ); |
(C++11以降) | |
複素数値 z の複素アークタンジェントを計算します。分岐カットは、虚軸に沿った区間 [−i, +i] の外側に存在します。
目次 |
[編集] パラメータ
| z | - | complex value |
[編集] 戻り値
エラーが発生しない場合、z の複素アークタンジェントが返されます。その範囲は、虚軸に沿って制限がなく、実軸に沿って区間 [−π/2, +π/2] にあります。
エラーおよび特殊ケースは、虚数単位を i として、-i * std::atanh(i * z) によって操作が実装されているかのように処理されます。
[編集] 注記
逆正接(またはアークタンジェント)は多価関数であり、複素平面上で分岐カットを必要とします。分岐カットは、慣例により虚軸上の線分 (-∞i,-i) および (+i,+∞i) に配置されます。
逆正接の主値の数学的定義は、atan z = -| 1 |
| 2 |
[編集] 例
このコードを実行
#include <cmath> #include <complex> #include <iostream> int main() { std::cout << std::fixed; std::complex<double> z1(0.0, 2.0); std::cout << "atan" << z1 << " = " << std::atan(z1) << '\n'; std::complex<double> z2(-0.0, 2.0); std::cout << "atan" << z2 << " (the other side of the cut) = " << std::atan(z2) << '\n'; std::complex<double> z3(0.0, INFINITY); std::cout << "2 * atan" << z3 << " = " << 2.0 * std::atan(z3) << '\n'; }
出力
atan(0.000000,2.000000) = (1.570796,0.549306) atan(-0.000000,2.000000) (the other side of the cut) = (-1.570796,0.549306) 2 * atan(0.000000,inf) = (3.141593,0.000000)
[編集] 関連項目
| (C++11) |
複素数の逆正弦 (アークサイン) を計算する (arcsin(z)) (関数テンプレート) |
| (C++11) |
複素数の逆余弦 (アークコサイン) を計算する (arccos(z)) (関数テンプレート) |
| 複素数の正接 (タンジェント) を計算する (tan(z)) (関数テンプレート) | |
| (C++11)(C++11) |
逆正接を計算する (arctan(x)) (関数) |
| valarrayの各要素に関数std::atanを適用する (function template) | |
| C言語ドキュメント catan
| |