simulink离散传递函数得到差分方程并用C语言实现

一. 创建连续时间的传递函数

G ( s ) = s 2 + 217 s s 2 + 384 s + 8989 G(s) = \frac{s^2+217s}{s^2+384s+8989} G(s)=s2+384s+8989s2+217s

二. 离散连续时间的传递函数G(s)

2.1 在matlab中用c2d函数双线性变换法离散G(s),

下面是matlab脚本代码

% 创建连续时间传递函数
num = [1 217 0];
den = [1 384 8989];
sys_c = tf(num, den);
% 设置采样时间
Ts = 0.001;
% 离散化传递函数(使用 tustin 方法)
sys_d = c2d(sys_c, Ts, 'tustin');
sys_d
% 查看离散化后的传递函数
disp('离散化后的传递函数:');
disp(sys_d);

2.2 matlab命令行显示结果

运行上面脚本代码后,matlab命令行显示的结果如下图,得到离散传递函数为
H ( z ) = 0.9282 z 2 − 1.6747 z + 0.7465 z 2 − 1.6709 z + 0.6785 H(z) = \frac{0.9282z^2-1.6747z+0.7465}{z^2-1.6709z+0.6785} H(z)=z21.6709z+0.67850.9282z21.6747z+0.7465
在这里插入图片描述
- z 的正幂形式

所有项均乘以最高次幂 z 2 z^2 z2(即将负幂形式清理为正幂形式)
常用于标准传递函数表达中,这样便于与连续系统的形式类比
H ( z ) = 0.9282 z 2 − 1.6747 z + 0.7465 z 2 − 1.6709 z + 0.6785 H(z) = \frac{0.9282z^2-1.6747z+0.7465}{z^2-1.6709z+0.6785} H(z)=z21.6709z+0.67850.9282z21.6747z+0.7465
- z 的负幂形式

所有项均除以最高次幂 z 2 z^2 z2,即 z − 1 z^{-1} z1 表示一个采样时刻的延迟, z − 2 z^{-2} z2 表示两个采样时刻的延迟,
常用于传递函数的数字实现分析中,与差分方程直接相关
H ( z ) = 0.9282 − 1.6747 z − 1 + 0.7465 z − 2 1 − 1.6709 z − 1 + 0.6785 z − 2 H(z) = \frac{0.9282-1.6747z^{-1}+0.7465z^{-2}}{1-1.6709z^{-1}+0.6785z^{-2}} H(z)=11.6709z1+0.6785z20.92821.6747z1+0.7465z2

三. 求出离散传递函数H(z)的差分方程

离散传递函数的标准形式

H ( z ) = Y ( z ) U ( z ) = b 0 + b 1 z − 1 + b 2 z − 2 1 + a 1 z − 1 + a 2 z − 2 H(z) = \frac{Y(z)}{U(z)}= \frac{b_0+b_1z^{-1}+b_2z^{-2}}{1+a_1z^{-1}+a_2z^{-2}} H(z)=U(z)Y(z)=1+a1z1+a2z2b0+b1z1+b2z2
其中:

  • Y(z) 和 𝑈(𝑧) 是输出和输入信号的 Z 变换

  • b 0 b_0 b0, b 1 b_1 b1, b 2 b_2 b2是传递函数分子(与输入信号的关系)

  • a 1 a_1 a1, a 2 a_2 a2是传递函数分母(与输出信号的关系)

3.1 求解传递函数的负幂形式得到差分方程Y(z)

Y ( z ) U ( z ) = 0.9282 − 1.6747 z − 1 + 0.7465 z − 2 1 − 1.6709 z − 1 + 0.6785 z − 2 \frac{Y(z)}{U(z)}= \frac{0.9282-1.6747z^{-1}+0.7465z^{-2}}{1-1.6709z^{-1}+0.6785z^{-2}} U(z)Y(z)=11.6709z1+0.6785z20.92821.6747z1+0.7465z2

  • 去掉分母

Y ( z ) ⋅ ( 1 − 1.6709 z − 1 + 0.6785 z − 2 ) = U ( z ) ⋅ ( 0.9282 − 1.6747 z − 1 + 0.6785 z − 2 ) Y(z) \cdot (1-1.6709z^{-1}+0.6785z^{-2}) = U(z) \cdot (0.9282-1.6747z^{-1}+0.6785z^{-2}) Y(z)(11.6709z1+0.6785z2)=U(z)(0.92821.6747z1+0.6785z2)

  • 左右两边同时展开

Y ( z ) − 1.6709 z − 1 Y ( z ) + 0.6785 z − 2 Y ( z ) = 0.9282 U ( z ) − 1.6747 z − 1 U ( z ) + 0.6785 z − 2 U ( z ) Y(z) -1.6709z^{-1}Y(z)+0.6785z^{-2}Y(z)= 0.9282U(z)-1.6747z^{-1}U(z)+0.6785z^{-2}U(z) Y(z)1.6709z1Y(z)+0.6785z2Y(z)=0.9282U(z)1.6747z1U(z)+0.6785z2U(z)

  • 移项得到Y(z)

