I'm a using matlab for the first time and my code has 2 errors which I don't know how to remove can you please take a look it is a 14 line code.

funtion sim_system tspan = 0:0.001:50; z0 = [1,0,sqrt(2),0]; [t,z]=ode45(@problem,tspan,z(0)); plot(t,z(:,1)); figure(); end
function zdot = problem(t,z) zdot = zeros(4,1); zdot(1)=z(2); zdot(2)=((2*sin(z(1))+(sin(z(1)-z(3))*z(4)*z(4))+(cos(z(1)-z(3))*sin(z(1)-z(3))*z(2)*z(2))-(cos(z(1)-z(3))*sin(z(3))))/((cos(z(1)-z(3))*cos(z(1)-z(3)))-2)); zdot(3)=z(4); zdot(4)=((-2*sin(z(1)-z(3))*z(2)*z(2))+(2*sin(z(3)))-(cos(z(1)-z(3))*sin(z(1)-z(3))*z(4)*z(4))+(2*cos(z(1)-z(3))*sin(z(1)))/((cos(z(1)-z(3))*cos(z(1)-z(3)))-2));

 Accepted Answer

Ahmed, two things. In the ode45 call replace z(0) by z0 (you need all four initial conditions, but possibly just a typo)
[t,z] = ode45(@problem,tspan,z0)
And two, close the function problem with an end statement.

1 Comment

There was one more error. I misspelled "function" in the first line. And thanks, your feedback really helped.

Sign in to comment.

More Answers (0)

Categories

Asked:

on 15 Mar 2014

Commented:

on 15 Mar 2014

Community Treasure Hunt

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

Start Hunting!