Problem with second order ODE solver

Hello everybody,
I'm trying to solve the following equation: y" = sin(y) - (1/t)*y'
I write down the following code for solving the equation but the output does not show anything, do i miss something here?
syms y(t)
[V] = odeToVectorField(diff(y, 2) == sin(y)-(1/t)*diff(y))
M = matlabFunction(V,'vars', {'t','Y'})
sol = ode45(M,[0 30],[5.71 0])
fplot(@(x)deval(sol,x,1), [0, 30])
I really appreciate your help!
Thanks.

답변 (1개)

Star Strider
Star Strider 2017년 5월 9일

1 개 추천

The problem is having ‘t’ to include 0 and having ‘t’ in the denominator. This creates a ‘0/0’ condition that equates to NaN, and tha then propagates throughout the integration of your ODE.
The easiest way to avoid that problem is to ‘cheat’, and use eps instead of 0.
This works:
syms y(t)
[V] = odeToVectorField(diff(y, 2) == sin(y)-(1/t)*diff(y))
M = matlabFunction(V,'vars', {'t','Y'})
[T,Y] = ode45(M,[eps 30],[5.71 0]);
figure(1)
plot(T, Y)
grid

댓글 수: 2

Yas
Yas 2017년 5월 10일
편집: Yas 2017년 5월 10일
Thank you very much! Yes it worked. However I have one more question: 1. why the new code generates to separate plots (orange and blue)? I mean the solution to this eq should be one right?
My pleasure!
There are two outputs (columns) in ‘Y’, ‘Y(:,1)’ (the derivative) and ‘Y(:,2)’, the solved equation. If you only want the solved equation, the plot changes to:
figure(1)
plot(T, Y(:,2))
grid

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

태그

질문:

Yas
2017년 5월 9일

댓글:

2017년 5월 10일

Community Treasure Hunt

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

Start Hunting!

Translated by