「ガウス求積」の版間の差分
前回の間違いを修正 |
|||
166行目: | 166行目: | ||
* [http://www.gnu.org/software/gsl/ GNU Scientific Library] - [[C言語]]版の QUADPACK アルゴリズムを含む([[GNU Scientific Library]]も参照) |
* [http://www.gnu.org/software/gsl/ GNU Scientific Library] - [[C言語]]版の QUADPACK アルゴリズムを含む([[GNU Scientific Library]]も参照) |
||
* [http://nm.mathforcollege.com/topics/gauss_quadrature.html Gaussian Quadrature Rule of Integration - Notes, PPT, Matlab, Mathematica, Maple, Mathcad] at ''Holistic Numerical Methods Institute'' |
* [http://nm.mathforcollege.com/topics/gauss_quadrature.html Gaussian Quadrature Rule of Integration - Notes, PPT, Matlab, Mathematica, Maple, Mathcad] at ''Holistic Numerical Methods Institute'' |
||
* [http://www.sitmo.com/eqcat/13 Gaussian Quadrature table] at sitmo.com (リンク切れ。閲覧する場合は [[インターネット |
* [http://www.sitmo.com/eqcat/13 Gaussian Quadrature table] at sitmo.com (リンク切れ。閲覧する場合は [[インターネットアーカイブ|Internet Archive]] によるキャッシュ ([http://web.archive.org/web/20100413154934/http://www.sitmo.com/eqcat/13 こちら]) を参照。) |
||
* [http://mathworld.wolfram.com/Legendre-GaussQuadrature.html Legendre-Gauss Quadrature at MathWorld] |
* [http://mathworld.wolfram.com/Legendre-GaussQuadrature.html Legendre-Gauss Quadrature at MathWorld] |
||
* [http://demonstrations.wolfram.com/GaussianQuadrature/ Gaussian Quadrature] by Chris Maes and Anton Antonov, [[ウルフラム・リサーチ|The Wolfram Demonstrations Project]]. |
* [http://demonstrations.wolfram.com/GaussianQuadrature/ Gaussian Quadrature] by Chris Maes and Anton Antonov, [[ウルフラム・リサーチ|The Wolfram Demonstrations Project]]. |
2017年9月5日 (火) 00:09時点における版
ガウス求積(ガウスきゅうせき、英: Gaussian quadrature)またはガウスの数値積分公式とは、カール・フリードリヒ・ガウスに因んで名づけられた数値解析における数値積分法の一種であり、実数のある閉区間(慣例的に [−1, 1] に標準化される)で定義された実数値関数のその閉区間に渡る定積分値を、比較的少ない演算で精度良く求めることができるアルゴリズムである。
n を正の整数とし、f(x) を 任意の多項式関数とする。f(x) の [−1, 1] に渡る定積分値 I を、
の形でなるべく正確に近似する公式を考える。ここで、xi は積分点またはガウス点 (ガウスノード)と呼ばれる [−1, 1] 内の n 個の点であり、wi は重みと呼ばれるn個の実数である。
実は、n 次のルジャンドル多項式の n 個の零点(これらは全て [−1, 1] 内にある)を積分点として選び、wi を適切に選ぶと、f(x) が 2n − 1 次以下の多項式であれば上記の式が厳密に成立することが分かっている。この場合、wi は f(x) によらず一意的に定まる。この方法を n 次のガウス・ルジャンドル (Gauss–Legendre) 公式と呼び、通常はガウス求積またはガウスの数値積分公式と言えばこの方法を指している[1]。
f(x) が 2n − 1次を超える多項式関数の場合、または多項式関数でない場合には、上記の公式は厳密には成立しないが、f(x) が 2n − 1 次以下の多項式関数で精度よく近似できる場合には、上記の公式を f(x) に対して適用することにより、その [−1, 1] における定積分値を精度よく得ることが期待できる。それ以外の例えば、特異点のある関数の積分にはこの公式をそのまま適用することはできないが、対象の関数を f(x) = W(x) g(x) と表すことができ、g(x) が近似多項式で W(x) が既知であれば、それを代替する重み wi を使って次のように表せる。
典型的な重み関数としては、(ガウス–チェビシェフ)や (ガウス–エルミート)がある。この場合の n 個の積分点 xi はルジャンドル多項式と同様に、ある直交多項式のクラスに属する n 次多項式の根である[2][3]。
ガウス・ルジャンドル公式による求積
上述のように n 次のこの方法には、n 次のルジャンドル多項式 Pn(x) が対応している。このときの n 次多項式は Pn(1) = 1 となるよう正規化され、i 番目のガウスノード xi は i 番目の Pn の根である。重みは次の式で与えられる[4]。
低次の求積法は次のようになる。
点の個数 n | 点 xi | 重み wi |
---|---|---|
1 | 0 | 2 |
2 | 1 | |
3 | 0 | 8/9 |
5/9 | ||
4 | ||
5 | 0 | 128/225 |
区間変更
区間 [a, b] についての積分は、ガウス求積法を適用する前に [−1, 1] に変更する必要がある。この区間変更は以下のように行う。
ガウス求積法を適用後、以下の近似が得られる。
他の形式
正の重み関数 ω を導入することで、より汎用的な積分問題の表現も可能であり、区間 [−1, 1] 以外にも適用可能である。すなわち、次の形式の問題である。
a, b, ω は適当に選択する。a = −1, b = 1, ω(x) = 1 のとき、前述の問題と同じ形式になる。それ以外の選択では、別の求積法になる。そのうちの一部を下記の表に示す。"A & S" という欄は、Abramowitz and Stegun[4]にある式番号である。
区間 | ω(x) | 直交多項式 | A & S | 解説など |
---|---|---|---|---|
[−1, 1] | 1 | ルジャンドル多項式 | 25.4.29 | 本項(上)で解説 |
(−1, 1) | ヤコビ多項式 | 25.4.33 () | ||
(−1, 1) | チェビシェフ多項式(第一種) | 25.4.38 | チェビシェフ・ガウス求積法 | |
[−1, 1] | チェビシェフ多項式(第二種) | 25.4.40 | チェビシェフ・ガウス求積法 | |
[0, ∞) | ラゲール多項式 | 25.4.45 | ガウス・ラゲール求積法 | |
(−∞, ∞) | エルミート多項式 | 25.4.46 | ガウス・エルミート求積法 |
基礎的な定理
pn が自明でない n 次の多項式で、次のように表されるとする。
ノードとして pn の零点を選ぶなら、全ての 2n − 1 以下の次数の多項式について正確に積分を計算できる重み wi が存在する。さらに、それらノードは全て開区間 (a, b) にある[3]。
この多項式 pn は、重み関数 ω(x) に関連する次数 n の直交多項式である。
計算
ガウス求積法のノード xi と重み wi を計算するための基本的ツールは、直交多項式群と対応する重み関数が満たす3項漸化式である。
例えば、pn がモニックな n 次直交多項式(最高次の項の係数が 1 の n 次直交多項式)なら、次のような漸化式で関係を表すことができる。
このことから、対応する線型代数問題の固有値および固有ベクトルからノードと重みを計算できる。これを一般に Golub–Welsch アルゴリズムと呼ぶ[5]。
xi が直交多項式 pn の根であるとき、前掲の漸化式を について用い、 であることを踏まえると、次が成り立つことがわかる。
ここで
である。そして、J はいわゆるヤコビ行列である。
したがって、ガウス求積法のノードは三重対角行列の固有値として計算できる。
重みとノードを求めるには、要素が , と から成る対称な三重対角行列 の方が好ましい。 と は相似なので、固有値(ノード)も同じになる。重みは、行列 J から計算できる。 が固有値 xj に対応する正規化固有ベクトル(すなわち、ユークリッドノルムが1の固有ベクトル)であるとき、固有ベクトルの第一成分から次のように重みが計算できる。
ここで は重み関数の積分である。
詳しくは Gil, Segura & Temme 2007 を参照されたい[5]。
誤差見積もり
ガウス求積法の誤差は次のように定式化される[3]。積分対象の関数が 2n 次の連続導関数を持つとき、
となり、ξ は (a, b) にあり、pn は n 次の直交多項式であり、さらに
である。ω(x) = 1 となる重要な特殊ケースでは、次のような誤差見積もりがある[6]。
Stoer and Bulirsch[3] によれば、2n 次の導関数を見積もるのが難しいのでこの誤差見積もりは実用には不便であり、さらに言えば実際の誤差は導関数の界よりもずっと小さい。別の手法として、異なる次数のガウス求積法を使い、2つの結果の差分から誤差を見積もる方法もある。この場合、ガウス=クロンロッド求積法が便利である。
ガウス=クロンロッド求積法
区間 [a, b] を分割すると、各部分区間のガウス評価点は元の区間での評価点とは一致せず(奇数の場合の0を除く)、従って、新たに評価点を求める必要がある。ガウス=クロンロッド求積法は、ガウス求積法の n 個の点に n + 1 個の点を追加し、求積法としての次数を 3n + 1 にするものである。これにより、低次の近似で使う関数値を高次の近似の計算に再利用できる。通常のガウス求積法とクロンロッドの拡張による近似の差分が誤差の見積もりによく利用される。
脚注
- ^ 森・名取・鳥居 『数値計算』、岩波書店〈情報科学 18〉、1982年、pp. 130–132.
- ^ Press, William H.; Flannery, Brian P.; Teukolsky, Saul A.; Vetterling, William T. (1988年), “§4.5: Gaussian Quadratures and Orthogonal Polynomials”, Numerical Recipes in C (2nd ed.), Cambridge University Press, ISBN 978-0-521-43108-8
- ^ a b c d Stoer, Josef; Bulirsch, Roland (2002年), Introduction to Numerical Analysis (3rd ed.), Springer, ISBN 978-0-387-95452-3
- ^ a b Abramowitz, Milton; Stegun, Irene A., eds. (1972年), “§25.4, Integration”, Handbook of Mathematical Functions (with Formulas, Graphs, and Mathematical Tables), Dover, ISBN 978-0-486-61272-0
- ^ a b Gil, Amparo; Segura, Javier; Temme, Nico M. (2007年), “§5.3: Gauss quadrature”, Numerical Methods for Special Functions, SIAM, ISBN 978-0-898716-34-4
- ^ Kahaner, David; Moler, Cleve; Nash, Stephen (1989年), Numerical Methods and Software, Prentice-Hall, ISBN 978-0-13-627258-8
外部リンク
- ALGLIB 数値積分のためのアルゴリズムが多数掲載されている(言語は C# / C++ / Delphi / Visual Basic / その他)
- GNU Scientific Library - C言語版の QUADPACK アルゴリズムを含む(GNU Scientific Libraryも参照)
- Gaussian Quadrature Rule of Integration - Notes, PPT, Matlab, Mathematica, Maple, Mathcad at Holistic Numerical Methods Institute
- Gaussian Quadrature table at sitmo.com (リンク切れ。閲覧する場合は Internet Archive によるキャッシュ (こちら) を参照。)
- Legendre-Gauss Quadrature at MathWorld
- Gaussian Quadrature by Chris Maes and Anton Antonov, The Wolfram Demonstrations Project.