ode45 or dsolve

8 visualizzazioni (ultimi 30 giorni)
felik kamwera
felik kamwera il 24 Giu 2019
Commentato: felik kamwera il 24 Giu 2019
whats wrong with my code.. its from a book but cant run
tspan=[0 4];
y0=[0.02;0];
[t,y]=ode45('unforced1',tspan,y0);
plot(t,y(:,1));
grid on
xlabel(time)
ylabel(Displacement)
title(Displacement Vs Time)
hold on;
its function is function yp = unforced1(t,y)
yp = [y(2);(-((c/m)*y(2))-((k/m)*y(1)))];
  4 Commenti
Chinmay Anand
Chinmay Anand il 24 Giu 2019
What are c and m defined in your function ? Have you assigned any values to them ?
felik kamwera
felik kamwera il 24 Giu 2019
should i give them values in the function definition or call?

Accedi per commentare.

Risposta accettata

madhan ravi
madhan ravi il 24 Giu 2019
tspan=[0 4];
y0=[0.02;0];
m=5;
k=1000;
c=1000;
[t,y]=ode45(@(t,y)unforced1(t,y,c,m,k),tspan,y0); % function call
plot(t,y(:,1));
grid on
xlabel('time')
ylabel('Displacement')
title('Displacement Vs Time')
%function definition
function yp = unforced1(t,y,c,m,k) % if your version is prior to 2016b save this in a separate file name unforced1.m
yp = [y(2);
(-((c/m)*y(2))-((k/m)*y(1)))];
end
  1 Commento
felik kamwera
felik kamwera il 24 Giu 2019
thank u very much...i have seen where i was wrong..again thank u

Accedi per commentare.

Più risposte (0)

Community Treasure Hunt

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

Start Hunting!

Translated by