当前位置: 首页 > news >正文

【Simulink系列】——动态系统仿真 之 混合系统

声明:本系列博客参考有关专业书籍,截图均为自己实操,仅供交流学习!

一、混合系统概述

由不同类型系统共同构成的系统称为混合系统!仿真时必须考虑连续信号和离散信号的采样匹配问题,一般使用变步长连续求解器!不同类型信号、不同采样时间信号可用如下颜色显示:

仿真时变步长求解器可不时地调整仿真步长以匹配离散信号的采样时间

二、混合仿真示例1:通信系统

(1)物理模型&数学描述

①信源

通信系统需要传递的信号,这里使用单位幅值、单位频率的锯齿波。

②调制与解调

调制信号为正弦连续信号(幅值1,频率100Hz);

解调信号为正弦离散信号(幅值1,频率100Hz,采样时间为0.005s);

并采用双边带抑制载波调制与解调。调制:output=input x carrier,其中input为低频信号,carrier为高频载波信号,output为幅度调制信号;解调:output=input x carrier,其中input为信道传递的信号,carrier为解调信号,output为幅度解调信号。

③信道

信道的动态方程为10^{-9}\ddot{y}+10^{-3}\dot{y}+y=u。其中u为信道输入,y为信道输出,显然为一条线性连续信道,信道的传递函数为:

\frac{Y\bigl(s\bigr)}{U\bigl(s\bigr)}=\frac{1}{10^{-9}s^{2}+10^{-3}s+1}

信道噪声random number模块产生,为服从高斯正态分布的随机性干扰,均值为0,方差为0.01。

信道延迟:信道经过缓冲区为1024的延迟,用Transport Delay模块实现。

④数字滤波器

数字滤波器的差分方程如下,为一个线性离散系统

y(n)-1.6y(n-1)+0.7y(n-2)=0.04u(n)+0.08u(n-1)+0.04u(n-2)

使用Z变换变为如下形式:

\frac{Y(z)}{U(z)}=\frac{0.04+0.08z^{-1}+0.04z^{-2}}{1-1.6z^{-1}+0.7z^{-2}}

(2)Simulink模型

首先回顾下在线性离散系统中我们做的简单的信号调制和解调模型,以作对比:

这里的混合系统如下:

(3)封装成子系统

可以用subsystem模块进行封装,这里只有示意图不再演示:(信号解调最后的discrete filter模块是数字滤波器)

(4)模块与仿真参数设置

根据物理模型&数学描述进行设置。Transport Delay的初始缓冲区设置为1024;Transfer Fcn根据信道动态方程设置,分子[1],分母[1e-9 1e-3 1];discrete filter模块根据数字滤波器Z变换式子设置,分子[0.04 0.08 0.04],分母[1 -1.6 0.7],采样时间0.005s。其他根据上面描述设置,此处不赘述。

仿真器用变步长连续求解器,其他根据需要。

(5)仿真运行

结果不佳,还是之前在线性离散系统仿真中遇到的问题,设定的锯齿波频率为1,但是scope显示却不是?如果有会的博友,请多多指教!

三、混合仿真示例2:汽车行驶控制

系统基本要点:

①操作机构的不同位置对应汽车不同的位置;

②测量汽车当前速度,并与设置的期望速度作差;

③由速度差值信号得到驱动牵引力大小,做到反馈控制。

(1)物理模型&数学描述

①速度操作机构的位置变换器

作用是将操纵机构的位置转换为相应的速度:

v=30x+50,x\in[0,1]

②离散行驶控制器

作用是根据速度差值产生相应的牵引力,典型的PID控制器:

其中u为输入,y为输出,x为系统中的状态。

③动力机构

作用是在牵引力作用下改变速度使其达到指定值:

F=m\dot{v}+bv

其中m为汽车质量1500kg,b为阻力因子取23。

(2)Simulink模型

Slider Gain模块用于限制位置变换器的输入信号x的范围;Unit Delay模块输入为x(n),输出为x(n-1);Unit Delay1模块输入为u(n),输出为u(n-1)。

(3)模块与仿真参数设置

Slider Gain模块最小值0,最大值1,初始值0.5;Unit Delay模块初始状态0,采样时间0.02s;PID的增益分别为1、0.003、0.01;其他参数增益如下图:

仿真器采用变步长连续求解器

(4)仿真运行

增加微分项增益可减小超调量,缩短系统调节时间;增加积分项增益可增加超调量,延长调节时间;增加比例项增益也可缩短系统调节时间。

 往期精彩

STM32专栏(付费9.9)icon-default.png?t=N7T8http://t.csdnimg.cn/E2F88

OpenCV-Python专栏(付费9.9)icon-default.png?t=N7T8http://t.csdnimg.cn/zK1jV

AI底层逻辑专栏(付费9.9)icon-default.png?t=N7T8http://t.csdnimg.cn/zic0f

机器学习专栏(免费)icon-default.png?t=N7T8http://t.csdnimg.cn/FaXzAFreeRTOS专栏(免费)icon-default.png?t=N7T8http://t.csdnimg.cn/SjIqU电机控制专栏(免费)icon-default.png?t=N7T8http://t.csdnimg.cn/FNWM7 

http://www.lryc.cn/news/306478.html

相关文章:

  • PHP中的飞碟运算符、取反运算符、对比非ASCII字符串、对比浮点数操作
  • unity-unity2d基础操作笔记(二)0.5.0
  • Feign远程调用(学习笔记)
  • pytorch建模的三种方式
  • GO-ICP的使用(一)
  • FPS游戏漫谈System.GC.Collect()强制进行垃圾回收
  • 第3集《灵峰宗论导读》
  • java面试设计模式篇
  • 桥接模式:解耦抽象与实现,实现灵活多变的扩展结构
  • HUAWEI Programming Contest 2024(AtCoder Beginner Contest 342)
  • Heap sorting
  • 开源模型应用落地-qwen2模型小试-入门篇(六)
  • c#程序,oracle使用Devart驱动解决第第三方库是us7ascii,数据乱码的问题
  • 代码随想录算法训练营第四一天 | 背包问题
  • AIDL的工作原理与使用示例 跨进程通信 远程方法调用RPC
  • K8S部署Java项目 pod报错 logs日志内容:no main manifest attribute, in app.jar
  • SQL实现模糊查询的四种方法总结
  • 爬虫基本库的使用(urllib库的详细解析)
  • 【PyQt5桌面应用开发】3.Qt Designer快速入门(控件详解)
  • react useMemo 用法
  • python学习笔记 - 标准库函数
  • 校招失败后,在小公司熬了 2 年终于进了字节跳动,竭尽全力....
  • PYTHON-使用正则表达式进行模式匹配
  • Fiddler工具 — 19.Fiddler抓包HTTPS请求(二)
  • 架构设计:流式处理与实时计算
  • Linux系统安装zookeeper
  • 【前端素材】推荐优质后台管理系统Modernize平台模板(附源码)
  • 二、Vue组件化编程
  • JVM跨代引用垃圾回收
  • AI:135-基于卷积神经网络的艺术品瑕疵检测与修复