フィルターのクリア

How do I solve a system of equations?

1 回表示 (過去 30 日間)
Julian Laackmann
Julian Laackmann 2012 年 8 月 14 日
Hello,
suppose I've got four equations which depend on one another and one of them depends on the time:
a = f(b);
b = f(c);
c = f(d);
d = f(a,t);
How can a system like this be solved? I thought about using one of the ode solvers but failed to implement the functions. Can anybody give me a hint?
Thanks in advance,
J
  1 件のコメント
Walter Roberson
Walter Roberson 2012 年 8 月 15 日
I am confused about you using f() with one argument in most places, but using it with two arguments for "d".

サインインしてコメントする。

採用された回答

Isktaine
Isktaine 2012 年 8 月 14 日
編集済み: Isktaine 2012 年 8 月 14 日
You need to have a function which the ode solvers can act on.
[t,y] = ode45('YourODEFunction', [0 50], [a(0) b(0) c(0) d(0)])
An example of how to create the function:
function dA=YourODEFunction(x,A)
dA(1)=f(b); %Equation for a,
dA(2)=f(c); %Equation for b
dA(3)=f(d); %Equation for c
dA(4)=f(a,t); %Equation for d
dA=dA'
Note that when you have f(b) (and all the others) you'd have to type in an experission eg
dA(1)=3*A(2) %Coding up of a=3*b
Any time your equation would have a 'b' use A(2), any time you would use an 'a' use A(1), any time you would use a 'c' use A(3) and 'd' use A(4). Does that make sense?
  5 件のコメント
Isktaine
Isktaine 2012 年 8 月 17 日
I'm sorry! I think I misunderstood your first question then. I was assuming all of these were differentials i.e. a'=f(b). How silly of me to make that assumption! Are any of the equations actually differentials?
If there are no differentials then you have to uncouple the system before it can solved numerically. You could just use direct substitution to solve them by hand to get one equation for d only in terms of t, the use back substitution to find values for c,b and a once you have d for any t.
Julian Laackmann
Julian Laackmann 2012 年 9 月 11 日
Isktaine,
thank you very much! Uncoupling the equations did the trick.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeOrdinary Differential Equations についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by