このページの翻訳は最新ではありません。ここをクリックして、英語の最新版を参照してください。
ode23tb
スティッフ微分方程式の求解 — 台形則 + 後退差分式
構文
説明
[
は、t
,y
] = ode23tb(odefun
,tspan
,y0
)tspan = [t0 tf]
のときに、初期条件 y0
を使用して、微分方程式系 を t0
から tf
まで積分します。解の配列 y
の各行は、列ベクトル t
に返される値に対応します。
すべての MATLAB® ODE ソルバーは、 の形式の方程式系、あるいは質量行列 を含む問題を解くことができます。すべてのソルバーは類似した構文を使用します。ode23s
ソルバーは、質量行列が定数である場合にのみ、これを含む問題を解くことができます。ode15s
および ode23t
は、特異質量行列をもつ方程式、つまり微分代数方程式 (DAE) を解くことができます。odeset
の Mass
オプションを使用して質量行列を指定します。
[
はさらに、(t,y) の関数 (イベント関数) がゼロになる点を求めます。出力の t
,y
,te
,ye
,ie
] = ode23tb(odefun
,tspan
,y0
,options
)te
はイベント時点、ye
はイベント時点における解、ie
はトリガーされたイベントのインデックスです。
各関数に対して、ゼロで積分を終了するかどうかと、ゼロクロッシングの方向を考慮するかどうかを指定します。これを行うには、myEventFcn
や @myEventFcn
などの関数に 'Events'
プロパティを設定し、対応する関数 [value
,isterminal
,direction
] = myEventFcn
(t
,y
) を作成します。詳細については、ODE のイベント検出を参照してください。
は、区間 sol
= ode23tb(___)[t0 tf]
の任意の点で解を計算する関数 deval
で使用できる構造体を返します。前述の構文にある任意の入力引数の組み合わせが使用できます。
例
入力引数
出力引数
アルゴリズム
関数 ode23tb
は TR-BDF2 の実装です。TR-BDF2 は、第 1 段で台形則ステップを使用し、第 2 段で 2 次の後退差分式を使用する陰的ルンゲ・クッタ公式です。この過程で、同じ反復行列が 2 つの段階での実行に利用されます。ode23s
や ode23t
と同様に、このソルバーも粗い許容誤差をもつ問題の場合は ode15s
よりも効率的です [1]、[2]。
参照
[1] Bank, R. E., W. C. Coughran, Jr., W. Fichtner, E. Grosse, D. Rose, and R. Smith, “Transient Simulation of Silicon Devices and Circuits,” IEEE Trans. CAD, 4 (1985), pp. 436–451.
[2] Shampine, L. F. and M. E. Hosea, “Analysis and Implementation of TR-BDF2,” Applied Numerical Mathematics 20, 1996.
バージョン履歴
R2006a より前に導入