Octave实现位置式PID算法

由于Matlab不让用,只能“你不让爷用,爷就用别的”,选择开源的Octave以及scilab进行相关领域的学习。Octave的代码和Matlab几乎是100%相同的,只有一些专用的包的函数,可能有些还没来得及写,或者有些差异。但这种差异,新手一般体会不到,老手应该能自己解决了吧。

目录

  • 数字PID控制
    • 位置式PID控制算法
    • 偏微分方程求解
    • 离散系统的数字PID控制仿真

数字PID控制

PID控制器是一种线性控制器,根据给定值 r i r_i ri与实际值构成控制偏差 e r r ( t ) = r i ( t ) − y o ( t ) err(t)=r_i(t)-y_o(t) err(t)=ri(t)yo(t)。其控制规律为

u ( t ) = k p ( e r r ( t ) + 1 T 1 ∫ 0 t e r r ( t ) d t + T D d e r r ( t ) d t ) u(t)=k_p(err(t)+\frac{1}{T_1}\int^{t}_{0}err(t)\text dt+\frac{T_D\text derr(t)}{\text dt}) u(t)=kp(err(t)+T110terr(t)dt+dtTDderr(t))

写成传递函数的形式为

G ( s ) = U ( s ) E ( s ) = k p ( 1 + 1 T 1 s + T D s ) G(s)=\frac{U(s)}{E(s)}=k_p(1+\frac{1}{T_1s}+T_Ds) G(s)=E(s)U(s)=kp(1+T1s1+TDs)

其中, k p k_p kp为比例系数; T 1 T_1 T1为积分时间常数; T D T_D TD为微分时间常数。 U ( s ) U(s) U(s)为输出量的拉氏量, E ( s ) E(s) E(s)为输入量的拉氏量。

PID控制器各校正环节如下:

  1. 比例环节:成比例地反应控制系统的偏差信号 e r r ( t ) err(t) err(t),偏差一旦产生,控制器立即产生控制作用,从而减少偏差。
  2. 积分环节:用于消除静差,提高系统的无差度。积分作用的强弱与积分时间常数 T 1 T_1 T1成负相关。
  3. 微分环节:反应偏差信号的变化趋势(变化速率),并能在偏差信号变得太大之前,在系统中引入一个有效的早期修正信号,从而加快系统的动作速度,减少调节时间。

位置式PID控制算法

以一系列的采样时刻点 k T kT kT代表连续时间 t t t,以举行法数值积分代替积分,以一阶后向差分近似代替微分,即

