资源简介
利用遗传算法优化pid控制器三个参数的matlab程序

代码片段和文件信息
%lizi2_1.m
%GA(Generic Algorithm) Program is to optimize PID Parameters
clear all;
close all;
global rin yout timef
Size=30;
CodeL=3;
MinX(1)=zeros(1);
MaxX(1)=20*ones(1);
MinX(2)=zeros(1);
MaxX(2)=1.0*ones(1);
MinX(3)=zeros(1);
MaxX(3)=1.0*ones(1);
Kpid(:1)=MinX(1)+(MaxX(1)-MinX(1))*rand(Size1);
Kpid(:2)=MinX(2)+(MaxX(2)-MinX(2))*rand(Size1);
Kpid(:3)=MinX(3)+(MaxX(3)-MinX(3))*rand(Size1);
G=100;
BsJ=0;
%*************** Start Running ***************
for kg=1:1:G
time(kg)=kg;
%****** Step 1 : Evaluate BestJ ******
for i=1:1:Size
Kpidi=Kpid(i:);
[KpidiBsJ]=lizi2_1f(KpidiBsJ);
BsJi(i)=BsJ;
end
[OderJiIndexJi]=sort(BsJi);
BestJ(kg)=OderJi(1);
BJ=BestJ(kg);
Ji=BsJi+1e-10; %Avoiding deviding zero
fi=1./Ji;
% Cm=max(Ji);
% fi=Cm-Ji;
[OderfiIndexfi]=sort(fi); %Arranging fi small to bigger
Bestfi=Oderfi(Size); %Let Bestfi=max(fi)
BestS=Kpid(Indexfi(Size):); %Let BestS=E(m) m is the Indexfi belong to max(fi)
kg
BJ
BestS
%****** Step 2 : Select and Reproduct Operation******
fi_sum=sum(fi);
fi_Size=(Oderfi/fi_sum)*Size;
fi_S=floor(fi_Size); % Selecting Bigger fi value
r=Size-sum(fi_S);
Rest=fi_Size-fi_S;
[RestValueIndex]=sort(Rest);
for i=Size:-1:Size-r+1
fi_S(Index(i))=fi_S(Index(i))+1; % Adding rest to equal Size
end
k=1;
for i=Size:-1:1 % Select the Sizeth and Reproduce firstly
for j=1:1:fi_S(i)
TempE(k:)=Kpid(Indexfi(i):); % Select and Reproduce
k=k+1; % k is used to reproduce
end
end
%************ Step 3 : Crossover Operation ************
Pc=0.90;
for i=1:2:(Size-1)
temp=rand;
if Pc>temp %Crossover Condition
alfa=rand;
TempE(i:)=alfa*Kpid(i+1:)+(1-alfa)*Kpid(i:);
TempE(i+1:)=alfa*Kpid(i:)+(1-alfa)*Kpid(i+1:);
end
end
TempE(Size:)=BestS;
Kpid=TempE;
%************ Step 4: Mutation Operation **************
Pm=0.10-[1:1:Size]*(0.01)/Size; %Bigger fismaller Pm
Pm_rand=rand(SizeCodeL);
Mean=(MaxX + MinX)/2;
Dif=(MaxX-MinX);
for i=1:1:Size
for j=1:1:CodeL
if Pm(i)>Pm_rand(ij) %Mutation Condition
TempE(ij)=Mean(j)+Dif(j)*(rand-0.5);
end
end
end
%Guarantee TempE(Size:) belong to the best individual
TempE(Size:)=BestS;
Kpid=TempE;
end
Bestfi
BestS
Best_J=BestJ(G)
figure(1);
plot(timeBestJ);
xlabel(‘Times‘);ylabel(‘Best J‘);
figure(2);
plot(timefrin‘r‘timefyout‘b‘);
xlabel(‘Time(s)‘);ylabel(‘rinyout‘);
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 2787 2008-05-21 20:51 遗传PID程序\lizi1_1.m
文件 1147 2008-05-20 14:00 遗传PID程序\lizi1_1f.m
文件 923 2008-05-20 15:18 遗传PID程序\Unti
目录 0 2008-06-06 18:33 遗传PID程序
----------- --------- ---------- ----- ----
4857 4
- 上一篇:隐式广义预测控制matlab程序
- 下一篇:KNN分类器完整的matlab代码
相关资源
- 基于MATLAB的质点弹道计算与外弹道优
- matlab优化工具箱讲解
- 龚纯《精通MATLAB最优化计算》随书源
- 工程优化问题的Matlab实现代码
- MATLAB 实现各类常见算法
- matlab编写的量子遗传算法
- 协同进化遗传算法求解函数优化问题
- 粒子群算法优化pid源码 matlab仿真.ra
- 坐标转换/坐标标定(matlab优化方法实
- 基于遗传算法的旅游全国的路径最优
- 基于遗传算法的机器人路径规划matl
- 多种群遗传算法的函数优化算法(源
- 遗传算法完整MATLAB程序实数法,轮盘
- 30个优化智能算法matlab
- 遗传算法解决最优路径、选址问题
- 基于matlabGUI的小车倒立摆pid控制
- 粒子群算法优化RBF网络matlab源码
- pso解决单目标优化问题
- 灰狼优化算法求解柔性作业车间问题
- 遗传算法GA车间调度Matlab代码
- 利用WOA算法优化libsvm中SVDD算法的参数
- 最优化算法规划-单纯形法MATLAB程序
- 求解多旅行商(MTSP)的遗传算法的
- 小车倒立摆系统的控制及GUI动画演示
- 论文研究-电加热模糊PID控制及仿真研
- 蝴蝶优化算法
- 优化的基于不定频滞环的SVPWM控制si
- 灰狼优化算法的仿真
- 粒子群算法求解函数优化问题.zip
- 最优化方法及其Matlab程序设计 - 马昌
评论
共有 条评论