遗传算法的C++代码实现教程(共14页).doc
《遗传算法的C++代码实现教程(共14页).doc》由会员分享,可在线阅读,更多相关《遗传算法的C++代码实现教程(共14页).doc(14页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上此例程总共包含3个文件:main.c(主函数);GA.c(包含3个所用函数);GA.h(头文件),3个文件截图如下:用visual c+或者visual stutio创建工程,然后将上述3个文件包含进工程,编译运行即可。亲测可行!3个文件代码分别如下:1、 main.c:#include#includeGA.husing namespace std;/* GA demo求函数y=x*sin(10*pai*x)+2.0的最大值编码:浮点数,1位初始群体数:50变异概率:0.8进化代数:100取值范围:0,4变异步长:0.004注:因为是单数浮点数编码,所以未使用基因重组
2、函数*/int main()GenEngine genEngine(50,0.8,0.8,1,100,0,4);genEngine.OnStartGenAlg();getchar();2、 GA.c:#include#include#include #include #include#includeGA.husing namespace std;/srand(unsigned) time(NULL);double random()double randNum;randNum=rand()*1.0/RAND_MAX;return randNum; GenAlg:GenAlg()void GenA
3、lg:init(int popsize, double MutRate, double CrossRate, int GenLenght,double LeftPoint,double RightPoint)popSize = popsize;mutationRate = MutRate;crossoverRate = CrossRate;chromoLength = GenLenght;totalFitness = 0;generation = 0;/fittestGenome = 0;bestFitness = 0.0;worstFitness = ;averageFitness = 0;
4、maxPerturbation=0.004;leftPoint=LeftPoint;rightPoint=RightPoint;/清空种群容器,以初始化vecPop.clear();for (int i=0; ipopSize; i+) /类的构造函数已经把适应性评分初始化为0vecPop.push_back(Genome();/把所有的基因编码初始化为函数区间内的随机数。for (int j=0; jchromoLength; j+)vecPopi.vecGenome.push_back(random() * (rightPoint - leftPoint) + leftPoint);voi
5、d GenAlg:Reset()totalFitness=0;/bestFitness=0; /worstFitness=9999;averageFitness=0;void GenAlg:CalculateBestWorstAvTot()for (int i=0; i=bestFitness)bestFitness=vecPopi.fitness;fittestGenome=vecPopi;if(vecPopi.fitness=worstFitness)worstFitness=vecPopi.fitness;averageFitness=totalFitness/popSize;Genom
6、e GenAlg: GetChromoRoulette()/产生一个0到人口总适应性评分总和之间的随机数./中m_dTotalFitness记录了整个种群的适应性分数总和)double Slice = (random() * totalFitness;/这个基因将承载转盘所选出来的那个个体.Genome TheChosenOne;/累计适应性分数的和.double FitnessSoFar = 0;/遍历总人口里面的每一条染色体。for (int i=0; i= Slice)TheChosenOne = vecPopi;break;/返回转盘选出来的个体基因return TheChosenOn
7、e;void GenAlg:Mutate(vector &chromo)/遵循预定的突变概率,对基因进行突变for (int i=0; ichromo.size(); +i)/如果发生突变的话if (random() mutationRate)/使该权值增加或者减少一个很小的随机数值chromoi += (random()-0.5) * maxPerturbation);/限定范围if(chromoi rightPoint)chromoi = leftPoint;/以上代码非基因变异的一般性代码只是用来保证基因编码的可行性。/此函数产生新的一代,见证着整个进化的全过程./以父代种群的基因组容器
8、作为参数传进去,该函数将往该容器里放入新一代的基因组(当然是经过了优胜劣汰的)void GenAlg:Epoch(vector &vecNewPop)/用类的成员变量来储存父代的基因组(在此之前m_vecPop储存的是不带估值的所有基因组)vecPop = vecNewPop;/初始化相关变量Reset();/为相关变量赋值CalculateBestWorstAvTot();/清空装载新种群的容器vecNewPop.clear(); /产生新一代的所有基因组while (vecNewPop.size() popSize)/转盘随机抽出两个基因Genome mum = GetChromoRoul
9、ette();Genome dad = GetChromoRoulette();/创建两个子代基因组vector baby1, baby2;/先把他们分别设置成父方和母方的基因baby1 = mum.vecGenome;baby2 = dad.vecGenome;/使子代基因发生基因突变Mutate(baby1);Mutate(baby2);/把两个子代基因组放到新的基因组容器里面vecNewPop.push_back( Genome(baby1, 0) );vecNewPop.push_back( Genome(baby2, 0) );/子代产生完毕/如果你设置的人口总数非单数的话,就会出现
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 遗传 算法 C+ 代码 实现 教程 14
限制150内