变异概率自适应调整的遗传算法GA程序

合集下载

遗传算法遗传算法

遗传算法遗传算法
11
(5)遗传算法在解空间进行高效启发式搜索,而非盲 目地穷举或完全随机搜索;
(6)遗传算法对于待寻优的函数基本无限制,它既不 要求函数连续,也不要求函数可微,既可以是数学解 析式所表示的显函数,又可以是映射矩阵甚至是神经 网络的隐函数,因而应用范围较广;
(7)遗传算法具有并行计算的特点,因而可通过大规 模并行计算来提高计算速度,适合大规模复杂问题的 优化。
26
(4)基本遗传算法的运行参数 有下述4个运行参数需要提前设定:
M:群体大小,即群体中所含个体的数量,一般取为 20~100; G:遗传算法的终止进化代数,一般取为100~500; Pc:交叉概率,一般取为0.4~0.99;
Pm:变异概率,一般取为0.0001~0.1。
27
10.4.2 遗传算法的应用步骤
遗传算法简称GA(Genetic Algorithms)是1962年 由美国Michigan大学的Holland教授提出的模拟自然 界遗传机制和生物进化论而成的一种并行随机搜索最 优化方法。
遗传算法是以达尔文的自然选择学说为基础发展起 来的。自然选择学说包括以下三个方面:
1
(1)遗传:这是生物的普遍特征,亲代把生物信息交 给子代,子代总是和亲代具有相同或相似的性状。生 物有了这个特征,物种才能稳定存在。
18
(3)生产调度问题 在很多情况下,采用建立数学模型的方法难以对生
产调度问题进行精确求解。在现实生产中多采用一些 经验进行调度。遗传算法是解决复杂调度问题的有效 工具,在单件生产车间调度、流水线生产车间调度、 生产规划、任务分配等方面遗传算法都得到了有效的 应用。
19
(4)自动控制。 在自动控制领域中有很多与优化相关的问题需要求
10

GA遗传算法概述

GA遗传算法概述

GA遗传算法概述GA遗传算法(Genetic Algorithm)是一种受生物进化理论启发的优化算法,用于解决问题的和优化。

它模拟了自然界中生物进化的过程,通过模拟“基因”在群体中的遗传、交叉和变异等过程,逐步优化空间中的解。

1. 群体:GA遗传算法使用一个群体(population)来表示可能的解集合,每个解称为个体(individual)。

群体中的个体通过染色体(chromosome)来表示,染色体则由基因(gene)组成。

基因可以是任意类型的变量,例如二进制、整数或实数。

2. 适应度函数:GA遗传算法通过适应度函数(fitness function)来评估每个个体的优劣程度。

适应度函数将每个个体映射到一个实值,表示该个体的适应度。

适应度值越高,个体越优秀。

3.选择:在选择阶段,GA遗传算法根据个体的适应度值来选择优秀个体作为父代。

通常使用轮盘赌选择法或锦标赛选择法来进行选择。

轮盘赌选择法根据个体的适应度值来分配选择的概率,适应度值越高的个体被选中的概率越大。

锦标赛选择法则随机选择一定数量的个体,然后从中选择适应度最高的个体作为父代。

4.交叉:在交叉阶段,GA遗传算法随机选择一对父代个体,并以一定的概率对它们的染色体进行交叉操作。

交叉操作可以通过染色体的位进行交换、重组或变异,产生新的个体。

5.变异:在变异阶段,GA遗传算法以一定的概率对个体的染色体进行变异操作,以增加空间的多样性。

变异操作可以是将染色体中的位进行随机翻转、替换或插入等操作。

6.遗传进化:通过选择、交叉和变异等操作,GA遗传算法不断迭代优化个体的染色体,使得适应度值不断提高。

经过多代的演化,群体中出现了越来越优秀的个体,最终达到最优解或接近最优解。

GA遗传算法可以用于求解各种优化问题,例如函数最大化、函数最小化、组合优化、排列问题等。

