1.问题
data:image/s3,"s3://crabby-images/5cd1f/5cd1f74130d4310ab550b190d9ea8e5ba1b0087e" alt=""
data:image/s3,"s3://crabby-images/9cccb/9cccb37f15c4e5af9c091d17d5fe40701c5c32aa" alt=""
2.运动方程
Step1: 将微分方程最高阶变量移到等式左边
data:image/s3,"s3://crabby-images/0d0b3/0d0b38caed3591438decff32d5f76cf0841f201a" alt=""
Step2: 为每一阶微分式选择状态变量,最高阶除外
2.1
'
''
...
data:image/s3,"s3://crabby-images/8a0f3/8a0f3f8a1764b4a80f45cf1c6baf7a355c4e687f" alt=""
2.2: 同时求导
2.3:整理为形式,各阶微分式替换为状态变量
3.1 Matlab 求解代码与结果
clear;clc;
tic
options = odeset('reltol',1e-13);
tspan = [0,80];
[tspan,x]=ode45(@vibration,tspan,[1 1],options);
toc
figure
plot(tspan,x(:,1),tspan,x(:,2));
legend('Position','Acceleration')
%Time Domain
fig = figure('Name','Position');
plot(x(:,1))
%Purpose Function
function dxdt = vibration(~ ,x)
%for t= 0:0.01:40
%f = cos(10*t);
f=0;
c = 0.3;
k = 5;
m = 1;
dxdt = [0;0];
dxdt(1) = x(2);
dxdt(2) =(1/m)*( f - c*x(2) - k*x(1));
end
data:image/s3,"s3://crabby-images/16627/16627e1a1b496166d19f0e097f00de2af4a7a3b4" alt=""
3.2 Simulink程序图与结果
data:image/s3,"s3://crabby-images/44a60/44a60da3e5025c6401ee1bf8c4c151a9073cc84d" alt=""
Scope显示为:
data:image/s3,"s3://crabby-images/42c03/42c0314d779a8dedf333b630dd2fdcc81839a267" alt=""
网友评论