增量式PID的matlab实现
首先,增量式PID的实现公式:

式中 Δe(k)=e(k)-e(k-1)
进一步可以改写成
式中 、
、
为了便于理解,也可写成:

式中e(k)为第k次采样时的设定值与实际值的差,e(k-1)为上一次采样时的设定值与实际值的差值,e(k-2)一样类推。
所以增量式PID 输出的是控制量的增量,无积分作用,因此该方法适用于执行机构带积分部件的对象,如步进电机等,而位置式PID适用于执行机构不带积分部件的对象,如电液伺服阀。
而且,由于增量式PID输出的是控制量增量,如果计算机出现故障,误动作影响较小,而执行机构本身有记忆功能,可仍保持原位,不会严重影响系统的工作,而位置式的输出直接对应对象的输出,
因此对系统影响较大。
下面是用Matlab 对增量式PID的仿真。
%执行机构需要的是控制量的增量,例如驱动不仅电机的时候,采用增量式PID控制,
%增量式PID控制算法中不需要累加,控制增量u(k)仅与最近k次的采样有关,所以误动作影响小。
%设一被控对象G(s)=/(.125s^+7s),
%用增量式PID控制算法编写仿真程序
%(输入分别为单位阶跃、正弦信号,采样时间为1ms,控制器输出限幅:[-,],
% 仿真曲线包括系统输出及误差曲线,并加上注释、图例)。 clc;
clear ;
ts=0.001; %采样时间
%sys=tf(,[0.125,, ]); %tf是传递函数,用来实现G(s); 在自动控制领域经常用到,
sys=tf(,[,,]);
dsys=c2d(sys,ts,'z'); %把控制函数离散化,转化为拆分方程
[num,den]=tfdata(dsys,'v'); % 离散化后提取分子、分母 ,提取拆分方程系数
u_1=0.0;
u_2=0.0;
y_1=0.0;
y_2=0.0;
x=[,,]';
error_1=;
error_2=;
for k=::
time(k)=k*ts; %采样次数 S=; %选择需要跟踪的函数
if S==
% kp=;ki=0.1;kd=; %初始化PID
kp=;ki=0.1;kd=;
rin(k)=; %Step Signal ,阶跃信号
end
if S==
kp=;ki=0.1;kd=;
rin(k)=0.5*sin(*pi*k*ts); %Sine Signal 正弦信号
end
if S== %三角波信号
kp=;ki=0.1;kd=;
if mod(time(k),)<
rin(k)=mod(time(k),);
else
rin(k)=-mod(time(k),);
end
rin(k)=rin(k)-0.5;
end
if S== %锯齿波信号
kp=;ki=0.05;kd=; %测试得合适参数,如果输出过冲,可将kd调小。
rin(k)=mod(time(k),);
end du(k)=kp*x()+kd*x()+ki*x(); %PID Controller 控制系数
u(k)=u_1+du(k); if u(k)>= %Restricting the output of controller,输出限幅
u(k)=;
end
if u(k)<=-
u(k)=-;
end %Linear model
yout(k)=-den()*y_1-den()*y_2+num()*u_1+num()*u_2; %实际输出
error(k)=rin(k)-yout(k); %Return of parameters 误差
u_2=u_1; %保存上上次输入 为下次计算
u_1=u(k); %保存上一次控制系数 为下次计算
y_2=y_1; %保存上上次次输出 为下次计算
y_1=yout(k); %保存上一次输出 为下次计算 x()=error(k)-error_1; %Calculating P
x()=error(k)-*error_1+error_2; %Calculating D
x()=error(k); %Calculating I error_2=error_1;
error_1=error(k);
end figure();
plot(time,rin,'b',time,yout,'r'); %输入 和实际控制输出
xlabel('time(s)'),ylabel('rin,yout');
% figure();
% plot(time,error,'r') %输入与输出误差输出曲线
% xlabel('time(s)');ylabel('error');
对锯齿信号的追踪图形:

增量式PID的matlab实现的更多相关文章
- 增量式PID计算公式4个疑问与理解
一开始见到PID计算公式时总是疑问为什么是那样子?为了理解那几道公式,当时将其未简化前的公式“活生生”地算了一遍,现在想来,这样的演算过程固然有助于理解,但假如一开始就带着对疑问的答案已有一定看法后再 ...
- 增量式PID简单翻板角度控制
1.研究背景 随着电子技术.信息技术和自动控制理论技术的完善与发展,近来微型处理器在控制方面的应用也越来越多.随之逐渐渗透到我们生活的各个领域.如导弹导航装置,飞机上仪表的控制,网络通讯与数据传输,工 ...
- 位置式PID与增量式PID算法
位置式PID与增量式PID算法 PID控制是一个二阶线性控制器 定义:通过调整比例.积分和微分三项参数,使得大多数的工业控制系统获得良好的闭环控制性能. 优点 ...
- 增量式PID的stm32实现(转)
源:增量式PID的stm32实现,整定过程 首先说说增量式PID的公式,这个关系到MCU算法公式的书写,实际上两个公式的写法是同一个公式变换来得,不同的是系数的差异. 资料上比较多的是: 还有一种是: ...
- 位置式PID与增量式PID
//位置式PID float Kp; float Ki; float Kd; float eSum,e0,e1; float pid_control(float now,float target) { ...
- 【转】位置式、增量式PID算法C语言实现
位置式.增量式PID算法C语言实现 芯片:STM32F107VC 编译器:KEIL4 作者:SY 日期:2017-9-21 15:29:19 概述 PID 算法是一种工控领域常见的控制算法,用于闭环反 ...
- 增量式pid和位置式PID参数整定过程对比
//增量式PID float IncPIDCalc(PID_Typedef* PIDx,float SetValue,float MeaValue)//err»ý·Ö·ÖÀë³£Êý { PIDx-& ...
- C 语言实现增量式PID
一直以来,pid都是控制领域的经典算法,之前尝试理解了很久,但还是一知半解,总是不得要领,昨天模仿着别人的代码写了一个增量式pid的代码. 我的理解就是pid其实就是对你设置的预定参数进行跟踪.在控制 ...
- 外置式与增量式PID模板程序(51单片机c语言)
外置式PID模板 #define MuBiaoCS 0 //目标常数 #define CHang_aCS 0 //比例常数 #define CHang_bCS 0 //积分常数 #define CHa ...
随机推荐
- Css样式兼容IE6,IE7,FIREFOX的写法
根据FF和IE对一些符号识别的差异,我们可以单独对FF以及IE定义样式,例子: 区别IE6与FF: background:orange;*background:blue; 区别I ...
- AOP——引言
转自:http://wayfarer.cnblogs.com/articles/241012.html 1.引言 2.AOP技术基础3.Java平台AOP技术研究 4..Net平台AOP技术研究 软件 ...
- MFC 窗体样式修改
窗体创建之后,如何设置窗体的样式呢? 一般情况下使用GetWindowLongW与SetWindowLongW即可实现窗体样式的修改或者使用ModifyStyle. 关于MFC存在GetWindowL ...
- PS流的格式和解析总结
对于PS流,最近因为工作需要,所以MPEG2中的PS流格式和解包过程进行了学习. 首先我们需要知道PS包流格式是怎么样的: (来自http://blog.csdn.net/chen495810242/ ...
- python cython 模块(1)
python 是一门动态类型的语音,其开发速度比C,C++等静态语言块, 但是速度慢很多, 而cython 通过混合C和python 的语法,可以提高python代码的运行速度 1) 安装cython ...
- PureMVC--一款多平台MVC框架
官网:http://puremvc.org/ 下载:https://github.com/PureMVC/puremvc-csharp-multicore-framework/tree/1.1.0 A ...
- [java] Unsupported major.minor version 51.0 错误解决方案
jdk1.6工程中使用外部jar包中类出现:Unsupported major.minor version 51.0原因分析:出现上述错误是因为:外部jar包使用jdk1.7(jdk7)编译,而使用此 ...
- ubuntu 安装source insight
1. 首先安装wine sudo apt-get install wine 2.下载source insight 安装包(.exe) 3,将安装包放到已知的目录下. 4.在终端进行安装,wine Si ...
- Android问题集锦之三十四:android studio导入项目下载gradle-x.x.x-all.zip
每每打开github上的项目,都会先下载gradle.每一个项目都有自己的gradle构建程序,可是打开一个新项目就又一次下载gradle对于网络较差的情况真是苦不堪言.所以我们能够用已经下载好的放到 ...
- Extjs3.4--TabpanelDemo
Ext.onReady(function () { var tab = new Ext.TabPanel({ renderTo: Ext.getBody(), height: 500 }) tab.a ...