它的优点在于可以在大规模空间中进行高效,并且能够找到全局最优解或接近最优解。

然而,由于遗传算法的随机性质,它无法保证每次都能找到最优解,且算法的收敛速度较慢。

遗传算法的原理及MATLAB程序实现.

遗传算法的原理及MATLAB程序实现.

1 遗传算法的原理1.1 遗传算法的基本思想遗传算法(genetic algorithms,GA)是一种基于自然选择和基因遗传学原理,借鉴了生物进化优胜劣汰的自然选择机理和生物界繁衍进化的基因重组、突变的遗传机制的全局自适应概率搜索算法。

遗传算法是从一组随机产生的初始解(种群)开始,这个种群由经过基因编码的一定数量的个体组成,每个个体实际上是染色体带有特征的实体。

染色体作为遗传物质的主要载体,其内部表现(即基因型)是某种基因组合,它决定了个体的外部表现。

因此,从一开始就需要实现从表现型到基因型的映射,即编码工作。

初始种群产生后,按照优胜劣汰的原理,逐代演化产生出越来越好的近似解。

在每一代,根据问题域中个体的适应度大小选择个体,并借助于自然遗传学的遗传算子进行组合交叉和变异,产生出代表新的解集的种群。

这个过程将导致种群像自然进化一样,后代种群比前代更加适应环境,末代种群中的最优个体经过解码,可以作为问题近似最优解。

计算开始时,将实际问题的变量进行编码形成染色体,随机产生一定数目的个体,即种群,并计算每个个体的适应度值,然后通过终止条件判断该初始解是否是最优解,若是则停止计算输出结果,若不是则通过遗传算子操作产生新的一代种群,回到计算群体中每个个体的适应度值的部分,然后转到终止条件判断。

这一过程循环执行,直到满足优化准则,最终产生问题的最优解。

图1-1给出了遗传算法的基本过程。

1.2 遗传算法的特点1.2.1 遗传算法的优点遗传算法具有十分强的鲁棒性,比起传统优化方法,遗传算法有如下优点:1. 遗传算法以控制变量的编码作为运算对象。

传统的优化算法往往直接利用控制变量的实际值的本身来进行优化运算,但遗传算法不是直接以控制变量的值,而是以控制变量的特定形式的编码为运算对象。

这种对控制变量的编码处理方式,可以模仿自然界中生物的遗传和进化等机理,也使得我们可以方便地处理各种变量和应用遗传操作算子。

2. 遗传算法具有内在的本质并行性。

遗传算法步骤

遗传算法步骤

遗传算法(Genetic Algorithm,GA)是一种基于自然进化理论的算法,是一种可以对不同问题寻找最优解的智能算法,它可以用于优化因变
量组成的多为目标函数,使得其能够模拟自然群体中最优种群的复制
替代的演化过程。

GA的基本步骤如下:
1.初始化种群:随机选择或采用已有解法创建一个代表优化问题的群体,这一群体中包含多个个体,并对每一体对应一个可衡量适应度的值。

2.计算适应度:根据建模函数以及求解问题,计算每一体的适应度值,作为群体的适应度表示,该适应度值指示了当前群体的优劣,越高的
适应度表示越优秀的群体。

3.选择操作:通过自然选择决定种群接下来的演化趋势,选取进化最佳的个体,裁去低适应度的个体,做出自然选择的决定。

4.交叉操作:将于原始群体中优秀的体通过交叉进行基因交换,优化基因序列,达到更加精细化优化的进化效果。

5.变异操作:在交叉操作过后,某些个体的基因顺序经过一定的随机变异,添加新的基因组合,增强搜索空间的拓展能力。

6.重复上述步骤:将上述步骤重复进行,让群体在遗传进化过程中迭代优化,不断找寻最优解,最终终止整个搜索过程,达到满足目标。

以上就是GA的基本步骤,它不仅能够用于求解多种问题,而且运算
效率高,不需要事先设定初始值,使得对比其它算法更加方便和灵活。

