常微分方程式の数値解法

常微分方程式を数値的に解く技術の総称 ウィキペディアから

常微分方程式の数値解法

常微分方程式の数値解法 (じょうびぶんほうていしきのすうちかいほう、: Numerical methods for ODEs) は、数値解析において常微分方程式を数値的に解く技術の総称である[1][2]

数値解法の必要性

これまで様々な自然現象 (物理現象など) を記述するために多くの常微分方程式が作られ、多くの数学者たちがその解法を探求してきたが、フックス型微分方程式[3][4]などを除いて、式変形による計算だけで厳密に解ける常微分方程式は多くない。そのため多くの研究者たちが常微分方程式を数値的に解く技術について研究をしてきた[1][2]。最も標準的な手法はルンゲ・クッタ法であり[1][2][5][A 1]MATLABにはode45として搭載されている。しかしこれは万能なソルバーとは言えない。例えばパンルヴェ方程式[6][7][8]リッカチ方程式[9]などは非線形性によって精度の良い計算ができず、数値実験結果だけを見ていると間違った結論 (幻影解) にたどり着く危険がある。そのため[要出典]

などの新しい解法に関する研究が進められている。

初期値問題

要約
視点

個の変数 に関する1階常微分方程式、すなわち (またはその開集合)で定義されたベクトル値連続関数 により定まる次の方程式

について考える。その初期値問題 (initial-value problem) とは、初期条件 を満たす関数 を求めることである[12]。関数 が第2引数についてリプシッツ連続であるとき、すなわち定数 が存在し

ノルム)を満たすとき、その初期値問題には解が一意に存在する[13]ピカール・リンデレフの定理)。本節では常微分方程式の初期値問題を数値的に解くことについて議論する。

初期値問題の例

例として、電気回路の研究から導かれたファン・デル・ポール振動子について考える。その運動方程式は

であり、これは2階の常微分方程式であるものの、 とおくと

という上述の形に帰着できる[14]

一段法

区間 の厳密解を とする。一段法[15]として知られるクラスの数値解法では、離散化した時刻 () での厳密解 の近似値

という漸化式によって定める[16]。関数 の選択が数値積分スキームを選択することに対応する。離散化した時刻の差分 を刻み幅あるいはステップサイズと呼ぶ[17]。なお、ここでは時間ステップ は一定としたが、これを動的に決定する適応刻み英語版という手法もある[18][19]

厳密解 から差分商

を導入するとき、数値積分スキーム の局所離散化誤差[20] (local discretization error) は

により定義される[21][22]。整合性のために の極限で局所離散化誤差(厳密にはその上限)は 0 に収束することが要求される[23][24]。さらに、この極限で局所離散化誤差が を満足するとき、この積分スキーム 次精度であるという[25][23]

一方、 を固定して とするとき、大域離散化誤差[26] (global discretization error)

が 0 に収束するならば、その積分スキームは収束するという[27][24] 次精度 () の1段法を十分に滑らかな関数 に適用するとき、そのスキームは収束し大域離散化誤差は

のように振る舞うことが保証されている、すなわち大域離散化誤差のオーダーは局所離散化誤差のオーダーに等しい[28][29]。この結果はすべての整合的な一段法が で漸近的に安定であることを意味するものの、ただし現実的に可能な で1段法が安定であることは必ずしも保証されない(#安定性節を参照)[30]

Thumb
オイラー法、ホイン法、古典的ルンゲ=クッタ法 (RK4) の相対誤差の比較。初期値 のもとでの常微分方程式 の数値解の での値をステップサイズの関数として対数プロットした。各手法がそれぞれ1次精度、2次精度、4次精度であることに対応して、傾き 1, 2, 4 で誤差が減少している[31]

積分スキーム としては以下のものが知られている。

  • オイラー法[32]: とするもの。これは1次精度のスキームである。
  • ホイン法英語版[33]: とするもの。これは2次精度のスキームであり、関数 の評価を2回必要とする。
  • 古典的ルンゲ=クッタ法: これは4次精度のスキームであり、関数 の評価を4回必要とする[34]

このうち古典的ルンゲ=クッタ法は適用可能範囲の広さ[18]やプログラミングの容易さのために広く用いられている[35](ただし Press らは著書において計算速度の観点から古典的ルンゲ=クッタ法に否定的に言及している[36])。

多段法

一段法は の値を だけから定めるものであったが、より多くのステップでの値 , ..., を使う積分スキームは多段法[15] (multistep method) と呼ばれる[37]。この場合、最初の , ..., はこのスキームでは定めることができず、1段法などの他の方法を用いる必要がある[37]。多段法としてはアダムス・バッシュフォース法や、それを応用する予測子修正子法などがある[38](これはどちらも , ..., の線型関数として定まるため、線型多段法と呼ばれる[39])。

安定性

数値積分スキームの安定性はしばしばそれを初期値問題

は複素数の定数)に適用することで定量化される[40]。問題のスキームを一定の刻み幅 で適用することで得られる数列 について、それが極限 で 0 に収束するような がなす複素平面上の領域を絶対安定領域[41]と呼ぶ[40]。もとの初期値問題の厳密解は であり、これは のとき で 0 に収束する[42]。そこである積分スキームの絶対安定領域が左半平面を含むとき、そのスキームはA-安定 (A-stable) であるという[43][44]

