【Simulink系列】——动态系统仿真 之 离散系统线性离散系统

2024-02-04 18:36

本文主要是介绍【Simulink系列】——动态系统仿真 之 离散系统线性离散系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、离散系统定义

离散系统是指系统的输入与输出仅在离散的时间上取值,而且离散的时间具有相同的时间间隔。满足下列条件:

①系统(的输入输出)每隔固定时间间隔才更新一次。固定时间间隔称为采样时间。

②系统的输出依赖当前的输入、以往的输入和输出见数学描述

③系统具有离散的状态。状态是指系统前一时刻的输出量。

设系统的输入变量为u\left(n T_s\right), n=0,1,2, \cdots,其中n为采样时刻,Ts为系统的采样时间。由于Ts为固定值,因而系统输入u\left(n T_s\right)常被记为u(n)。设系统输出为y(nTs),也可记为y(n),则离散系统的数学描述为:

y(n)=f(u(n), u(n-1), \cdots, y(n-1), y(n-2), \cdots)

注:离散系统初始状态的确定非常重要。

二、离散Simulinlk仿真

有一个人口变化系统。设某一年的人口数目为p(n),其中n表示年份,它与上一年的人口数目p(n-1)、人口繁殖速率r以及新增资源所能满足的个体数目K之间的动力学模型如下差分方程:

p(n)=r p(n-1)\left[1-\frac{p(n-1)}{K}\right]

此差分方程可看出系统为非线性离散系统。设人口初始值p(0)=600000,人口繁殖速率r为1.08,新增资源满足个体数K=200000,建立Simulink模型,分析人口数目的变化趋势。

(1)建立系统模型

Unit Delay为单位延迟模块,主要功能是将输入信号延迟一个采样时间,这里将p(n)作为它的输入以得到p(n-1)。

(2)模块参数设置

人口繁殖速率r:取1.08,
1/K:取1/2000000,
Unit Delay的初始值为初始人口数目:取600000。

(3)仿真参数设置

仿真时间0~50s,求解器设置为discrete离散,即需要使用离散求解器;仿真步长选择Fixed-step定步长。

(4)仿真运行

注:若离散系统中所有模块的采样时间均相同,则此系统为单速率离散系统(选定步长求解器),否则为多速率离散系统(选变步长仿真更好)。

三、线性离散系统定义

在离散系统中,线性离散系统具有重要的地位。当离散系统同时满足齐次性和叠加性时,即:

T\left\{\alpha u_{1}(n)+\beta u_{2}\left(n\right)\right\}=\alpha T\left\{u_{1}\left(n\right)\right\}+\beta T\left\{u_{2}\left(n\right)\right\}

此离散系统称为线性离散系统。最一般的数学描述为:

y(n)=f\bigl(u(n),u(n-1),\cdots;y(n-1),y(n-2),\cdots\bigr)

也可用差分方程描述(上为状态方程,下为输出方程):

\begin{array}{rl}&x(n+1)=f\big(x(n),u(n),n\big)\\&y(n)=g\big(x(n),u(n),n\big)\end{array}

除了上述两种方式,针对线性离散系统本身的特点,常使用Z变换来描述线性离散系统。Z变换时对离散信号进行分析的一个强有力工具,尤其线性离散系统

对于一个离散信号u(n),其Z变换为U\bigl(z\bigr)=\sum_{k=-\infty}^{\infty}u\bigl(k\bigr)z^{-k},一般离散系统的时间大于0,则Z变换为U\bigl(z\bigr)=\sum_{k=0}^{\infty}u\bigl(k\bigr)z^{-k},简记为U(z)=Z\left\{u(n)\right\}

利用离散信号的Z变换结果得到原离散信号的过程,叫做Z变换的逆变换,简记为u\left(z\right)=Z^{-1}\left\{U(n)\right\}

Z变换有两个重要性质

①Z变换同时满足齐次性和叠加性。

Z\left\{\alpha u_{1}\left(n\right)+\beta u_{2}\left(n\right)\right\}=\alpha Z\left\{u_{1}\left(n\right)\right\}+\beta Z\left\{u_{2}\left(n\right)\right\}

②若u(n)的Z变换为U(z),则u(n-1)的Z变换为z^{-1}U(z)

四、线性离散系统Simulink仿真

低通滤波器模型。它可以滤除信号中的高频部分,以获取信号中有用的低频信号,一个低通数字滤波器的差分方程如下:

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