但是,由于其随机性原因,在某些情况下可能得出的解不一定是最优解,使其在实际应用中并不尽如人意。

变异概率自适应调整的遗传算法GA程序

变异概率自适应调整的遗传算法GA程序

变异概率自适应调整的遗传算法算例一:优化函数:()()*sin 10*2,[1,2]f x x x x =+∈-+A.变异概率自适应调整公式:B.遗传算法参数 (1)种群规模设为80,遗传算子分别为轮盘法选择,多点点交叉和多点自适应变异;(2)交叉概率0.7,变异概率0.01;(3)最大进化代数为100代,保优操作。

C.程序框图图 1 程序流程框图()()12max 1max 1,,m m m avg avg m m avg P P f f P f f f f P P f f --⎧-≥⎪-=⎨⎪<⎩ 开始 确定实际问题参数对参数集进行编码 初始化群体P(t) 群体P(t+1)(更新) 位串解码得参数 计算目标函数值 函数值向适应值映射 适应值调整 选择、交叉、自适应变异群体评价 遗传操作 满足停止准则 结束二:程序及运行结果(1)%变异概率自适应调整的GA程序%优化函数为f=x*sin(10*x)+2,其中,-1=<x<=2%编码长度为12位%种群规模设为80,遗传算子分别为轮盘法选择,多点点交叉和多点自适应变异。

%交叉概率0.7,变异概率0.01%最大进化代数为100代,保优操作。

%**********************%主函数*****************************************function main()global chrom lchrom oldpop newpop varible fitness popsize sumfitness %定义全局变量global pcross pmutation temp bestfit maxfit gen bestgenglobal maxgen po pp mp nplchrom=12; %染色体长度popsize=80; %种群大小pcross=0.7; %交叉概率pmutation=0.01; %变异概率maxgen=100; %最大代数po=0.1; %淘汰概率pp=0.1; %保护概率mp=floor(pp*popsize); %保护的个数np=floor(po*popsize); %淘汰的个数initpop; % 初始化种群for gen=1:maxgenobjfun; %计算适应度值pp_po; %执行保优操作select; %选择操作selfmutation; %自变异操作crossover; %交叉操作endbestbestfit % 最佳个体适应度值输出bestgen % 最佳个体所在代数输出figuregen=1:maxgen;plot(gen,maxfit(1,gen)); % 进化曲线hold on;plot(bestgen,bestfit);xlabel('Generation');ylabel('Fitness');%********************** 产生初始种群 ************************************ function initpop()global lchrom oldpop popsize chromfor i=1:popsizechrom=rand(1,lchrom); % lchrom=12 染色体长度for j=1:lchromif chrom(1,j)<0.5chrom(1,j)=0;elsechrom(1,j)=1;endendoldpop(i,1:lchrom)=chrom;end%************************%计算适应度值************************************ function objfun()global lchrom oldpop fitness popsize chrom maxfit gen varible avgfiness savgfitness % a=0;b=3;a=0;b=10;for i=1:popsizechrom=oldpop(i,:);c=decimal(chrom);varible(1,i)=a+c*(b-a)/(2.^lchrom-1); %对应变量值fitness(1,i)=varible(1,i)*sin(10*varible(1,i))+2;avgfitness=sum(fitness)/popsize;lsort; % 个体排序maxfit(1,gen)=max(fitness); %求本代中的最大适应度值maxfit%************************二进制转十进制********************************** function c=decimal(chrom)global lchrom popsizec=0;for j=1:lchromc=c+chrom(1,j)*2.^(lchrom-j);end%************************* 个体从小到大排序 ************************ function lsort()global popsize fitness oldpopfor i=1:popsizej=i+1;while j<=popsizeif fitness(1,i)>fitness(1,j)tf=fitness(1,i); % 适应度值tc=oldpop(i,:); % 基因代码fitness(1,i)=fitness(1,j); % 适应度值互换oldpop(i,:)=oldpop(j,:); % 基因代码互换fitnescs(1,j)=tf;oldpop(j,:)=tc;endj=j+1;endend%*************************保优操作*****************************function pp_po()global popsize oldpop npi=np+1; % np=floor(po*popsize); %淘汰的个数npwhile i<=popsize %将(np+1)~popsize的个体放在toldpop中,共(popsize-np)个 toldpop(j,:)=oldpop(i,:);j=j+1;i=i+1;endfor i=1:(popsize-np) %从小到大顺序排列,将前面np个淘汰oldpop(i,:)=toldpop(i,:); % 适应度是否也要互换?end%*************************转轮法选择操作********************************** function select()global fitness popsize sumfitness oldpop temp mp npsumfitness=0; %个体适应度之和for i=1:(popsize-np-mp) % 仅计算(popsize-np-mp)个个体的选择概率sumfitness=sumfitness+fitness(1,i);endfor i=1:(popsize-mp-np) % 仅计算(popsize-np-mp)个个体的选择概率p(1,i)=fitness(1,i)/sumfitness; % 个体染色体的选择概率endq=cumsum(p); % 个体染色体的累积概率(内部函数),共(popsize-np-mp)个b=sort(rand(1,(popsize-mp))); % 产生(popsize-mp)个随机数,并按升序排列。

