ImageVerifierCode 换一换
格式:DOCX , 页数:5 ,大小:588.15KB ,
资源ID:257163      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-257163.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(粒子群算法优化模糊pid.docx)为本站会员(cjc2202537)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

粒子群算法优化模糊pid.docx

1、本文选取常见的二阶惯性加纯滞后环节,传递函数为: )1(21sTeGs在这里, PID参数取为3.0,2,1T 2,idpK本设计中的模糊控制器采用两输入(e, ec),三输出(P,I,D)的形式来调整PID参数。e 的论域为-3,3,ec 的论域为-3,3。推理机使用,表示负大,负中,负小,零,正小,正中,正,NBMSOPB大为了可以调节尽可能多的系统,此控制器选定在负边界处和正边界处分别选用平滑连续的 Z型隶属度函数和 S型隶属度函数,在中间部分采用灵敏度较强的三角形隶属度函数。规则表如下图所示:(1)主程序:clearclc% 参数设置w = 0.6; % 惯性因子 c1 = 1.414

2、; % 加速常数c2 = 1.623; % 加速常数Dim = 5; % 维数SwarmSize = 100; % 粒子群规模ObjFun = PSO_PID; % 待优化函数句柄MaxIter = 100; % 最大迭代次数 MinFit = 0.01; % 最小适应值Vmax = 2;Vmin =-2;Ub = 20 50 1 1 1;Lb = 0 0 0 0 0;% 粒子群初始化Range = ones(SwarmSize,1)*(Ub-Lb);Swarm = rand(SwarmSize,Dim).*Range + ones(SwarmSize,1)*Lb; % 初始化粒子群VStep

3、 = rand(SwarmSize,Dim)*(Vmax-Vmin) + Vmin; % 初始化速度fSwarm = zeros(SwarmSize,1);for i=1:SwarmSizefSwarm(i,:) = feval(ObjFun,Swarm(i,:); % 粒子群的适应值end% 个体极值和群体极值bestf,bestindex=min(fSwarm);zbest=Swarm(bestindex,:); % 全局最佳gbest=Swarm; % 个体最佳fgbest=fSwarm; % 个体最佳适应值fzbest=bestf; % 全局最佳适应值% 迭代寻优iter = 0;y_

4、fitness = zeros(1,MaxIter); % 预先产生 4 个空矩阵K_p = zeros(1,MaxIter); K_i = zeros(1,MaxIter);K_d = zeros(1,MaxIter);e= zeros(1,MaxIter);ec = zeros(1,MaxIter);while( (iter MinFit) )for j=1:SwarmSize% 速度更新VStep(j,:) = w*VStep(j,:) + c1*rand*(gbest(j,:) - Swarm(j,:) + c2*rand*(zbest - Swarm(j,:);if VStep(j,

5、:)Vmax, VStep(j,:)=Vmax; endif VStep(j,:)Ub(k), Swarm(j,k)=Ub(k); endif Swarm(j,k)Lb(k), Swarm(j,k)=Lb(k); endend% 适应值fSwarm(j,:) = feval(ObjFun,Swarm(j,:);% 个体最优更新 if fSwarm(j) fgbest(j)gbest(j,:) = Swarm(j,:);fgbest(j) = fSwarm(j);end% 群体最优更新if fSwarm(j) fzbestzbest = Swarm(j,:);fzbest = fSwarm(j)

6、;endend iter = iter+1; % 迭代次数更新y_fitness(1,iter) = fzbest; % 为绘图做准备K_p(1,iter) = zbest(1);K_i(1,iter) = zbest(2);K_d(1,iter) = zbest(3);e(1,iter) = zbest(4);ec(1,iter) = zbest(5);end% 绘图输出figure(1) % 绘制性能指标 ITAE 的变化曲线plot(y_fitness,LineWidth,2)title(最优个体适应值, fontsize,18);xlabel(迭代次数,fontsize,18);yla

7、bel( 适应值,fontsize,18);set(gca,Fontsize,18);figure(2) % 绘制 PID 控制器参数变化曲线plot(K_p)hold onplot(K_i,k,LineWidth,3)title(Kp、Ki 优化曲线 ,fontsize,18);xlabel(迭代次数,fontsize,18);ylabel( 参数值,fontsize,18);set(gca,Fontsize,18);legend(Kp,Ki,1);figure(3) % 绘制 PID 控制器参数变化曲线plot(e)hold onplot(ec,k,LineWidth,3)title(e、

8、ec 优化曲线 ,fontsize,18);xlabel(迭代次数,fontsize,18);ylabel( 参数值,fontsize,18);set(gca,Fontsize,18);legend(e,ec,1);figure(4) % 绘制 PID 控制器参数变化曲线plot(K_d)hold ontitle(Kd 优化曲线 ,fontsize,18);xlabel(迭代次数,fontsize,18);ylabel( 参数值,fontsize,18);set(gca,Fontsize,18);legend(Kd,1);clearclc(2)simulnik 与算法结合程序function

9、z=PSO_PID(x)assignin(base,Kp,x(1);assignin(base,Ki,x(2);assignin(base,Kd,x(3);assignin(base,e,x(4);assignin(base,ec,x(5);t_time,x_state,y_out=sim(pca,0,20);z=y_out(end,1);(3)Simulink 仿真图:实验结果: ,波形如下图所示。846.,1,20,15ITAEKdip实验结论:本次设计使用的是 pid,粒子群算法模糊 pid,粒子群算法模糊 smith pid 相结合,仿真波形如下图所示。黄色的是 pid 波形,红色的是粒子群算法模糊 pid,蓝色的是粒子群算法模糊 smith pid。从图中明显的可以看出加入粒子群算法模糊控制后波形超调量减少,调节时间缩短;在加入 smith 后波形有了明显的改善。0 50 100迭代次数8.84458.8458.84558.8468.8465适应值最优个体适应值0 20406080100迭代次数01020304050参数值Kp、 Ki优化曲线 KpKi0 20406080100迭代次数00.20.40.60.81参数值Kd优化曲线 Kd0 20406080100迭代次数00.20.40.60.81参数值e、 ec优化曲线eec

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报