资源简介
使用MATLAB软件中的simulink模块,进行遗传算法PID控制仿真,实测成功!!
代码片段和文件信息
%Generic Algorithm for function f(x1x2) optimum
clear all;
close all;
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);
E(:1)=MinX(1)+(MaxX(1)-MinX(1))*rand(Size1);
E(:2)=MinX(2)+(MaxX(2)-MinX(2))*rand(Size1);
E(: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
x=E(i:);
[xBsJ]=GA_PID_Simulink_fitness(xBsJ);
BsJi(i)=BsJ;
end
[OderJiIndexJi]=sort(BsJi);
BestJ(kg)=OderJi(1);
BJ=BestJ(kg);
Ji=BsJi+1e-10; %Avoiding deviding zero
fi=1./Ji;
[OderfiIndexfi]=sort(fi); %Arranging fi small to bigger
Bestfi=Oderfi(Size); %Let Bestfi=max(fi)
BestS=E(Indexfi(Size):); %Let BestS=E(m) m is the Indexfi belong to max(fi)
bfi(kg)=Bestfi;
kg
x
BJ
%****** 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:)=E(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*E(i+1:)+(1-alfa)*E(i:);
TempE(i+1:)=alfa*E(i:)+(1-alfa)*E(i+1:);
end
end
TempE(Size:)=BestS;
E=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;
E=TempE;
end
BestS
Bestfi
fi
x
Best_J=BestJ(G)
figure(1);
plot(timeBestJ);
xlabel(‘Times‘);ylabel(‘Best J‘);
save pfile x;
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
目录 0 2017-03-03 16:03 遗传算法优化simuli
文件 2608 2017-03-03 11:09 遗传算法优化simuli
文件 235 2017-03-03 12:52 遗传算法优化simuli
文件 16722 2017-03-03 10:27 遗传算法优化simuli
文件 20243 2017-03-03 15:55 遗传算法优化simuli
- 上一篇:永磁直驱电机控制仿真simuli
nk模式 - 下一篇:MATLAB有限元仿真出图案例
相关资源
- 被动调Q激光器MATLAB仿真
-
两相交错并联 图腾柱PFC拓扑 simuli
- SVPWM整流器matlab仿真
- matlab中实现遗传算法求解旅行商问题
- 蚁群、粒子群、GA、TS等算法解决Job
- matlab遗传算法程序以求解函数的极值
- KUKA六关节机器人matlab仿真
-
三相电压不平衡度计算 simuli
nk模型 -
风力发电机整体MATLABSIMUli
nk建模 - 重频参差信号matlab仿真程序
- 同步电机模型的MATLAB仿真
- 信道化的matlab仿真实现
-
电路实验与MatlabSimuli
nk仿真 - matlab源码包括遗传算法等等
- 单神经元自适应PID控制器的研究及M
- 雷达信号matlab仿真
- 基于matlab的Iris、乳腺癌数据集的模式
- 免疫遗传算法,matlab
- a*启发式搜索算法的matlab仿真程序
- Turbo码Matlab仿真程序
- 基于遗传算法车间调度问题matlab程序
- 空时编码的MATLAB仿真
- gold序列MATLAB仿真
- matlab遗传算法geneticbx工具箱和安装步
-
高电压技术-气隙局部放电simuli
nk仿 - 放大器模型的matlab仿真实现
- RFID系统MATLAB仿真
- S曲线 MATLAB仿真通过
-
MATLAB PID simuli
nk - PID算法Matlab仿真程序和C程序[doc.xueh
评论
共有 条评论