在MATLAB中分别用数值计算、符号计算和Simulink仿真方法求解方程: 𝑥′′+0.2𝑥′+0.4𝑥=0.2𝑢(𝑡),其中u(t)是单位阶跃函数。 x(0)=0 and x′(0)=0
时间: 2024-06-08 16:12:49 浏览: 114
数值计算方法:
首先将二阶微分方程转换为一阶微分方程组:
$\begin{cases} x_1' = x_2 \\ x_2' = -0.4x_1 - 0.2x_2 + 0.2u(t) \end{cases}$
其中 $x_1 = x$,$x_2 = x'$。
然后采用欧拉法进行数值计算,MATLAB代码如下:
```
function [t,x] = numerical_solve()
h = 0.001; % 步长
t = 0:h:10; % 时间范围
x = zeros(2,length(t)); % 初始化
x(:,1) = [0;0]; % 初值
for i = 2:length(t)
u = 0.2*(t(i)>0); % 单位阶跃函数
x(:,i) = x(:,i-1) + h*[x(2,i-1); -0.4*x(1,i-1)-0.2*x(2,i-1)+0.2*u];
end
end
```
符号计算方法:
采用MATLAB的符号计算工具箱,代码如下:
```
syms x(t) u(t)
Dx = diff(x,t);
ode = diff(x,t,2) + 0.2*Dx + 0.4*x == 0.2*u;
cond = [x(0) == 0, Dx(0) == 0];
xSol(t) = dsolve(ode, cond);
u(t) = heaviside(t); % 单位阶跃函数
ezplot(xSol,[0,10]);
```
Simulink仿真方法:
建立Simulink模型,将二阶微分方程转换成一阶微分方程组,模型如下图所示:
data:image/s3,"s3://crabby-images/8f7a8/8f7a826748c7a20ca53d741b819a34091221553d" alt="Simulink模型"
其中,Subsystem1用于计算状态方程,Subsystem2用于计算输出方程,Step用于产生单位阶跃函数,Scope用于显示结果。
MATLAB代码如下:
```
open_system('simulink_solve')
sim('simulink_solve', [0, 10]);
```
三种方法求解的结果如下图所示:
data:image/s3,"s3://crabby-images/2a16a/2a16a2d7ae3611bbfe939839f6ba715f02a51ac8" alt="结果对比"
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/48ecf/48ecfff65b0229a65d66a94d53c67b4ec0248998" alt="docx"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"