ロンバーグ積分(ロンバーグせきぶん、Romberg integration)またはロンベルク積分は、関数の数値積分アルゴリズムのひとつである。この方法では台形公式とリチャードソンの補外を組み合わせ離散化幅 h {\displaystyle h} をゼロとする極限として数値積分を評価する。他の数値積分法に比べ、少ない回数の被積分関数の評価によって高精度の結果が得られる。

1955年にヴェルナー・ロンベルクによって考案された。

概要

ロンバーグ積分は区間 [ a , b ] {\displaystyle [a,b]} で定義された関数 f {\displaystyle f} の定積分

を数値的に求めるアルゴリズムである。積分区間 [ a , b ] {\displaystyle [a,b]} を幅 h = ( b a ) / N {\displaystyle h=(b-a)/N} N {\displaystyle N} 個の小区間 [ x i , x i 1 ] {\displaystyle [x_{i},x_{i 1}]} ( x i = a i h {\displaystyle x_{i}=a ih} , i = 0 , 1 , , N 1 {\displaystyle i=0,1,\dots ,N-1} ) に分割するとき, 数値積分アルゴリズムのひとつである台形公式は求める定積分を

により近似する。台形公式による値 T ( h ) {\displaystyle T(h)} と真の定積分の値の差は O ( h 2 ) {\displaystyle {\mathcal {O}}(h^{2})} であるが、オイラー・マクローリンの和公式(オイラーの和公式)によりそれをより詳しく評価することができる。すなわち、 f {\displaystyle f} C 2 m 2 {\displaystyle C^{2m 2}} -級関数であるならば

が成立する。ここに B 2 k {\displaystyle B_{2k}} はベルヌーイ数 であり、 ξ ( h ) {\displaystyle \xi (h)} a < ξ ( h ) < b {\displaystyle a<\xi (h) を満足するある数である。それ故に台形公式を h {\displaystyle h} に関する漸近級数と見るとき、誤差項としては h {\displaystyle h} の偶数次の項だけが現れる。そこで複数の h {\displaystyle h} について台形公式を適用し、それらの結果について誤差項を打ち消すようにリチャードソンの補外を行うことで、より精度の高い定積分の評価が得られる。これがロンバーグ積分である。

アルゴリズム

ロンバーグ積分のアルゴリズムは以下のように記述される。

  1. いくつかの幅 h 0 {\displaystyle h_{0}} , h 1 = h 0 / N 1 {\displaystyle h_{1}=h_{0}/N_{1}} , ..., h m = h 0 / N m {\displaystyle h_{m}=h_{0}/N_{m}} に対して台形公式を適用することにより定積分の近似値 T 0 , 0 = T ( h 0 ) {\displaystyle T_{0,0}=T(h_{0})} , ..., T m , 0 = T ( h m ) {\displaystyle T_{m,0}=T(h_{m})} を求める.
  2. 次の漸化式(ネヴィルのアルゴリズム)
    T i , k = T i , k 1 T i , k 1 T i 1 , k 1 [ h i k h i ] 2 1 {\displaystyle \quad T_{i,k}=T_{i,k-1} {\frac {T_{i,k-1}-T_{i-1,k-1}}{\left[{\frac {h_{i-k}}{h_{i}}}\right]^{2}-1}}}
    により帰納的に T i , k {\displaystyle T_{i,k}} を計算し、得られた T m , m {\displaystyle T_{m,m}} が求める補外値を与える。

h 0 , , h m {\displaystyle h_{0},\cdots ,h_{m}} としては、ロンバーグは

を用いていたが、Roland Bulirschは次数が急激に増加し計算コストが増大することを抑えるために

を提案している。

補外ステップにおいてリチャードソン補外テーブルの各項の差分に基づいて積分の収束性を判定することで、計算をどこまで進めればよいか判定することも可能である。

特徴

ロンバーグ積分 T i , k {\displaystyle T_{i,k}} の誤差は、評価に用いたステップ h i k , , h i {\displaystyle h_{i-k},\dots ,h_{i}} から O ( h i k 2 h i k 1 2 h i 2 ) {\displaystyle {\mathcal {O}}(h_{i-k}^{2}h_{i-k 1}^{2}\cdots h_{i}^{2})} と見積もられる。特に h i {\displaystyle h_{i}} をロンバーグの提案に従って選ぶときには誤差の厳密な評価

が得られている。

h 2 = h 1 / 2 {\displaystyle h_{2}=h_{1}/2} に選ぶとき、リチャードソン補外において現れる T 2 , 1 {\displaystyle T_{2,1}} T 3 , 1 {\displaystyle T_{3,1}} はシンプソンの公式によって問題の定積分を評価した値に一致する。その意味で、より多くの積分幅 h {\displaystyle h} での評価を行うことはニュートン・コーツの公式において積分公式を拡張することに、漸化式を解き補外を行うことは積分の次数を上げることに対応していると解釈できる。

Press らは著書「Numerical Recipes in C」においてロンバーグ積分が異なる次数の数値積分法を組み合わせた一般的な方法であることから数値積分においてこの方法を用いることを強く推奨している。特に、被積分関数が積分区間において十分に滑らかであれば、ロンバーグ積分はニュートン・コーツ型の積分公式に比べて極めて少ない回数の被積分関数の評価だけで十分な精度の結果を与える。

なお、ネヴィルのアルゴリズムはラグランジュ多項式による補外であるが、有理関数補外を行うこともでき、この場合ロンバーグ積分における漸化式は

へと変更される。

具体例

次の定積分をロンバーグ積分により求めることを考える。

積分ステップとして h 0 = 1 {\displaystyle h_{0}=1} , h 1 = 1 / 2 {\displaystyle h_{1}=1/2} , h 2 = 1 / 4 {\displaystyle h_{2}=1/4} を取り補外を行う。その結果、次の表に示すようにロンバーグ積分によって正確な積分値を得ることができる。

ライブラリ

C言語により実装されているオープンソースの科学技術計算ライブラリGNU Scientific Library (GSL) にはロンバーグ積分を行う関数が含まれている。また、Pythonの数値解析ライブラリSciPyにはロンバーグ積分により数値積分を行う scipy.integrate.romberg および scipy.integrate.romb というふたつの関数がある.

脚注

参考文献

  • Press, William H.; Teukolsky, Saul A.; Vetterling, William T.; Flannery, Brian P. (1992). Numerical Recipes in C: The Art of Scientific Computing (2nd ed.). Cambridge University Press. doi:10.2277/0521431085. ISBN 978-0-521-43108-8 
  • Stoer, Josef; Bulirsch, R. (2002). Introduction to Numerical Analysis. Springer. doi:10.1007/978-0-387-21738-3. ISBN 978-0-387-21738-3 

関連項目

  • 台形公式
  • シンプソンの公式
  • ニュートン・コーツの公式
  • ブリルシュ・ストア法 - 常微分方程式の数値解法のひとつで、修正中点法の結果に対してロンバーグ積分と同様にリチャードソンの補外を行う。

はじめてのルベーグ積分

ルベーグ積分とかいうまじでよく分からないやつについてできるだけわかりやすく解説してみた 実用的な数学を

ルベーグ積分とかいうまじでよく分からないやつについてできるだけわかりやすく解説してみた 実用的な数学を

ルベーグ積分とかいうまじでよく分からないやつについてできるだけわかりやすく解説してみた 実用的な数学を

[SciPy] 18. integrate. trapezoid, simpsonなどで離散的データの数値積分 サボテンパイソン