MATLAB学习笔记(二) 控制工程会用到的

news2025/5/26 0:41:23

MATLAB中 控制工程会用到的

  • 基础
    • 传递函数表达
    • 传递函数 零极点式 状态空间表达式 相互转化
    • 画响应图线
    • 根轨迹
    • Nyquist图和bode图
    • 现控部分
      • 求约旦
      • 判能控能观
      • 极点配置和状态观测

基础

传递函数表达

在这里插入图片描述

% 拉普拉斯变换
syms t s a
f = exp(a*t)            %e的a次方
l = laplace(f)          %拉氏变换
f2 = ilaplace(f)        %拉氏反变换

%传递函数

%多项式形式
num=[1,2]           %表示传递函数分子系数    从右往左表示0次 1次   0次为2 1次为1
den=[1,2,3]         %表示分母上的系数
sys = tf(num,den)   %连续时间传递函数


%零极点形式
z = [1 2 3]         %零点   用逗号空格都可以
p = [4 5 6]         %极点
k = 15              %增益
sys = zpk(z,p,k)    %传递函数 



传递函数 零极点式 状态空间表达式 相互转化

在这里插入图片描述

%状态空间表达式
A = [1,2,3;4,5,6;7,8,9]
B = [0;1;1]
C = [1,2,3]
D = 3

sys = ss(A,B,C,D)


%状态空间表达式到多项式形式传递函数---  ss2tf
A = [1,2,3;4,5,6;7,8,9]
B = [0;1;1]
C = [1,2,3]
D = 3
[num,den] = ss2tf(A,B,C,D)
sys = tf(num,den)

%状态空间表达式生成零极点---  ss2zp
A = [1,2,3;4,5,6;7,8,9]
B = [0;1;1]
C = [1,2,3]
D = 3
[z,p,k] = ss2zp(A,B,C,D)
sys = zpk(z,p,k)

在这里插入图片描述

%多项式形式到零极点形式---    tf2zp
num = [1,2]
den = [1,2,3]
[z,p,k] = tf2zp(num,den)

%多项式形式到状态空间表达式-- tf2ss
num = [1,2]
den = [1,2,3]
[A,B,C,D] = tf2ss(num,den)
sys = ss(A,B,C,D)

在这里插入图片描述


%零极点形式得到状态空间表达式-- zp2ss
z = [1 2 3]         %零点 
p = [4 5 6]         %极点
k = 15              
[A,B,C,D] = zp2ss(z,p,k)
sys = ss(A,B,C,D)

%零极点形式得到多项式形式--  zp2tf
z = [1;2;3]         %零点 
p = [4 5 6]         %极点
k = 15              
sys = zpk(z,p,k)
[num,den]= zp2tf(z,p,k)
sys = tf(num,den)

画响应图线

在这里插入图片描述

%时域响应部分  求单位阶跃响应和单位脉冲响应
num = [1];
den = [1,0.4];
t = [0:0.1:20];
% step 函数用于计算由分子 num 和分母 den 定义的系统在时间向量 t 上的阶跃响应
y = step(num,den,t);
%y = impulse(num,den,t);    % 单位脉冲响应
plot(t,y)                   % 以时间 t 为横轴,阶跃响应 y 为纵轴绘制曲线
grid on                     % grid on 用于在绘图中显示网格线,方便观察数据
xlabel('时间/s')
ylabel('y')
title('单位阶跃响应曲线')
legend('单位阶跃响应曲线')      %在坐标图例添加标签

根轨迹

在这里插入图片描述

%根轨迹

num = [1,2]
den = [1,2,3]
sys = tf(num,den)
pzmap(sys)              %画出零极点位置
rlocus(sys)             %画出根轨迹

num = [1,2]
den = conv([1,0],conv([0.5,1],[4,1])) 
%卷积 实际上就是算S*[(0.5s+1)(4s+1)]
sys = tf(num,den)
k = [0,0.1,10]  %就是给k一个范围
rlocus(sys,k)



Nyquist图和bode图

在这里插入图片描述
在这里插入图片描述


%频率特性奈奎斯特图
num = 5
den = [3,1]
G = tf(num,den)
figure   % figure 函数用于打开一个新的图形窗口,后续的绘图操作将在这个窗口中进行