{ t ≈ k T , k = 0 , 1 , 2... ∫ 0 1 e r r ( t ) d t ≈ T ∑ j = 0 k e r r ( j T ) = T ∑ j = 0 k e r r j d e r r ( t ) d t ≈ e r r ( k T ) − e r r ( ( k − 1 ) T ) T = e r r k − e r r k − 1 T \left\{\begin{aligned} &t\approx kT, k=0,1,2...\\ &\int^1_0err(t)\text dt\approx T\sum^k_{j=0}err(jT)=T\sum^k_{j=0}err_j\\ &\frac{\text derr(t)}{\text dt}\approx\frac{err(kT)-err((k-1)T)}{T}=\frac{err_k-err_{k-1}}{T} \end{aligned}\right. tkT,k=0,1,2...01err(t)dtTj=0kerr(jT)=Tj=0kerrjdtderr(t)Terr(kT)err((k1)T)=Terrkerrk1

可得离散PID表达式

u ( k ) = k p ( e r r k + T T 1 ∑ j = 0 k e r r j + T D T ( e r r k − e r r k − 1 ) ) = k p e r r k + k I ∑ j = = 0 k e r r j T + k d e r r k − e r r k − 1 T \begin{aligned} u(k)=&k_p(err_k+\frac{T}{T_1}\sum^k_{j=0}err_j+\frac{T_D}{T}(err_k-err_{k-1}))\\ =&k_perr_k+k_I\sum^k_{j==0}err_jT+k_d\frac{err_k-err_{k-1}}{T} \end{aligned} u(k)==kp(errk+T1Tj=0kerrj+TTD(errkerrk1))kperrk+kIj==0kerrjT+kdTerrkerrk1

其中, k I = k p T 1 , k d = k p T D k_I=\frac{k_p}{T_1},k_d=k_pT_D kI=T1kp,kd=kpTD T T T为采样周期, k k k为采样序号, k = 1 , 2 , . . . k=1,2,... k=1,2,...。其控制系统为

在这里插入图片描述

偏微分方程求解

设被控对象为电机模型传递函数

G ( s ) = 1 J s 2 + B s , J = 0.0067 , B = 0.10 G(s)=\frac{1}{Js^2+Bs},J=0.0067,B=0.10 G(s)=Js2+Bs1,J=0.0067,B=0.10

则我们可以通过Octave通过ODE45的方法来求解方程,输入信号为 r i n ( k ) = 0.50 sin ⁡ ( 2 π t ) r_{in}(k)=0.50\sin(2\pi t) rin(k)=0.50sin(2πt),采用PID控制方法设计控制器,其中 k p = 20.0 , k d = 0.50 k_p=20.0,k_d=0.50 kp=20.0,kd=0.50

其中,ODE45的调用方法为

[t,x]=ode45(func,tspan,x0,op,para)

其返回值t是一个列向量,x是一个矩阵;参数func为待处理函数或其路径,tspan=[t0 tf]为微分方程组的积分区间,

代码为

ts = 0.001; %Sampling time
xk = zeros(2,1);
e1 = 0; u1 = 0; %初始化误差

time = ts:ts:2000*ts
rin = 0.5*sin(1*2*pi*time);
for k = 1:1:2000
  para = u1;
  tSpan = [0 ts];
  [tt, xx] = ode45("test1_func", tSpan, xk, [], para);
  xk = xx(length(xx),:);
  yout(k) = xk(1);
  e(k) = rin(k) - yout(k);  %误差
  de(k) = (e(k)-e1)/ts;     %误差的一阶导数
  u(k) = 20.0*e(k)+0.5*de(k);
  u(k) = min(u(k),10.0);    %限制u(k)所在区间为[-10,10]
  u(k) = max(u(k),-10.0);
  u1 = u(k);
  e1 = e(k);
end

subplot(1,2,1)
plot(time, rin, 'r', time ,yout, 'b');
xlabel('time(s)'), ylabel('rin,yout');

subplot(1,2,2)
plot(time, rin-yout, 'r');
xlabel('time(s)'), ylabel('error');

函数文件为

% test1_func.m
function dy=PlantModel(t,y,flag,para)
  u = para;J = 0.0067;B = 0.1;
  
  dy = zeros(2,1);
  dy(1) = y(2);
  dy(2) = -(B/J)*y(2)+(1/J)*u;

得到其结果为

在这里插入图片描述
此外,可以通过XCOS进行仿真,被控对象为三阶传递函数,采用XCOS与脚本结合的方式。主程序由XCOS实现,控制由scilab实现。

离散系统的数字PID控制仿真

控制对象为

G ( S ) = 523500 s 3 + 87.35 s 2 + 10470 s G(S)=\frac{523500}{s^3+87.35s^2+10470s} G(S)=s3+87.35s2+10470s523500

采样时间为1ms,采用z变换进行离散化,经过z变换后的离散化对象为

y o u t = − d e n ( 2 ) y o u t ( k − 1 ) − d e n ( 3 ) y o u t ( k − 2 ) − d e n ( 4 ) y o u t ( k − 3 ) + n u m ( 2 ) u ( k − 1 ) + n u m ( 3 ) u ( k − 2 ) + n u m ( 1 ) u ( k − 3 ) \begin{aligned} y_{out}=&-den(2)y_{out}(k-1)-den(3)y_{out}(k-2)-den(4)y_{out}(k-3)\\ &+num(2)u(k-1)+num(3)u(k-2)+num(1)u(k-3) \end{aligned} yout=den(2)yout(k1)den(3)yout(k2)den(4)yout(k3)+num(2)u(k1)+num(3)u(k2)+num(1)u(k3)

其Octave控制代码为

ts = 0.001; %采样时间
N = 1000;    %采样个数

pkg load control    %载入control包,内含tf函数
pkg load tisean     %内含c2d函数

sys = tf(2.235e5,[1,87.35,1.047e4,0]); 
dsys = c2d(sys,ts,'z'); %z变换
[num,den] = tfdata(dsys, 'v');

titles = ["step signal";"square signal";"sin signal"]

for s = 1:3
%参数初始化
u = zeros(1,3);y = zeros(1,3);x = zeros(1,3);
err = 0;

time = ts:ts:ts*N;
rin = ones(1,N);
PDI = [2 0.001 0.001];          %表示P,D,I的分量
if s==2
  rin = sign(sin(2*2*pi*time)); %方波信号
elseif s==3
  rin = 0.5*sin(2*2*pi*time);   %正弦信号
endif

for k = 1:1:N
  yout(k) = -sum(den(2:4).*y)+sum(num.*u);
  error(k) = rin(k)-yout(k);

  u(2:3) = u(1:2);  
  u(1) = sum(PDI.*x);  %PID 控制
  u(1) = sort([u(1),10,-10])(2)   %区间限制
  
  y = [yout(k) y(1:2)];
  
  x(1) = error(k);
  x(2) = (error(k)-err)/ts;
  x(3) = x(3) + error(k)*ts;
  
  err = error(k);
end

subplot(230+s)
plot(time, rin, 'b', time, yout, 'r')
xlabel('time(s)'), ylabel('rin, rout')
title(titles(s,:))

subplot(233+s)
plot(time,error)
xlabel('time(s)'),ylabel('error')
end

在这里插入图片描述
这种PID控制算法的缺点是,每次输出均与过去的状态有关,故需要对误差量进行累加,如果位置传感器出现故障, u ( k ) u(k) u(k)可能会出现大幅度变化,从而引起执行机构位置的大幅度变化,从而产生事故。为避免这种情况发生,可采用增量式PID控制算法。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

NLP_语言模型的雏形 N-Gram 模型

文章目录 N-Gram 模型1.将给定的文本分割成连续的N个词的组合(N-Gram)2.统计每个N-Gram在文本中出现的次数,也就是词频3.为了得到一个词在给定上下文中出现的概率,我们可以利用条件概率公式计算。具体来讲,就是计算给定前N-1个词时&#xff0…

Redis篇之redis是单线程

一、redis是单线程 Redis是单线程的,但是为什么还那么快?主要原因有下面3点原因: 1. Redis是纯内存操作,执行速度非常快。 2. 采用单线程,避免不必要的上下文切换可竞争条件,多线程还要考虑线程安全问题。 …

硬件大熊原创合集(2024/01更新)

则2024-01月份更新篇章: NFC芯片WS1850的9个典型问题-篇章1 凡夫畏果,菩萨畏因 赶在春节前,做个红包封面,一轮操作下来,发现自己在美工设计这块实在是太欠缺,还好图像处理AI出来了,用Midijourne…

软考 系统分析师系列知识点之信息系统战略规划方法(3)

接前一篇文章:软考 系统分析师系列知识点之信息系统战略规划方法(2) 所属章节: 第7章. 企业信息化战略与实施 第4节. 信息系统战略规划方法 7.4.1 企业系统规划法 7. 确定管理部门对系统的要求 BSP的出发点是管理部门对系统的要…

WordPress如何实现随机显示一句话经典语录?怎么添加到评论框中?

我们在一些WordPress网站的顶部或侧边栏或评论框中,经常看到会随机显示一句经典语录,他们是怎么实现的呢? 其实,boke112百科前面跟大家分享的『WordPress集成一言(Hitokoto)API经典语句功能』一文中就提供…

Tomcat之虚拟主机

1.创建存放网页的目录 mkdir -p /web/{a,b} 2.添加jsp文件 vi /web/a/index.jsp <% page language"java" import"java.util.*" pageEncoding"UTF-8"%> <html> <head><title>JSP a page</title> </head> …

BUUCTF-Real-[Tomcat]CVE-2017-12615

目录 漏洞描述 一、漏洞编号&#xff1a;CVE-2017-12615 二、漏洞复现 get flag 漏洞描述 CVE-2017-12615&#xff1a;远程代码执行漏洞 影响范围&#xff1a;Apache Tomcat 7.0.0 - 7.0.79 (windows环境) 当 Tomcat 运行在 Windows 操作系统时&#xff0c;且启用了 HTTP P…

力扣面试题 05.06. 整数转换(位运算)

Problem: 面试题 05.06. 整数转换 文章目录 题目描述思路及解法复杂度Code 题目描述 思路及解法 1.通过将两个数进行异或操作求出两个数中不同的位(不同的位异或后为二进制1); 2.统计异或后不同的位的个数(即异或后二进制为1的个数) 复杂度 时间复杂度: O ( 1 ) O(1) O(1) 空间…

《Git 简易速速上手小册》第9章:Git 工作流程定制(2024 最新版)

文章目录 9.1 选择合适的工作流9.1.1 基础知识讲解9.1.2 重点案例&#xff1a;为中等规模的 Python 项目选择 Feature Branch 工作流9.1.3 拓展案例 1&#xff1a;适应 Gitflow 工作流的大型项目9.1.4 拓展案例 2&#xff1a;使用 Forking 工作流的开源 Python 项目 9.2 定制化…

94.网游逆向分析与插件开发-游戏窗口化助手-地图数据获取的逆向分析与C++代码还原

内容参考于&#xff1a;易道云信息技术研究院VIP课 上一个内容&#xff1a;升级经验数据获取的逆向分析 码云地址&#xff08;游戏窗口化助手 分支&#xff09;&#xff1a;https://gitee.com/dye_your_fingers/sro_-ex.git 码云版本号&#xff1a;c4351a5b346d8953a1a8e3ec…

Hgame week1 web

1.Bypass it 不准注册&#xff0c;禁用一下js成功注册登录拿到flag 2.ezHTTP 跟着提示走就行 jwt解析一下 3.点击选课发包时候显示已满 一直发包就会选上 每个都一直发包最后就可以全选课成功 后来得知是后天每隔一段时间会放出一些课&#xff0c;一直发包就能在放课的时候选到…

CDN相关和HTTP代理

CDN相关和HTTP代理 参考&#xff1a; 《透视 HTTP 协议》——chrono 把这两个放在一起是因为容易搞混&#xff0c;我一开始总以为CDN就是HTTP代理&#xff0c;但是看了极客时间里透视HTTP协议的讲解&#xff0c;感觉又不仅于此&#xff0c;于是专门写下来。 先说结论&#xf…

计算机组成原理——计算机系统概述

文章目录 概要计算机硬件的基本组成早期冯诺依曼的结构介绍特点 现代计算机的结构介绍五大部件的归属 五大部件存储器&#xff1a;存储体 MAR、MDR运算器控制器 运行原理 计算机软件系统软件和应用软件三种级别的语言编译程序与解释程序的区别 软件硬件功能程序的等价性指令集体…

LLaMA 模型中的Transformer架构变化

目录 1. 前置层归一化&#xff08;Pre-normalization&#xff09; 2. RMSNorm 归一化函数 3. SwiGLU 激活函数 4. 旋转位置嵌入&#xff08;RoPE&#xff09; 5. 注意力机制优化 6. Group Query Attention 7. 模型规模和训练超参数 8. 分布式模型训练 前置归一化与后置…

音视频色彩:RGB/YUV

目录 1.RGB 1.1介绍 1.2分类 1.2.1RGB16 1)RGB565 2)RGB555 1.2.2RGB24 1.2.3RGB222 2.YUV 2.1介绍 2.2分类 2.2.1 YUV444 2.2.2 YUV 422 2.2.3 YUV 420 2.3存储格式 2.3.1 YUYV 2.3.2 UYVY 2.3.3 YUV 422P 2.3.4 YUV420P/YUV420SP 2.3.5 YU12 和…