其中u(n)为滤波器输入,y(n)为滤波器输出。可见其为线性离散系统。

(1)Z变换

对该滤波器系统的差分方程进行Z变换,可得下面描述:

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

(2)建立系统模型

发送方首先使用高频正弦波(载波)对一低频锯齿波(原信号波)进行幅度调制,然后在无损信道中传递此幅度调制信号;接受方在接收到幅度调制信号后,首先进行解调,然后使用低通数字滤波器对解调后的信号进行滤波以获得低频锯齿波信号

Sine Wave用来产生高频载波信号,Sine Wave1用来产生解调信号;

Signal Generator产生低频锯齿波信号;

Discrete Filter表示数字滤波器。

(3)模块参数设置

高频载波(Sine Wave)频率设置为1000rad/sec,其余默认;Signal Generator波形选择锯齿波sawtooth,其余默认;解调正弦波(Sine Wave1)频率也为1000rad/sec,采样时间0.005s。

Discrete Filter设置如下:

注:数字滤波器的采样时间应该与解调信号的采样时间一致。

(4)仿真参数设置

仿真时间0~10s,选择求解器并设置为Variable-step变步长ode45(Dormand-Prince),最大步长设置为0.005

(5)仿真运行

数字滤波器的输出信号与原始锯齿信号并不完全一致,存在一定失真,这种失真不可避免,因为实际上并不存在理想的滤波器,调制时信号之间不可避免会相互干扰。

疑问:博友们,这里遇到各问题,锯齿波的scope显示周期与设定的信号周期不一致???

往期精彩

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

这篇关于【Simulink系列】——动态系统仿真 之 离散系统线性离散系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/678442

相关文章

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

MyBatis-Plus使用动态表名分表查询的实现

《MyBatis-Plus使用动态表名分表查询的实现》本文主要介绍了MyBatis-Plus使用动态表名分表查询,主要是动态修改表名的几种常见场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录1. 引入依赖2. myBATis-plus配置3. TenantContext 类:租户上下文

Java中的随机数生成案例从范围字符串到动态区间应用

《Java中的随机数生成案例从范围字符串到动态区间应用》本文介绍了在Java中生成随机数的多种方法,并通过两个案例解析如何根据业务需求生成特定范围的随机数,本文通过两个实际案例详细介绍如何在java中... 目录Java中的随机数生成:从范围字符串到动态区间应用引言目录1. Java中的随机数生成基础基本随

C++简单日志系统实现代码示例

《C++简单日志系统实现代码示例》日志系统是成熟软件中的一个重要组成部分,其记录软件的使用和运行行为,方便事后进行故障分析、数据统计等,:本文主要介绍C++简单日志系统实现的相关资料,文中通过代码... 目录前言Util.hppLevel.hppLogMsg.hppFormat.hppSink.hppBuf

基于Nacos实现SpringBoot动态定时任务调度

《基于Nacos实现SpringBoot动态定时任务调度》本文主要介绍了在SpringBoot项目中使用SpringScheduling实现定时任务,并通过Nacos动态配置Cron表达式实现任务的动... 目录背景实现动态变更定时机制配置化 cron 表达式Spring schedule 调度规则追踪定时

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S

linux系统中java的cacerts的优先级详解

《linux系统中java的cacerts的优先级详解》文章讲解了Java信任库(cacerts)的优先级与管理方式,指出JDK自带的cacerts默认优先级更高,系统级cacerts需手动同步或显式... 目录Java 默认使用哪个?如何检查当前使用的信任库?简要了解Java的信任库总结了解 Java 信

Python动态处理文件编码的完整指南

《Python动态处理文件编码的完整指南》在Python文件处理的高级应用中,我们经常会遇到需要动态处理文件编码的场景,本文将深入探讨Python中动态处理文件编码的技术,有需要的小伙伴可以了解下... 目录引言一、理解python的文件编码体系1.1 Python的IO层次结构1.2 编码问题的常见场景二

Oracle数据库在windows系统上重启步骤

《Oracle数据库在windows系统上重启步骤》有时候在服务中重启了oracle之后,数据库并不能正常访问,下面:本文主要介绍Oracle数据库在windows系统上重启的相关资料,文中通过代... oracle数据库在Windows上重启的方法我这里是使用oracle自带的sqlplus工具实现的方