% 在图形窗口中创建子图布局
% subplot(2,1,1) 表示将图形窗口划分为 2 行 1 列的子图网格,并激活第 1 个子图(即第一行的子图)
subplot(2,1,1)

nyquist(G)
title('nyquist图')
grid on      % 在当前子图中显示网格线

%绘制伯德图
subplot(2,1,2)
bode(G)
title('bode图')
grid on
%频域性能指标:赋值裕度(没有Db单位得) 相角裕度,穿越频率,截止频率。
num = 5
den = [3,1]
G = tf(num,den)
[Gm,pm,Wcg,wcp] = margin(G)   %一串直接求了

现控部分

求约旦

在这里插入图片描述

判能控能观

在这里插入图片描述

%判断能控能观性
A = [1,2,3;4,5,6;7,8,9]
B = [0;1;1]
C = [1,2,3]
D = 1
M = [B,A*B,A*A*B]
M = ctrb(A,B)                %计算可控性矩阵
a = rank(M)
if a == 3
    disp('可控');
else
    disp('no')
end
%判断能观性

N = obsv(A,C)               %计算能观判别矩阵
b = rank(N)

极点配置和状态观测

在这里插入图片描述

%状态反馈    极点配置
A = [1,2,3;4,5,6;7,8,9]
B = [0;1;1]
C = [1,2,3]
D = 1

%期望闭环极点
p = [1,2,4]
%适用place函数进行任意极点配置
%当然也要先判能控
K = place(A,B,p)

%状态观测器
A = [1,2,3;4,5,6;7,8,9]
B = [7;2;8]
C = [3,1,3]
D = 1
N = obsv(A,C)
N = [C;C*A;C*A*A]
b = rank(N)
p = [-5,-6,-7]
G = place(A',C',p)


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

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

相关文章

C++ 线程间通信开发从入门到精通实战

C 线程间通信开发从入门到精通实战 在现代软件开发中,多线程程序已成为提升应用性能、实现并行处理的重要手段。随着多核处理器的普及和复杂应用需求的增加,C作为一门高性能的编程语言,在多线程开发中扮演着不可或缺的角色。然而&#xff0c…

Redis原理与Windows环境部署实战指南:助力测试工程师优化Celery调试

引言 在分布式系统测试中,Celery作为异步任务队列常被用于模拟高并发场景。而Redis作为其核心消息代理,其性能和稳定性直接影响测试结果。本文将深入解析Redis的核心原理,主要讲解Windows环境部署redis,为测试工程师提供一套完整…

Go语言入门到入土——一、安装和Hello World

Go语言入门到精通——安装和Hello World 文章目录 Go语言入门到精通——安装和Hello World下载并安装让Go跑起来为你的代码启动依赖跟踪调用外部包总结 下载并安装 下载地址:https://go.dev/dl/ 下载后傻瓜式安装 查看是否安装完成 go version让Go跑起来 创建一个…

opencv函数展示

一、图像基础 I/O 与显示 1.cv2.imread() 2.cv2.imshow() 3. cv2.waitKey() 4. cv2.imwrite() 5. cv2.selectROI() 6. cv2.VideoCapture() 二、颜色空间与转换 1. cv2.cvtColor() 2. cv2.split() 三、阈值处理 1. cv2.threshold() 2. 特殊阈值方法

【vue3】vue3+express实现图片/pdf等资源文件的下载

文件资源的下载,是我们业务开发中常见的需求。作为前端开发,学习下如何自己使用node的express框架来实现资源的下载操作。 实现效果 代码实现 前端 1.封装的请求后端下载接口的方法,需求配置aixos的请求参数里面的返回数据类型为blob // 下载 export…

如何在 Kali 上解决使用 evil-winrm 时 Ruby Reline 的 quoting_detection_proc 警告

在使用 Kali Linux 运行 Ruby 工具(例如 evil-winrm)时,你可能会遇到以下警告: Warning: Remote path completions is disabled due to ruby limitation: undefined method quoting_detection_proc for module Reline这个警告会导…

从零到一:网站设计新手如何快速上手?

从零到一:网站设计新手如何快速上手? 在当今数字化时代,网站已成为企业、个人展示信息、提供服务的重要窗口。对于想要涉足网站设计领域的新手而言,如何快速上手并掌握必要的技能成为首要任务。本文将从基础知识、软件工具、设计…