JavaScript流程控制详解之循环结构(倒三角、九九乘法表)

循环结构 在JavaScript中&#xff0c;循环语句指的是在满足某个条件下重复执行 指定的一段代码。若条件结果为true,则重复执行&#xff0c;则进入循环&#xff0c;否则结束循环。 在JavaScript中&#xff0c;循环语句如下&#xff1a; while语句do…while语句for语句 while…

springboot163美食推荐商城的设计与实现

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…

WifiConfigStore初始化读取-Android13

WifiConfigStore初始化读取 1、StoreData创建并注册2、WifiConfigStore读取2.1 文件读取流程2.2 时序图2.3 日志 1、StoreData创建并注册 packages/modules/Wifi/service/java/com/android/server/wifi/WifiConfigManager.java mWifiConfigStore.registerStoreData(mNetworkL…

Windows 安装 MySQL 最新最简教程

Windows 安装 MySQL 最新最简教程 官网地址 https://dev.mysql.com/downloads/mysql/下载 MySQL zip 文件 配置 MySQL1、解压文件 2、进入 bin 目录 搜索栏输入 cmd 回车进入命令行 C:\Users\zhong\Desktop\MySQL\mysql-8.3.0-winx64\mysql-8.3.0-winx64\bin 注意这里是你自己…

【数据分享】1929-2023年全球站点的逐日平均风速数据(Shp\Excel\免费获取)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、能见度等指标&#xff0c;说到气象数据&#xff0c;最详细的气象数据是具体到气象监测站点的数据&#xff01; 有关气象指标的监测站点数据&#xff0c;之前我们分享过1929-2023年全球气象站…