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