遗传算法函数ga用法

遗传算法函数ga用法

遗传算法函数ga用法matlab 遗传算法工具箱函数gamatlab 遗传算法工具箱函数及实例讲解核心函数:(1)function[pop]=initializega(num,bounds,eevalFN,eevalOps,options)-- 初始种群的生成函数【输出参数】pop--生成的初始种群【输入参数】num--种群中的个体数目bounds--代表变量的上下界的矩阵eevalFN--适应度函数eevalOps--传递给适应度函数的参数options-- 选择编码形式( 浮点编码或是二进制编码)[precisionF_or_B],如precision--变量进行二进制编码时指定的精度F_or_B--为1 时选择浮点编码,否则为二进制编码,由precision指定精度)(2)function[x,endPop,bPop,traceInfo]=ga(bounds,evalFN,ev alOps,startPop,opts,...termFN,termOps,selectFN,selectOps,xOverFNs,xOverOps,mutFN s,mutOps)--遗传算法函数【输出参数】x--求得的最优解endPop--最终得到的种群bPop--最优种群的一个搜索轨迹【输入参数】bounds--代表变量上下界的矩阵evalFN--适应度函数evalOps--传递给适应度函数的参数startPop-初始种群opts[epsilon prob_ops display]--opts(1:2)等同于initializega 的options 参数,第三个参数控制是否输出,一般为0。

如[1e-6 1 0]termFN--终止函数的名称,如['maxGenTerm']termOps--传递个终止函数的参数,如[100]selectFN--选择函数的名称,如['normGeomSelect']selectOps--传递个选择函数的参数,如[0.08]xOverFNs-- 交叉函数名称表,以空格分开,如['arithXover heuristicXoversimpleXover'] xOverOps--传递给交叉函数的参数表,如[2 0;2 3;2 0]mutFNs-- 变异函数表,如['boundaryMutation multiNonUnifMutation nonUnifMutation unifMutation'] mutOps--传递给交叉函数的参数表,如[4 0 0;6 100 3;4 100 3;4 0 0]注意】matlab 工具箱函数必须放在工作目录下运算借过为:x =同的初始群体)一定可以得到近似最优解。

遗传算法matlab程序代码

遗传算法matlab程序代码

遗传算法matlab程序代码
遗传算法(GA)是一种用于求解优化问题的算法,其主要思想是模拟
生物进化过程中的“选择、交叉、变异”操作,通过模拟这些操作,来寻
找最优解。

Matlab自带了GA算法工具箱,可以直接调用来实现遗传算法。

