亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? vc_gad.cpp

?? 簡單遺傳算法VC實現
?? CPP
字號:
#include <stdio.h>
#include<stdlib.h>
#include<time.h>
#include<math.h>
#define POPSIZE 500
#define maximization 1
#define minimization 2
#define cmax 100
#define cmin 0
#define length1 10
#define length2 10
#define chromlength length1+length2  //染色體長度
 int functionmode=maximization;
 int popsize;        //種群大小
int maxgeneration;  //最大世代數
 double pc;          //交叉率
 double pm;          //變異率
struct individual
     {
      char  chrom[chromlength+1];
      double value;         
      double fitness;//適應度
};
int generation;      //世代數
int best_index;
int worst_index;
struct individual bestindividual;  //最佳個體
struct individual worstindividual; //最差個體
struct individual currentbest;
struct individual population[POPSIZE];
//函數聲明                                       
void generateinitialpopulation();                 
void generatenextpopulation();
void evaluatepopulation();
long decodechromosome(char *,int,int);
void calculateobjectvalue();
void calculatefitnessvalue();
void findbestandworstindividual();
void performevolution();
void selectoperator();
void crossoveroperator();
void mutationoperator();
void input();
void outputtextreport();

void generateinitialpopulation( )  //種群初始化
{
	int i,j;
	for (i=0;i<popsize; i++)
	{
		for(j=0;j<chromlength;j++)
	{
population[i].chrom[j]=(rand()%10<5)?'0':'1';
		}
		population[i].chrom[chromlength]='\0';
	}
}
void generatenextpopulation()  //生成下一代
{
	selectoperator();
	crossoveroperator();
	mutationoperator();
}
void evaluatepopulation()   //評價個體,求最佳個體
{
	calculateobjectvalue();
	calculatefitnessvalue();
	findbestandworstindividual();
}
long decodechromosome(char *string ,int point,int length) //給染色體解碼
{
	int i;
	long decimal=0;
	char*pointer;
for(i=0,pointer=string+point;i<length;i++,pointer++)
	if(*pointer-'0')

	{decimal +=(long)pow(2,i);
	}
	return (decimal);

}
void calculateobjectvalue()  //計算函數值
{
	int i;
	long temp1,temp2;
    double x1,x2;

	for (i=0; i<popsize; i++)
	{
		 temp1=decodechromosome(population[i].chrom,0,length1);
         temp2=decodechromosome(population[i].chrom,length1,length2);
         x1=4.096*temp1/1023.0-2.048;
         x2=4.096*temp2/1023.0-2.048;
population[i].value=100*(x1*x1-x2)* (x1*x1-x2)+(1-x1)*(1-x1);
}
}
void calculatefitnessvalue()//計算適應度
{
	int  i;
double temp;
   for(i=0;i<popsize;i++)
   {
 if(functionmode==maximization)
	   {if((population[i].value+cmin)>0.0)
  {temp=cmin+population[i].value;}
 else
 {temp=0.0;
   }
	   }
else if (functionmode==minimization)
 {
   if(population[i].value<cmax)
      {temp=cmax-population[i].value;}
    else{ temp=0.0;}
}
population[i].fitness=temp;
}
}
void findbestandworstindividual( ) //求最佳個體和最差個體
{
	int i;
	double sum=0.0;
	
	bestindividual=population[0];
	worstindividual=population[0];

	for (i=1;i<popsize; i++){
		if (population[i].fitness>bestindividual.fitness){
			bestindividual=population[i];
			best_index=i;
}
		else if (population[i].fitness<worstindividual.fitness)
{
			worstindividual=population[i];
			worst_index=i;
			
		}
        sum+=population[i].fitness;
}
if (generation==0){
		currentbest=bestindividual;
	}
	else{
		if(bestindividual.fitness>=currentbest.fitness){
			currentbest=bestindividual;
		}
	}
}
void performevolution() //演示評價結果
{
	if (bestindividual.fitness>currentbest.fitness){
		currentbest=population[best_index];
	}
	else{
		population[worst_index]=currentbest;
	}
}
void selectoperator() //比例選擇算法
{
	int i,index;
	double p,sum=0.0;
	double cfitness[POPSIZE];

	struct individual newpopulation[POPSIZE];
	for(i=0;i<popsize;i++)
{sum+=population[i].fitness;}

for(i=0;i<popsize; i++){
		cfitness[i]=population[i].fitness/sum;
	}

	for(i=1;i<popsize; i++){
		cfitness[i]=cfitness[i-1]+cfitness[i];
	}

	for (i=0;i<popsize;i++)
	{
		p=rand()%1000/1000.0;
		index=0;
		while (p>cfitness[index])
		{
			index++;
		}
		newpopulation[i]=population[index];
	}
	for(i=0;i<popsize; i++){
		population[i]=newpopulation[i];
	}
}
void crossoveroperator() //交叉算法
{
	int i,j;
	int index[POPSIZE];
	int point,temp;
	double p;
	char ch;

	
	for (i=0;i<popsize;i++){
		index[i]=i;
	}
	for (i=0;i<popsize;i++){
		point=rand()%(popsize-i);
		temp=index[i];
		index[i]=index[point+i];
		index[point+i]=temp;
	}

	
	for (i=0;i<popsize-1;i+=2){
		p=rand()%1000/1000.0;
		if (p<pc){
			point=rand()%(chromlength-1)+1;
			for (j=point; j<chromlength;j++){
				ch=population[index[i]].chrom[j];
				population[index[i]].chrom[j]=population[index[i+1]].chrom[j];
				population[index[i+1]].chrom[j]=ch;
			}
		}
	}

}
void mutationoperator() //變異操作
{
	int i,j;
	double p;
	
	for (i=0;i<popsize;i++){
		for(j=0;j<chromlength;j++){
			p=rand()%1000/1000.0;
			if (p<pm){
				population[i].chrom[j]=(population[i].chrom[j]=='0')?'1':'0';
			}
		}
	}
}
void input() //數據輸入
{   printf("初始化全局變量:\n");
	printf("    種群大小(50-500):");
   scanf("%d", &popsize);
    if((popsize%2) != 0)
      {
	printf( "   種群大小已設置為偶數\n");
	popsize++;};
    printf("     最大世代數(100-300):");
   scanf("%d", &maxgeneration);
   printf("     交叉率(0.2-0.99):");
   scanf("%f", &pc);
   printf("     變異率(0.001-0.1):");
   scanf("%f", &pm);
}
void outputtextreport()//數據輸出
{
	int i;
double sum;
double average;
sum=0.0;
for(i=0;i<popsize;i++)
{sum+=population[i].value;}
average=sum/popsize;
	
printf("當前世代=%d\n當前世代平均函數值=%f\n當前世代最高函數值=%f\n",generation,average,population[best_index].value);

}
void main()    //主函數
{   int i;
printf("本程序為求函數y=100*(x1*x1-x2)*(x1*x2-x2)+(1-x1)*(1-x1)的最大值 \n其中-2.048<=x1,x2<=2.048\n");
    generation=0;
    input();
    generateinitialpopulation();
	evaluatepopulation();
	while(generation<maxgeneration)
	{
		generation++;
		generatenextpopulation();
		evaluatepopulation();
		performevolution();
		outputtextreport();
	}
    printf("\n");
	printf("         統(tǒng)計結果:        ");
    printf("\n");
printf("最大函數值等于:%f\n",currentbest.fitness);
	printf("其染色體編碼為:");
	for (i=0;i<chromlength;i++)
	{
	printf("%c",currentbest.chrom[i]);
		
	}
    printf("\n"); 
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产视频一区二区| 国产精品一区二区x88av| 亚洲日本丝袜连裤袜办公室| 国产午夜精品久久| 欧美精品一区二区三区很污很色的 | 日韩一区二区视频在线观看| 欧美在线观看一区二区| 日本精品免费观看高清观看| 在线亚洲一区二区| 欧美日韩一区三区| 6080国产精品一区二区| 欧美日韩一区二区三区不卡| 欧美日韩一区 二区 三区 久久精品| 在线观看免费亚洲| 欧美浪妇xxxx高跟鞋交| 337p亚洲精品色噜噜| 欧美哺乳videos| 日本一区二区三区久久久久久久久不 | 在线不卡免费av| 91精品国产91热久久久做人人| 在线综合亚洲欧美在线视频| 精品国产一区二区三区久久久蜜月| 26uuu亚洲综合色| 国产精品美女www爽爽爽| 有码一区二区三区| 免费在线观看不卡| 成人美女视频在线看| 日本福利一区二区| 在线不卡欧美精品一区二区三区| 精品国产伦一区二区三区观看体验 | 97久久精品人人做人人爽50路| 欧美综合天天夜夜久久| 日韩欧美在线综合网| 国产亚洲视频系列| 一区二区三区四区高清精品免费观看| 亚洲va国产天堂va久久en| 国产一区二区三区不卡在线观看 | 精品国一区二区三区| 国产精品福利影院| 日韩电影在线看| 成人午夜视频在线观看| 欧美系列在线观看| 精品播放一区二区| 亚洲天堂网中文字| 久久精品国产99国产| 成人aa视频在线观看| 9191久久久久久久久久久| 国产亚洲精品资源在线26u| 综合久久给合久久狠狠狠97色| 青椒成人免费视频| 99久久99久久精品免费观看| 91麻豆精品国产91久久久| 国产精品妹子av| 青青草国产成人av片免费| 色悠悠久久综合| 欧美成人精品高清在线播放| 一区二区三区在线观看欧美| 国产精品资源在线| 在线成人午夜影院| 亚洲美女视频在线| 国产成人免费在线| 在线成人av网站| 亚洲日本在线a| 国产999精品久久久久久| 欧美日韩中文一区| 国产精品私人影院| 久久国产精品72免费观看| 91国在线观看| 久久亚洲综合色一区二区三区| 亚洲电影中文字幕在线观看| 成人h动漫精品| 亚洲精品在线观看网站| 天堂va蜜桃一区二区三区漫画版| 成人h动漫精品一区二区| 久久综合久久综合久久综合| 午夜精品一区二区三区免费视频| 成人黄色av电影| 久久精品视频在线看| 精品一区二区在线看| 欧美色倩网站大全免费| 亚洲欧美中日韩| 成人在线综合网站| 精品人伦一区二区色婷婷| 无码av免费一区二区三区试看| 91免费视频网| 亚洲欧洲美洲综合色网| 国产很黄免费观看久久| 欧美大片拔萝卜| 日韩精品欧美成人高清一区二区| 色综合天天综合在线视频| 国产精品人成在线观看免费| 国产精品一区二区免费不卡| 精品国产自在久精品国产| 日本欧美加勒比视频| 欧美一区二区三区在线电影| 亚洲第一主播视频| 欧美日韩综合不卡| 日韩精品亚洲专区| 777午夜精品视频在线播放| 亚洲成人1区2区| 欧美日韩在线综合| 亚洲综合av网| 欧美午夜一区二区三区| 亚洲主播在线播放| 欧美三级视频在线| 午夜精品福利一区二区蜜股av| 欧美日本在线播放| 免费人成黄页网站在线一区二区| 日韩一区二区三区视频在线| 天天av天天翘天天综合网色鬼国产 | 欧美中文字幕久久| 一区二区三区精品在线| 欧美婷婷六月丁香综合色| 亚洲国产日日夜夜| 91精品一区二区三区久久久久久 | 六月丁香婷婷久久| www成人在线观看| 国产一区二区中文字幕| 欧美激情在线一区二区| 99视频精品全部免费在线| 亚洲精品一二三区| 欧美日韩日日摸| 美国三级日本三级久久99| 欧美大片一区二区三区| 高清日韩电视剧大全免费| 中文字幕人成不卡一区| 91福利在线免费观看| 日韩精品成人一区二区三区| 日韩欧美另类在线| 成人午夜在线免费| 亚洲国产综合人成综合网站| 日韩一区二区三区四区| 国产丶欧美丶日本不卡视频| 国产精品国产三级国产aⅴ中文 | 欧美日韩大陆一区二区| 久久99这里只有精品| 欧美国产亚洲另类动漫| 日本精品一级二级| 久久国产精品72免费观看| 亚洲欧洲成人av每日更新| 欧美日韩aaaaa| 国产成人av电影在线观看| 亚洲精品免费视频| 精品91自产拍在线观看一区| av在线一区二区三区| 丝瓜av网站精品一区二区| 欧美韩国日本不卡| 在线播放视频一区| 丁香婷婷综合网| 日韩av电影一区| 国产精品美日韩| 日韩欧美国产电影| 色综合久久综合中文综合网| 蜜桃在线一区二区三区| 亚洲视频免费观看| 欧美va亚洲va| 欧美性受xxxx| 成人午夜激情在线| 蜜桃视频免费观看一区| 亚洲欧洲日产国产综合网| 日韩欧美一级精品久久| 91成人在线观看喷潮| 国产一区二区三区久久悠悠色av| 亚洲愉拍自拍另类高清精品| 日本一区二区视频在线观看| 777奇米四色成人影色区| gogogo免费视频观看亚洲一| 麻豆国产欧美一区二区三区| 亚洲中国最大av网站| 中文字幕欧美国产| 欧美sm极限捆绑bd| 91精品免费观看| 色国产综合视频| 成人h动漫精品一区二区| 国内精品久久久久影院色 | 91久久国产综合久久| 国产乱码精品1区2区3区| 婷婷综合久久一区二区三区| 成人欧美一区二区三区小说 | 亚洲一线二线三线视频| 亚洲国产精品成人久久综合一区| 日韩欧美专区在线| 欧美精品第1页| 欧美影视一区在线| 波多野结衣欧美| 国产成人三级在线观看| 精品一区二区三区免费毛片爱| 五月天网站亚洲| 亚洲在线视频一区| 又紧又大又爽精品一区二区| 最新高清无码专区| 国产精品理论在线观看| 国产婷婷色一区二区三区| 欧美成人艳星乳罩| 日韩美女主播在线视频一区二区三区| 欧美精品高清视频| 这里是久久伊人| 日韩一区国产二区欧美三区| 欧美美女直播网站| 在线不卡免费av|