Y ( z ) = 0.9282 U ( z ) − 1.6747 z − 1 U ( z ) + 0.6785 z − 2 U ( z ) + 1.6709 z − 1 Y ( z ) − 0.6785 z − 2 Y ( z ) Y(z) = 0.9282U(z)-1.6747z^{-1}U(z)+0.6785z^{-2}U(z)+ 1.6709z^{-1}Y(z) -0.6785z^{-2}Y(z) Y(z)=0.9282U(z)1.6747z1U(z)+0.6785z2U(z)+1.6709z1Y(z)0.6785z2Y(z)

3.2 将 z − 1 z^{-1} z1表示为时域延迟

从Z-变换的性质, z − 1 z^{-1} z1 表示信号延迟一个采样周期(即𝑘 → 𝑘−1)因此

  • z − 1 Y ( z ) z^{-1}Y(z) z1Y(z) 表示 y [ k − 1 ] y[k−1] y[k1]

  • z − 2 Y ( z ) z^{-2}Y(z) z2Y(z) 表示 y [ k − 2 ] y[k−2] y[k2]

  • 同理 z − 1 U ( z ) z^{-1}U(z) z1U(z) 表示 u [ k − 1 ] u[k−1] u[k1] z − 2 U ( z ) z^{-2}U(z) z2U(z) 表示 u [ k − 2 ] u[k−2] u[k2]

带入差分方程Y(z) 中的得到
Y ( z ) = 0.9282 u [ k ] − 1.6747 u [ k − 1 ] + 0.6785 u [ k − 2 ] + 1.6709 y [ k − 1 ] − 0.6785 y [ k − 2 ] Y(z) = 0.9282u[k]-1.6747u[k−1]+0.6785u[k−2]+ 1.6709y[k−1]-0.6785y[k−2] Y(z)=0.9282u[k]1.6747u[k1]+0.6785u[k2]+1.6709y[k1]0.6785y[k2]

四. 差分方程Y(z) 的C代码实现

  • u[k] :本次输入值

  • Y(z):本次输出值

MCU代码中带入u[k] 时,需乘以采样周期Ts
Y ( z ) = 0.9282 u [ k ] − 1.6747 u [ k − 1 ] + 0.6785 u [ k − 2 ] + 1.6709 y [ k − 1 ] − 0.6785 y [ k − 2 ] Y(z) = 0.9282u[k]-1.6747u[k−1]+0.6785u[k−2]+ 1.6709y[k−1]-0.6785y[k−2] Y(z)=0.9282u[k]1.6747u[k1]+0.6785u[k2]+1.6709y[k1]0.6785y[k2]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/64592.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

搭建私有链

文章目录 1. 准备工作2. 创建创世区块配置文件2.1 创建数据目录2.2 创建创世区块配置文件1. “config”部分2. “alloc”部分3. “coinbase”4. “difficulty”5. “extraData”6. “gasLimit”7. “nonce”8. “mixhash”9. “parentHash”10. “timestamp” 3. 初始化&#x…

AI Alignment: A Comprehensive Survey---治理

治理 除了技术解决方案之外,治理(规则的制定和执行)对于确保人工智能系统的安全开发和部署也是必不可少的。在本节中,我们将通过探索人工智能治理的作用、利益相关者在治理人工智能方面的功能和关系以及有效人工智能治理面临的若干…

CNN、RNN、LSTM和Transformer之间的区别和联系

文章目录 CNN、RNN、LSTM和Transformer之间的区别和联系前言CNN(卷积神经网络)RNN(循环神经网络)LSTM(长短期记忆网络)Transformer四者之间的联系与区别Yolo算法简介Yolo和CNN的关系YOLO各版本 CNN、RNN、L…

深度学习之超分辨率算法——FRCNN

– 对之前SRCNN算法的改进 输出层采用转置卷积层放大尺寸,这样可以直接将低分辨率图片输入模型中,解决了输入尺度问题。改变特征维数,使用更小的卷积核和使用更多的映射层。卷积核更小,加入了更多的激活层。共享其中的映射层&…

小程序UI自动化测试实践:Minium+PageObject !

小程序架构上分为渲染层和逻辑层,尽管各平台的运行环境十分相似,但是还是有些许的区别(如下图),比如说JavaScript 语法和 API 支持不一致,WXSS 渲染表现也有不同,所以不论是手工测试&#xff0c…

堆的深度剖析及使用

目录 1.堆的创建1.1初始化1.2销毁 2.堆的使用2.1数据插入2.2堆顶元素2.3数据删除 3.堆的难点3.1向上调整3.1.1视频分析向上调整3.1.2 代码分析 3.2向下调整3.2.1视频分析向下调整3.2.2代码分析 1.堆的创建 堆的物理储存方式其实是一个数组,而逻辑储存方式其实是一个…