以下是遗传算法Matlab程序代码示例:
1.初始化
首先定义GA需要优化的目标函数f,以及GA算法的相关参数,如种
群大小、迭代次数、交叉概率、变异概率等,如下所示:
options = gaoptimset('PopulationSize',10,...
'Generations',50,...
2.运行遗传算法
运行GA算法时,需要调用MATLAB自带的ga函数,将目标函数、问
题的维度、上下界、约束条件和算法相关参数作为输入参数。

其中,上下
界和约束条件用于限制空间,防止到无效解。

代码如下:
[某,fval,reason,output,population] = ga(f,2,[],[],[],[],[-10,-10],[10,10],[],options);
3.结果分析
最后,将结果可视化并输出,可以使用Matlab的plot函数绘制出目
标函数的值随迭代次数的变化,如下所示:
plot(output.generations,output.bestf)
某label('Generation')
ylabel('Best function value')
总之,Matlab提供了方便易用的GA算法工具箱,开发者只需要根据具体问题定义好目标函数和相关参数,就能够在短时间内快速实现遗传算法。

GA遗传算法范文

GA遗传算法范文

GA遗传算法范文GA(Genetic Algorithm,遗传算法)是一种基于生物进化原理的优化算法,通过遗传、交叉和变异等操作来寻找最优解。

GA模拟了自然界中的进化过程,以一种更加高效的方式来解决复杂的问题。

本文将会对GA算法的原理、步骤以及应用进行详细介绍,并且分析其优势和不足之处。

GA算法的原理是受到达尔文的进化理论的启发。

在进化过程中,个体之间存在着遗传信息的交流,通过自然选择和适者生存的机制,最终会得到适应环境的个体。

GA算法也通过类似的方式来解决问题,首先定义了问题的适应度评估函数,然后通过遗传算子(如选择、交叉和变异)来产生新的解,并不断迭代,直到找到满足要求的解。

GA算法的步骤主要包括以下几个方面:1.初始化种群:生成初始的解集合,可以是随机生成的,也可以通过一些启发式算法生成。

2.确定适应度:对于每个个体,通过适应度函数来评估其适应能力。

适应度函数可以根据问题的特点进行设计,通常是一个数值来表示个体的优劣程度。

3.选择操作:根据适应度的大小,选择适应度较高的个体作为“父代”参与后续操作。

常用的选择方法有轮盘赌选择、锦标赛选择等。

4.交叉操作:选取两个父代个体,通过其中一种方式进行交叉,生成两个新的子代个体。

交叉的方式可以有很多种,如单点交叉、多点交叉等。

5.变异操作:对生成的子代个体进行变异操作,通过一定的概率进行基因的随机改变。

变异操作能够增加种群的多样性,避免陷入局部最优。

6.替换操作:将新生成的子代个体替换掉原来的父代个体,以保持种群的规模不变。

7.收敛判断:判断是否满足停止条件,如果满足则输出当前种群中的最优解,否则返回第3步。

GA算法的应用非常广泛。

例如在组合优化问题中,GA可以用来求解旅行商问题、背包问题等。

在机器学习中,GA可以用来进行特征选择、参数优化等。

在工程优化设计中,GA可以用来求解复杂的优化问题,如结构优化、布局优化等。

GA算法有一些明显的优势。

首先,GA算法具有全局能力,可以避免陷入局部最优解。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

变异概率自适应调整的遗传算法算例一:优化函数:()()*sin 10*2,[1,2]f x x x x =+∈-+A.变异概率自适应调整公式:B.遗传算法参数 (1)种群规模设为80,遗传算子分别为轮盘法选择,多点点交叉和多点自适应变异;(2)交叉概率0.7,变异概率0.01;(3)最大进化代数为100代,保优操作。

C.程序框图图 1 程序流程框图()()12max 1max 1,,m m m avg avg m m avg P P f f P f f f f P P f f --⎧-≥⎪-=⎨⎪<⎩ 开始 确定实际问题参数对参数集进行编码 初始化群体P(t) 群体P(t+1)(更新) 位串解码得参数 计算目标函数值 函数值向适应值映射 适应值调整 选择、交叉、自适应变异群体评价 遗传操作 满足停止准则 结束二:程序及运行结果(1)%变异概率自适应调整的GA程序%优化函数为f=x*sin(10*x)+2,其中,-1=<x<=2%编码长度为12位%种群规模设为80,遗传算子分别为轮盘法选择,多点点交叉和多点自适应变异。

%交叉概率0.7,变异概率0.01%最大进化代数为100代,保优操作。

%**********************%主函数*****************************************function main()global chrom lchrom oldpop newpop varible fitness popsize sumfitness %定义全局变量global pcross pmutation temp bestfit maxfit gen bestgenglobal maxgen po pp mp nplchrom=12; %染色体长度popsize=80; %种群大小pcross=0.7; %交叉概率pmutation=0.01; %变异概率maxgen=100; %最大代数po=0.1; %淘汰概率pp=0.1; %保护概率mp=floor(pp*popsize); %保护的个数np=floor(po*popsize); %淘汰的个数initpop; % 初始化种群for gen=1:maxgenobjfun; %计算适应度值pp_po; %执行保优操作select; %选择操作selfmutation; %自变异操作crossover; %交叉操作endbestbestfit % 最佳个体适应度值输出bestgen % 最佳个体所在代数输出figuregen=1:maxgen;plot(gen,maxfit(1,gen)); % 进化曲线hold on;plot(bestgen,bestfit);xlabel('Generation');ylabel('Fitness');%********************** 产生初始种群 ************************************ function initpop()global lchrom oldpop popsize chromfor i=1:popsizechrom=rand(1,lchrom); % lchrom=12 染色体长度for j=1:lchromif chrom(1,j)<0.5chrom(1,j)=0;elsechrom(1,j)=1;endendoldpop(i,1:lchrom)=chrom;end%************************%计算适应度值************************************ function objfun()global lchrom oldpop fitness popsize chrom maxfit gen varible avgfiness savgfitness % a=0;b=3;a=0;b=10;for i=1:popsizechrom=oldpop(i,:);c=decimal(chrom);varible(1,i)=a+c*(b-a)/(2.^lchrom-1); %对应变量值fitness(1,i)=varible(1,i)*sin(10*varible(1,i))+2;avgfitness=sum(fitness)/popsize;lsort; % 个体排序maxfit(1,gen)=max(fitness); %求本代中的最大适应度值maxfit%************************二进制转十进制********************************** function c=decimal(chrom)global lchrom popsizec=0;for j=1:lchromc=c+chrom(1,j)*2.^(lchrom-j);end%************************* 个体从小到大排序 ************************ function lsort()global popsize fitness oldpopfor i=1:popsizej=i+1;while j<=popsizeif fitness(1,i)>fitness(1,j)tf=fitness(1,i); % 适应度值tc=oldpop(i,:); % 基因代码fitness(1,i)=fitness(1,j); % 适应度值互换oldpop(i,:)=oldpop(j,:); % 基因代码互换fitnescs(1,j)=tf;oldpop(j,:)=tc;endj=j+1;endend%*************************保优操作*****************************function pp_po()global popsize oldpop npi=np+1; % np=floor(po*popsize); %淘汰的个数npwhile i<=popsize %将(np+1)~popsize的个体放在toldpop中,共(popsize-np)个 toldpop(j,:)=oldpop(i,:);j=j+1;i=i+1;endfor i=1:(popsize-np) %从小到大顺序排列,将前面np个淘汰oldpop(i,:)=toldpop(i,:); % 适应度是否也要互换?end%*************************转轮法选择操作********************************** function select()global fitness popsize sumfitness oldpop temp mp npsumfitness=0; %个体适应度之和for i=1:(popsize-np-mp) % 仅计算(popsize-np-mp)个个体的选择概率sumfitness=sumfitness+fitness(1,i);endfor i=1:(popsize-mp-np) % 仅计算(popsize-np-mp)个个体的选择概率p(1,i)=fitness(1,i)/sumfitness; % 个体染色体的选择概率endq=cumsum(p); % 个体染色体的累积概率(内部函数),共(popsize-np-mp)个b=sort(rand(1,(popsize-mp))); % 产生(popsize-mp)个随机数,并按升序排列。

mp为保护个体数j=1;k=1;while j<=(popsize-mp) % 从(popsize-mp-np)中选出(popsize-mp)个个体,并放入temp(j,:)中;if b(1,j)<q(1,k)temp(j,:)=oldpop(k,:);j=j+1;elsek=k+1;endendj=popsize-np-mp+1; % 从统一挪过来的(popsize-np-mp)以后个体——优秀个体中选择for i=(popsize-mp+1):popsize % 将mp个保留个体放入交配池temp(i,:),以保证群体数popsizetemp(i,:)=oldpop(j,:);j=j+1;end%*********************%自适应变异操作************************************* function selfmutation()global i popsize lchrom pmutation temp newpop oldpop mp fitness avgfitness maxfitnessm=lchrom*(popsize-mp); % 总的基因数pm1=pmutation;pm2=0.005;a=0;b=10;for i=1:popsizechrom=oldpop(i,:);c=decimal(chrom);varible(1,i)=a+c*(b-a)/(2.^lchrom-1); %对应变量值fitness(1,i)=varible(1,i)*sin(10*varible(1,i))+2; %目标函数if(fitness(1,i)>=avgfitness)pmutatio = pm1-(pm1-pm2)*(fitness(1,i)-avgfitness)/(maxfitness-avgfitness);elsepmutation = pm1;endendn=round(pmutation*m); % 变异发生的次数for i=1:n % 执行变异操作循环k=round(rand*(m-1))+1; %确定变异位置(四舍五入取整)j=ceil(k/lchrom); % 确定个体编号(取整)l=rem(k,lchrom); %确定个体中变位基因的位置(求余)if l==0temp(j,lchrom)=~temp(j,lchrom); % 取非操作elsetemp(j,l)=~temp(j,l); % 取非操作endendfor i=1:popsizenewpop(i,:)=temp(i,:); %产生新的个体oldpop(i,:)=newpop(i,:);end%**************************%交叉操作*************************************** function crossover()global temp popsize pcross lchrom mpn=floor(pcross*(popsize-mp)); %交叉发生的次数(向下取整)if rem(n,2)~=0 % 求余n=n+1; % 保证为偶数个个体,便于交叉操作endj=1;m=0;% 对(popsize-mp)个个体将进行随机配对,满足条件者将进行交叉操作(按顺序选择要交叉的对象)for i=1:(popsize-mp)p=rand; % 产生随机数if p<pcross % 满足交叉条件parent(j,:)=temp(i,:); % 选出1个父本k(1,j)=i;j=j+1; % 记录父本个数m=m+1; % 记录杂交次数if(j==3)&(m<=n) % 满足两个父本(j==3),未超过交叉次数(m<=n) pos=round(rand*(lchrom-1))+1; % 确定随机位数(四舍五入取整)for i=1:poschild1(1,i)=parent(1,i);child2(1,i)=parent(2,i);endfor i=(pos+1):lchromchild1(1,i)=parent(2,i);child2(1,i)=parent(1,i);endi=k(1,1);j=k(1,2);temp(i,:)=child1(1,:);temp(j,:)=child2(1,:);j=1;endendend%*********************%最佳个体******************************************** function best()global maxfit bestfit gen maxgen bestgenbestfit=maxfit(1,1);gen=2;while gen<=maxgenif bestfit<maxfit(1,gen)bestfit=maxfit(1,gen);bestgen=gen;endgen=gen+1;end0102030405060708090100024681012Generation F i t n e s s (2)运行结果A.程序运行结果:最优适应值解为bestfit= 11.4862 最优个体所在代数bestgen= 33B.程序运行结果图图2 程序运行结果图。

相关文档
最新文档