遗传算法(GA)【多元函数优化MATLAB】(二)

%% 多元函数优化
clc, clear
close all
 
%% 画出函数图
figure(1);
lbx = -2; ubx = 2;
lby = -2; uby = 2;
ezmesh('x*cos(2*pi*y) + y*sin(2*pi*x)', [lbx, ubx, lby, uby], 50);
hold on;
 
%% 定义遗传算法参数
nind = 40;      %种群大小
maxgen = 50;    %最大遗传迭代次数
preci = 20;     %个体长度
ggap = 0.95;    %代沟
px = 0.7;       %交叉概率
pm = 0.01;      %变异概率
trace = zeros(3, maxgen);               %寻优结果初始化
fieldd = [preci preci;lbx lby;ubx uby;1 1;0 0;1 1;1 1]; %区域描述器
chrom = crtbp(nind, preci * 2);         %种群初始化(任意离散随机种群)
 
%% 优化
gen = 0;                                                %代计数器
XY = bs2rv(chrom, fieldd);                              %初始种群二进制转十进制
X = XY(:, 1); Y = XY(:, 2); 
objv = X .* cos(2*pi*Y) + Y .* sin(2*pi*X);             %计算目标函数值
while gen < maxgen
    fitnv = ranking(-objv);                             %分配适应度值
    selch = select('sus', chrom, fitnv, ggap);          %选择
    selch = recombin('xovsp', selch, px);               %交叉
    selch = mut(selch, pm);                             %变异
    XY = bs2rv(selch, fieldd);                          %子代个体十进制转换
    X = XY(:, 1); Y = XY(:, 2);
    objvsel = X .* cos(2*pi*Y) + Y .* sin(2*pi*X);
    [chrom, objv] = reins(chrom, selch, 1, 1, objv, objvsel);   %重插入子代到父代,得到新种群
    XY = bs2rv(chrom, fieldd);
    gen = gen + 1;
    %获取每代的最优解及其序号,Y为最优解,i为个体的序号
    [Y, i] = max(objv);
    trace(1:2, gen) = XY(i, :);
    trace(3, gen) = Y;
end
plot3(trace(1, :), trace(2, :), trace(3, :), 'bo');   %绘制每一代的最优点
grid on;
plot3(XY(:, 1), XY(:, 2), objv, 'b*');
hold off
 
%% 画进化图
figure(2);
plot(1 : maxgen, trace(3, :));
grid on;
xlabel('遗传代数')
ylabel('解的变化')
title('进化过程')
best_z = trace(3, end);
best_y = trace(2, end);
best_x = trace(1, end);
fprintf(['最优解:\nX=', num2str(best_x), '\nY=', num2str(best_y), '\nZ=', num2str(best_z), '\n'])
最优解:
X=1.7627
Y=-2
Z=3.7563

图一为目标函数图,圈为每代的最优价。图中可以看出,圈大都集中在一个点,这个点即为最优解。图中标出的最优点和程序计算的有偏差,这是因为图一画出的是函数的离散点,并不是全部。

图二所示是种群优化50代的进化图。(这边可以改最大迭代次数)

PS:图一还可以拉来拉去,好好玩(像吃的薄饼)

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
简单的遗传算法,计算函数最值. function ga_main() % 遗传算法程序 % n-- 种群规模% ger-- 迭代次数% pc--- 交叉概率% pm-- 变异概率 % v-- 初始种群(规模为n)% f-- 目标函数值% fit-- 适应度向量 % vx-- 最优适应度值向量% vmfit-- 平均适应度值向量 clear all; close all; clc;%清屏 tic;%计时器开始计时 n=20;ger=100;pc=0.65;pm=0.05;%初始化参数 %以上为经验值,可以更改。 % 生成初始种群 v=init_population(n,22); %得到初始种群,22串长,生成20*22的0-1矩阵 [N,L]=size(v); %得到初始规模行,列 disp(sprintf('Number of generations:%d',ger)); disp(sprintf('Population size:%d',N)); disp(sprintf('Crossover probability:%.3f',pc)); disp(sprintf('Mutation probability:%.3f',pm)); %sprintf可以控制输出格式 % 待优化问题 xmin=0;xmax=9; %变量X范围 f='x+10*sin(x.*5)+7*cos(x.*4)'; % 计算适应度,并画出初始种群图形 x=decode(v(:,1:22),xmin,xmax);"位进制换成十进制,%冒号表示对所有行进行操作。 fit=eval(f);%eval转化成数值型的 %计算适应度 figure(1);%打开第一个窗口 fplot(f,[xmin,xmax]);%隐函数画图 grid on;hold on; plot(x,fit,'k*');%作图,画初始种群的适应度图像 title('(a)染色体的初始位置');%标题 xlabel('x');ylabel('f(x)');%标记轴 % 迭代前的初始化 vmfit=[];%平均适应度 vx=[]; %最优适应度 it=1; % 迭代计数器 % 开始进化 while it<=ger %迭代次数 0代 %Reproduction(Bi-classist Selection) vtemp=roulette(v,fit);%复制算子 %Crossover v=crossover(vtemp,pc);%交叉算子 %Mutation变异算子 M=rand(N,L)<=pm;%这里的作用找到比0.05小的分量 %M(1,:)=zeros(1,L); v=v-2.*(v.*M)+M;%两个0-1矩阵相乘后M是1的地方V就不变,再乘以2. NICE!!确实好!!!把M中为1的位置上的地方的值变反 %这里是点乘 %变异 %Results x=decode(v(:,1:22),xmin,xmax);%解码,求目标函数值 fit=eval(f); %计算数值 [sol,indb]=max(fit);% 每次迭代中最优目标函数值,包括位置 v(1,:)=v(indb,:); %用最大值代替 fit_mean=mean(fit); % 每次迭代中目标函数值的平均值。mean求均值 vx=[vx sol]; %最优适应度值 vmfit=[vmfit fit_mean];%适应度均值 it=it+1; %迭代次数计数器增加 end
MATLAB中,遗传算法可以通过ga函数实现。这个函数主要用于解决优化问题,特别是在求解Bin Packing问题中,可以利用遗传算法来进行求解。 在使用ga函数时,可以通过设置一些参数来控制算法的行为。例如,可以使用gaoptimset函数来设置迭代次数、种群大小、是否并行以及函数是否向量化等参数。例如,可以设置迭代次数为200,种群大小为50,是否并行为true,并指定函数是否向量化为'on'。 另外,在使用遗传算法求解问题时,可以使用fprintf函数将结果输出到文件中。例如,可以使用fprintf函数将变量x的数值按照一定的格式输出到文件中。这样可以方便地查看求解结果。 综上所述,遗传算法ga函数MATLAB中用于求解优化问题的一个函数,可以通过设置参数来控制算法的行为,并使用fprintf函数将结果输出到文件中。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [利用遗传算法(GA)、粒子群算法(PSO)、萤火虫算法(FA)和入侵杂草优化(IWO)求解Bin Packing问题的MATLA](https://download.csdn.net/download/weixin_39168167/88251667)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [matlab 遗传算法 ga函数实现并行](https://download.csdn.net/download/weixin_38751177/14885265)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [matlab遗传算法ga函数](https://blog.csdn.net/weixin_39789792/article/details/116158890)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值