MATLAB の ODE ソルバーを使用して解く必要のある微分方程式がいくつかあります。微分方程式自体はかなり単純ですが、多くの「定数」に依存しています。これらの定数は普遍的ではなく、呼び出し元が提供する必要があります。
この種の ODE の例は次のようになります。
dx/dt = -j * (k + x) ./ (l + x)
ここで、j、k、l は定数で、x は変数です。
私がこれまでにこれらを解決してきた方法は、すべての初期値と定数のすべての値 (約 10 個あります) を引数として取り、次に内部の「ステップ」関数を呼び出す関数を使用することです。 MATLAB が ODE ソルバーに期待する形式のベクトル。そう...
function [outputVector] = someFunction(x, y, j, k, l, m, n, o)
function [output] = someFunctionStep(t, inputVector)
x = inputVector(1);
y = inputVector(2);
dx = -j .* (k + x) ./ (l + x);
dy = -m .* (n + y) ./ (o + y);
output = [dx;dy]
end
outputVector = ode15s(@someFunctionStep, [0, endTime], [x,y]);
end
ただし、変数の数とコードのサイズが大きくなるにつれて、これはますます洗練されなくなり、ほとんど判読できないコードの混乱が生じます。したがって、私がやりたいことは、a) 入力ベクトルのステップ関数に定数を渡すか、b) グローバル変数を使用することなく、各システムのステップ関数を独自のファイルに移動することです。これを行う合理的な方法はありますか、それとも単にそれを吸い上げて醜いコードを書くべきですか?