
Matlab Simulink - How to simulation this math?
6 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens

0 commentaires
Réponses (1)
Ameer Hamza
le 6 Nov 2020
Modifié(e) : Ameer Hamza
le 6 Nov 2020
You need to use ode45(): https://www.mathworks.com/help/matlab/ref/ode45.html . Convert your 2nd order ODE into a system of 2 first-order ODEs. The following code assumes F(t)=1.
tspan = [0 10];
IC = [0; 0]; % initial condition
[t, X] = ode45(@odeFun, tspan, IC);
plot(t, X, '-o')
legend({'$x$', '$\dot{x}$'}, 'FontSize', 16, 'Interpreter', 'latex', 'Location', 'best')
function dxdt = odeFun(t, x)
c = 2;
k = 1;
m = 5;
F = 1;
dxdt = zeros(2,1);
dxdt(1) = x(2);
dxdt(2) = (F - c*x(2) - k*x(1))/m;
end

0 commentaires
Voir également
Catégories
En savoir plus sur Ordinary Differential Equations dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!