面向初学者的JMeter实战手册:从环境搭建到组件解析

🌟 ​大家好,我是摘星!​ 🌟 今天为大家带来的是面向初学者的JMeter实战手册:从环境搭建到组件解析,废话不多说,让我们直接开始~ 目录 1. JMeter简介 2. JMeter安装与配置 2.1. 安装 2.2.…

工资管理系统的主要功能有哪些

工资管理系统通过自动化薪资计算、税务处理、员工数据管理、报表生成等功能,极大地提升了薪资发放的效率和准确性。在传统的人工薪资管理中,HR人员需要手动计算每位员工的薪资,并确保符合税务要求,极易出错且耗时。而现代工资管理…

子函数嵌套的意义——以“颜色排序”为例(Python)

多一层缩进精减参数传递,参数少平铺书代码写更佳。 笔记模板由python脚本于2025-04-16 11:52:53创建,本篇笔记适合喜欢子函数嵌套结构代码形式的coder翻阅。 【学习的细节是欢悦的历程】 博客的核心价值:在于输出思考与经验,而不仅…

信息系统项目管理工程师备考计算类真题讲解四

一、三点估算(PERT) PERT(Program Evaluation and Review Technique):计划评估技术,又称三点估算技术。PERT估算是一种项目管理中用于估算项目工期或成本的方法,以下是其详细介绍: …

Golang|KVBitcask

文章目录 初识KVbitcask论文详解 初识KV bitcask论文详解 论文地址:https://riak.com/assets/bitcask-intro.pdf理想的存储引擎,应该满足下面一些特点:

基于骨骼识别的危险动作报警系统设计与实现

基于骨骼识别的危险动作报警系统设计与实现 基于骨骼识别的危险动作报警分析系统 【包含内容】 【一】项目提供完整源代码及详细注释 【二】系统设计思路与实现说明 【三】基于骨骼识别算法的实时危险行为预警方案 【技术栈】 ①:系统环境:Windows 10…

PDF转换格式失败?原因及解决方法全解析

在日常工作中,我们经常会遇到将PDF转换为Word、Excel、PPT等格式的需求。有时候以为一键转换就能搞掂,没想到却转换失败。到底问题出在哪?别急,我们可以看看是否以下几个问题引起的,找到解决问题的关键! 原…

模型提示词

一 提示词 (一) 提示词(Prompt)是用户发送给大语言模型的问题、指令或请求,** 1 来明确地告诉模型用户想要解决的问题或完成的任务,是大语言模型理解用户需求并据此生成相关、准确回答或内容的基础。对于…

Node.js 数据库 事务 项目示例

1、参考:JavaScript语言的事务管理_js 函数 事务性-CSDN博客 或者百度搜索:Nodejs控制事务, 2、实践 2.1、对于MySQL或MariaDB,你可以使用mysql或mysql2库,并结合Promise或async/await语法来控制事务。 使用 mysql2…

Qt开发:QFileInfo详解

文章目录 一、QFileInfo 简介二、常用的构造函数三、常用函数的介绍和使用四、常用静态函数的介绍和使用五、完整代码示例 一、QFileInfo 简介 QFileInfo 提供了一个对象化的方式,用于访问文件系统中单个文件的信息。它可以接受: 文件名字符串&#xff…

蓝桥杯常考排序

1.逆序 Collections.reverseOrder() 方法对列表进行逆序排序。通过 Collections.sort() 方法配合 Collections.reverseOrder(),可以轻松实现从大到小的排序。 import java.util.ArrayList; // 导入 ArrayList 类,用于创建动态数组 import java.util.C…

深度学习基础:从入门到理解核心概念

引言 近年来,深度学习(Deep Learning)已成为人工智能领域最热门的研究方向之一。从AlphaGo战胜人类围棋冠军,到ChatGPT等大型语言模型的惊艳表现,深度学习技术正在深刻改变我们的生活和工作方式。本文将系统介绍深度学习的基础知识&#xff0…

科技项目验收测试报告有哪些作用?需要多长时间和费用?

在当今快速发展的科技环境中,科技项目的有效验收至关重要。对于公司、开发团队以及客户来说,科技项目验收测试报告更是一个不可缺少的一项重要环节。 科技项目验收测试报告是对一个项目在开发完成后所进行的一系列测试结果的总结。这份报告不仅用于证明…