资源简介
利用遗传算法优化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代码
相关资源
- pid控制的buck电路
- 汽车变速器传动比粒子群算法优化
- 智能优化算法及其MATLAB第2版-书中的
- 基于遗传算法的TSP问题(matlab)
- 蚁群优化模拟退火算法、多目标,遗
- 基于Matlab的模糊自适应PID控制器仿真
- MOPSO多目标优化程序MATLAB代码.zip
- 基于粒子群算法的优化模型matlab程序
- 遗传算法完整MATLAB程序
- 遗传算法函数优化matlab代码
- 入侵杂草优化算法IWO的matlab实现
- 基于Matlab2018b的SimMechanics工具箱建立的
- 优化方法:最速下降、阻尼牛顿、共
- 无约束最优化的matlab代码
- matab源码 fmincon函数实用
- 基于粒子群算法和混沌搜索的协同优
- HookeJeeves优化程序
- PSO_GD.m粒子群求解多目标优化
- 基于遗传算法的OFDM自适应资源分配算
- MATLAB遗传算法工具箱
- 串级DMC+PID控制
- 磷虾群优化算法加入模拟退火思想和
- 粒子群优化CLPSO的MATLAB源代码
- 遗传算法-matlab代码
- matlab优化算法源码大全
- 优化问题测试函数matlab代码
- 变速积分PID控制算法PDF+MATLAB源程序
- 一种pid控制跟踪SIN函数的
- 英国设菲尔德大学遗传算法工具箱
- 模糊自适应PID控制的Matlab 仿真代码
评论
共有 条评论