関数 が大きな値を取り積分スキームによっては極端に時間刻み幅 を小さくする必要がある場合、その常微分方程式は硬い方程式と呼ばれる[45]。この場合には十分に安定なスキームを用いる必要が生じる[44]。これはしばしば 陰関数的に 等から定める陰解法によって実現される[46]

幾何学的解法

解析対象となる微分方程式が何らかの特別な性質を持つとき、汎用の数値積分法ではなく、その性質を尊重するように構成された数値解法を用いることがあり、そのような手法は構造保存型解法または幾何学的数値解法と呼ばれる[47][48]。例えば古典力学ハミルトン力学)において時間発展はシンプレクティック写像であり、エネルギーハミルトニアン)等の保存量が存在する[48]。この場合にはシンプレクティック数値積分法というハミルトン系にのみ適用可能な数値解法が存在し、良好な性質を持つことが知られている[49]

境界値問題

要約
視点

常微分方程式

の解 で, に対する境界条件

を満足するものを求める問題を境界値問題 (boundary-value problem) と呼ぶ[50]。初期値問題と異なり、境界値問題では複数の解が存在すること、あるいは解が存在しないことがあり得る。また、スツルム=リウヴィル型微分方程式のように常微分方程式にパラメータ が含まれ、境界値問題に解が存在するようにパラメータ を同時に定める問題もある[51]

これらの問題を数値的に解く最も単純な方法が狙い撃ち法 (shooting method) である[52]。一方の端点(例えば )において初期条件 を適当に定めて微分方程式をもう一方の端点 まで解き、境界条件を満たすように未定の初期条件(および固有値)を適切に選ぶ[53][54]。これはニュートン法などの関数の根を求めるアルゴリズム(これはしばしば逐次反復を伴う)を常微分方程式の数値解法と組み合わせることを意味する[55][56]。ただし初期条件によっては区間 全体で定義された解が存在しないことがあり、そのために改良された手法がある[57]。あるいは有限要素法 (finite element method) などの手法も用いられる[58]

解の存在検証

高精度に解く技術が追求されている一方で、「計算機で解の存在を検証する」という研究もおこなわれている[59]。このような研究が必要となるのは、近似解が求まったとしてもそれが幻影解である危険性があるからである。偏微分方程式ではすでに幻影解が報告されているので[59][B 1][B 2]常微分方程式でも警戒が必要である。偏微分方程式の時と同様に関数解析学的な手法[59][60][61][62]も考えられるが、関数解析学に頼らない手法 (例えば狙い撃ち法スペクトル法アフィン演算など) に基づく研究が主流であり[59]、欧米などの海外[B 3][B 4][B 5][B 6][B 7][B 8][B 9][B 10][B 11]のみならず日本国内でも研究されている[B 12][B 13][B 14][B 15]。また、爆発解 (: Blow-up solution) に特化した精度保証付き解法も探求されている[B 16][B 17]

解の存在検証・計算機援用証明が行われた方程式

関連ソフトウェア・ライブラリ

出典

参考文献

外部リンク

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.