- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
微分先行的 PID 控制算法
实验目的
通过上机实践操作,使学生能够直观理解课堂上所讲的内容。学生在计算机上结合课程教学用的 Matlab 语言或 Simulink 构建仿真模型实现微分先行的 PID 控制算法,培养学生的动手实践能力。
实验内容
用 Matlab 语言或 Simulink 构建仿真模型实现微分先行的 PID 控制算法
题目:控制对象为G
0
e?80t
?70s ? 1 ,采样时间为 20s,输入信号为带有高频干
?
扰的方波信号: r(t) ? sign(square(0.0005?t)) ? 0.05sin(0.03?t) ,执
行 机 构 输 出 限 制 在 [-10,10], 仿 真 时 间 为 8000s ; 其
中, kp ? 0.3, ki ? 0.006, kd ? 18,? ? 0.4 .试采用微分先行的PID 控制算法和标准 PID 控制算法实现后,比较两种控制算法的输入/输出、控制量。
实验原理
微分先行 PID 控制算法:
u (k ) ? c
D 1
*u (k ?1) ? c
D 2
* y(k ) ? c
3
* y(k ?1)
u(k ) ? k
p
* e(k ) ? k
i
* ?k
j ?0
e( j)*T
? *T T ? T T
dd式中c
d
d
1
? ? *T
? T , c2 ?
*T ? T , c3
? ? *Td ? T
, e(k) ? r(k) ? u
D
(k) 。
?d d d
?
实验程序:
clear all;close all;
ts=20;
M=2;
ki=0.006;kd=18;kp=0.3;gama=0.4; sys=tf(1,[70 1],inputdelay,80); dsys=c2d(sys,ts,zoh);
[num,den]=tfdata(dsys,v); ud_1=0;y_1=0;e_1=0;ei=0; u_1=0;u_2=0;u_3=0;u_4=0;u_5=0; Td=kd/kp;
c1=gama*Td/(gama*Td+ts);c2=(Td+ts)/(gama*Td+ts);c3=Td/(gama*Td+ts
);%微分先行算法中的参数c1,c2,c3 for k=0:1:400
time(k+1)=k*ts;
y(k+1)=-den(2)*y_1+u_5*num(2); % 输 出 量ud(k+1)=c1*ud_1+c2*y(k+1)-c3*y_1; %控制量ud_1=ud(k+1);
r(k+1)=sign(sin(0.0005*pi*time(k+1)))+0.05*sin(0.03*pi*time(k+1))
;
if M==1
e(k+1)=r(k+1)-ud(k+1);
ei=ei+e(k+1)*ts; %积分项累加值
u(k+1)=kp*e(k+1)+ki*ei; %控制量
else
end
e(k+1)=r(k+1)-y(k+1);
ei=ei+e(k+1)*ts; u(k+1)=kp*e(k+1)+ki*ei+kd*(e(k+1)-e_1)/ts;
if u(k+1)10 %控制量限幅
u(k+1)=10;
else if u(k+1)-10
u(k+1)=-10;
end
end
end
y_1=y(k+1); u_5=u_4;u_4=u_3;u_3=u_2;u_2=u_1;u_1=u(k+1);e_1=e(k+1);
hold on; if M==1
figure(1);
plot(time,r,r,time,y,b);xlabel(时间(单位: s));ylabel(输入/输出);
legend(输入,微分先行PID输出);
else
figure(1);
plot(time,r,r,time,y,b);xlabel(时间(单位: s));ylabel(输入/输出);
legend(输入,普通PID输出);
end figure(2);
plot(time,u,r);xlabel(时间(单位:s));ylabel(控制量);
legend(微分先行PID控制算法控制量);
实验结果
微分先行 PID 算法结果:
输 入微 分 先 行
输 入
微 分 先 行 PID 输 出
1
0.5
出
/输 0
/
入输
-0.5
-1
-1.5
0 1000 2000 3000 4000 5000
时 间 ( 单 位 : s )
6000 7000 8000
微 分 先 行 PID
微 分 先 行 PID 控 制 算 法 控 制 量
1
0.5
量
制 0
控
-0.5
-1
-1.5
0 1000 2000 3000 4000 5000
时 间 ( 单 位
您可能关注的文档
最近下载
- 水利水电工程单元工程施工质量验收评定表填表说明与示例(样表)2025年版(全).doc VIP
- 人教PEP版(一起)(2024)英语二年级上册英语Unit 3 Helpful hands 教案.docx
- 2025第三届全国技术技能大赛江西选拔赛制造业数字化转型赛项技术方案.pdf VIP
- 实验员考试试题及答案.doc VIP
- 标准起草编制说明范文.pdf VIP
- CRISPR-Cas9基因编辑技术.pptx VIP
- (高清版)B-T 17421.1-2023 机床检验通则 第1部分在无负荷或准静态条件下机床的几何精度.pdf VIP
- 2025年纪检监察应知应会试题库及参考答案.docx VIP
- 球馆充值协议书范本.docx VIP
- 2022年9月17日全国事业单位联考D类《综合应用能力》小学真题及答案.pdf VIP
原创力文档


文档评论(0)