マルチステップ法
📂数値解析マルチステップ法
定義
D⊂R2で定義された連続関数に対して、初期値問題{y′=f(x,y)(y(x0),⋯,y(xp))=(Y0,⋯,Yp)が与えられているとする。区間(a,b)をa≤x0<x1<⋯<xn<⋯xN≤bのようなノードポイントに分割したとしよう。特に、十分に小さいh>0に対してxj=x0+jhとすると、初期値と0≤p≤mに対して、ap=0またはbp=0ならば、以下を**(p+1)ステップメソッド**と呼ぶ。
yn+1=j=0∑pajyn−j+hj=−1∑pbjf(xn−j,yn−j)
説明
もちろん、十分に大きなq≥1とD⊂R2で定義されたf∈Cq(D)を考えても構わない。この一般的な形で、特にp=0であり、a0=1,b0=1,b−1=0であるならば、オイラーメソッドになる。
マルチステップメソッドは、ワンステップメソッドに比べてより多くのデータ情報を使用するため、通常は精度が高くなる。初期値問題{y′=f(x,y)(y(x0),⋯,y(xp))=(Y0,⋯,Yp)に対して、切り捨て誤差truncated errorを
Tn(Y):=Yn+1−j=0∑pajYn−j+hj=−1∑pbjY’n−j
としよう。これについて、τn(Y):=h1Tn(Y)と書き、h→0limxp≤xn≤bmax∣τn(Y)∣=0を満たす場合、メソッドが一貫性consistency conditionを持つと言われる。式で書くと複雑に見えるが、簡単に言えば、hが小さくなる速さより切り捨て誤差が小さくなる速さの方が速いことを指す。ここで
τ(h):=xp≤xn≤bmax∣τn(Y)∣=O(hm)
を満たすmの中で最も大きい数をメソッドの収束次数order of Convergenceと呼ぶ。
特にb−1=0の場合、yn+1は左辺にのみ現れるので、明示的メソッドexplicit methodと呼ばれる。b−1=0であれば、yn+1が両辺に現れるので、暗黙的メソッドimplicit methodと呼ばれる。計算の際には明示的メソッドが便利だが、一般的に知られている暗黙的メソッドは性能が良いが追加的な計算が必要だ。