How to use ODE45 to solve 2nd order differential equation with random variables in it?
2 ビュー (過去 30 日間)
古いコメントを表示
In Quarter car model equations, (see above attached file for skematic model)
data:image/s3,"s3://crabby-images/9e5a9/9e5a987e27fc7d49dbc005ac7277e041e0fd925a" alt=""
data:image/s3,"s3://crabby-images/536ff/536fff57f03a05d3e750ba62d4bed00557b24db7" alt=""
where
data:image/s3,"s3://crabby-images/2b230/2b230203740a235fa3b492ffabd45a1d68361e53" alt=""
data:image/s3,"s3://crabby-images/f1d5d/f1d5d64bc1e6aef94098925420b166e863a85072" alt=""
data:image/s3,"s3://crabby-images/16384/16384d87d0799ff1aae53e9298b9517dab940fe1" alt=""
data:image/s3,"s3://crabby-images/71a62/71a628f2d7bbf15ebae7febcbdcb93f8934db3bf" alt=""
data:image/s3,"s3://crabby-images/5739f/5739fedbcf15e40cef6997ef74002910895853b5" alt=""
data:image/s3,"s3://crabby-images/4adaf/4adafe19ce98ad7f5c0a940e822cf347b4683224" alt=""
data:image/s3,"s3://crabby-images/30579/30579d5d57ca7710f348ad19cf7f54aba535e8ff" alt=""
data:image/s3,"s3://crabby-images/0d8db/0d8dbc46e9a07d3ae4381f569490a490c6a00965" alt=""
data:image/s3,"s3://crabby-images/6f870/6f870eace29a99137bbea07f65e61afae841b350" alt=""
how could i apply this random variables to the equations by using ode45 ?
I have done for one sample, any hint to simulate for 100 samples.
dt = 0.01;
tf = 30;
tspan = dt:dt:tf;
y0 = [0;100;0;10];
[t,y] = ode45('eqsystem',tspan,y0);
plot(y(:,1))
grid
xlabel('X-Displacement')
ylabel('y-Displacement')
title('X vs Y Displacement')
hold on;
function dydt = eqsystem(t,y)
ks = 1000; % N/m^3 - Gaussian
ku = 1000; % N/m - Gaussian
ms = 10; % kg - Gaussian
mu = 20; % kg - Gaussian
c = 300; % Ns/m - Gaussian
A = 0.10; % m -
omega = 2*pi; % rad/s -
dydt = zeros(4,1);
dydt(1,:) = y(2);
dydt(2,:) = ((-ks/ms)* (y(1)-y(3))^3 - (c/ms)*(y(2)-y(4)));
dydt(3,:) = y(4);
dydt(4,:) = ((ks/mu)*(y(1)-y(3))^3 + (y(2)-y(4)) + ku*(A*sin(omega*t) - y(3)));
end
2 件のコメント
採用された回答
Jan
2021 年 6 月 6 日
dt = 0.01;
tf = 30;
tspan = dt:dt:tf;
y0 = [0;100;0;10];
for k = 1:100
ms = 10 + randn;
mu = 20 + randn * 2;
...
fcn = @(t, y) eqsystem(t, y, ms, mu, ...)
[t, y] = ode45('eqsystem',tspan,y0);
end
function dydt = eqsystem(t, y, ms, mu, ...)
dydt = zeros(4,1);
dydt(1) = y(2);
dydt(2) = (-ks / ms) * (y(1) - y(3))^3 - (c/ms) * (y(2) - y(4));
dydt(3) = y(4);
dydt(4) = (ks / mu) * (y(1) - y(3))^3 + (y(2) - y(4)) + ...
ku * (A * sin(omega * t) - y(3));
end
その他の回答 (0 件)
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!