Consider the following symbolic ODE:
syms gamma(t)
C1 = 2.4
C2 = 3.1
ode = diff(gamma, t, 2) == C1 * sin(gamma) + C2 * cos(diff(gamma))
Now, I want to convert the above expression to the function odefun which I can use with ode45:
function res = odefun(t, gamma)
res = [gamma(2);
2.4*sin(gamma(1)) + 3.1*cos(gamma(2))]
end
Are there ways to automate (parts of) this process? The above ode is only a simple example to illustrate my problem. The ode I'm really trying to solve has way more terms with coefficients.
Thanks

 채택된 답변

Star Strider
Star Strider 2021년 11월 11일

0 개 추천

Try something like this —
syms gamma(t) T Y
C1 = 2.4
C1 = 2.4000
C2 = 3.1
C2 = 3.1000
ode = diff(gamma, t, 2) == C1 * sin(gamma) + C2 * cos(diff(gamma))
ode(t) = 
[VF,Subs] = odeToVectorField(ode)
VF = 
Subs = 
odefun = matlabFunction(VF, 'Vars',{T,Y})
odefun = function_handle with value:
@(T,Y)[Y(2);cos(Y(2)).*(3.1e+1./1.0e+1)+sin(Y(1)).*(1.2e+1./5.0)]
ic = [0 1];
tspan = [0 10];
[t,omega] = ode45(odefun, tspan, ic);
figure
plot(t, omega)
grid
legend(string(Subs), 'Location','best')
The constants do not have to be specified in the original equations. They can be included as parameters, so for example —
syms gamma(t) T Y C1 C2
ode = diff(gamma, t, 2) == C1 * sin(gamma) + C2 * cos(diff(gamma))
odefun = matlabFunction(VF, 'Vars',{T,Y, [C1,C2]})
ic = [0 1];
tspan = [0 10];
CV = rand(1,2)
[t,omega] = ode45(@(t,omega)odefun(t,omega,CV), tspan, ic);
Now they can be changed in the numeric code (for example in a loop or nested loops) without having to re-derive them each time in the original symbolic code.
.

댓글 수: 2

Clemens Herrmann
Clemens Herrmann 2021년 11월 12일
Thanks a lot, works like a charm!
Star Strider
Star Strider 2021년 11월 12일
As always, my pleasure!
.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

도움말 센터File Exchange에서 Symbolic Math Toolbox에 대해 자세히 알아보기

제품

릴리스

R2021b

질문:

2021년 11월 11일

댓글:

2021년 11월 12일

Community Treasure Hunt

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

Start Hunting!

Translated by