Hu矩原理 | cv2中基于Hu矩计算图像轮廓相似度差异的函数cv2.matchShapes【小白记笔记】

Hu 矩(Hu Moments) 是一种用于描述轮廓形状的 不变特征。它基于图像的矩提取,经过数学变换得到 7 个不变矩,这些不变矩在图像 平移、旋转和缩放等几何变换下保持不变,适合用来衡量轮廓或形状的相似度差异。 1、图像矩…

计算无人机俯拍图像的地面采样距离(GSD)矩阵

引言 在无人机遥感、测绘和精细农业等领域,地面采样距离(Ground Sampling Distance,简称 GSD)是一个非常重要的指标。GSD 是指图像中每个像素在地面上实际代表的物理距离,通常以米或厘米为单位。GSD 决定了图像的空间…

浅谈怎样系统的准备前端面试

前言 创业梦碎,回归现实,7 月底毅然裸辞,苦战两个月,拿到了美团和字节跳动的 offer,这算是从业以来第一次真正意义的面试,遇到蛮多问题,比如一开始具体的面试过程我都不懂,基本一直是…

2009 ~ 2019 年 408【数据结构】大题解析

2009 年 讲解视频推荐:【BOK408真题讲解-2009年(催更就退网版)】 1. 图的应用(10’) 带权图(权值非负, 表示边连接的两顶点间的距离)的最短路径问题是找出从初始顶点到目标顶点之间…

时空AI赋能低空智能科技创新

随着人工智能技术的不断进步,时空人工智能(Spatio-Temporal AI,简称时空AI)正在逐渐成为推动低空经济发展的新引擎。时空AI结合了地理空间智能、城市空间智能和时空大数据智能,为低空智能科技创新提供了强大的数据支持…

Python读取Excel批量写入到PPT生成词卡

一、问题的提出 有网友想把Excel表中的三列数据,分别是:单词、音标和释义分别写入到PPT当中,每一张PPT写一个单词的内容。这种批量操作是python的强项,尤其是在办公领域,它能较好地解放双手,读取Excel表后…

Proteus(8.15)仿真下载安装过程(附详细安装过程图)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一、Proteus是什么? 二、下载链接 三、下安装步骤 1.解压,有键管理员运行 2.点击Next,进行下一步 3.勾选I accept…&#…

动态导出word文件支持转pdf

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、功能说明二、使用步骤1.controller2.工具类 DocumentUtil 导出样式 前言 提示:这里可以添加本文要记录的大概内容: 例如&#xff…

紧固件设计之——开槽六角头防脱出杆螺栓仿真APP

按照产品形态分类,紧固件通常包括以下12类:螺栓、螺柱、螺钉、螺母、自攻螺钉、木螺钉、垫圈、挡圈、销、铆钉、焊钉、组合件与连接副,是一类用于连接和固定各种构件和零部件的重要机械零件,可确保机械装置或设备结构的牢固和稳定…

mysql中与并发相关的问题?

今天我们来聊聊 MySQL 中与并发相关的一些问题。作为一名资深 Python 开发工程师,我觉得这些问题不仅关乎数据库的稳定性和数据的一致性,更与我们的代码实现和业务逻辑密切相关。 尤其是在高并发环境下,如何保证数据的一致性,如何…

使用k6进行kafka负载测试

1.安装环境 kafka环境 参考Docker搭建kafka环境-CSDN博客 xk6-kafka环境 ./xk6 build --with github.com/mostafa/xk6-kafkalatest 查看安装情况 2.编写脚本 test_kafka.js // Either import the module object import * as kafka from "k6/x/kafka";// Or in…

[机器学习]XGBoost(3)——确定树的结构

XGBoost的目标函数详见[机器学习]XGBoost(2)——目标函数(公式详解) 确定树的结构 之前在关于目标函数的计算中,均假设树的结构是确定的,但实际上,当划分条件不同时,叶子节点包含的…

springboot444新冠物资管理系统的设计与实现(论文+源码)_kaic

摘 要 传统办法管理信息首先需要花费的时间比较多,其次数据出错率比较高,而且对错误的数据进行更改也比较困难,最后,检索数据费事费力。因此,在计算机上安装新冠物资管理系统软件来发挥其高效地信息处理的作用&#x…

Javascript-web API-day02

文章目录 01-事件监听02-点击关闭广告03-随机点名案例04-鼠标经过或离开事件05-可点击的轮播图06-小米搜索框07-键盘类型事件08-键盘事件-发布评论案例09-focus选择器10-评论回车发布11-事件对象12-trim方法13-环境对象14-回调函数15-tab栏切换 01-事件监听 <!DOCTYPE html…