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

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

?? ga.cpp

?? 遺傳算法的實現
?? 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("         統計結果:        ");
    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一区二区三区免费野_久草精品视频
日本成人中文字幕| 91搞黄在线观看| 97久久精品人人做人人爽| 在线不卡中文字幕播放| 综合欧美亚洲日本| 国产福利精品导航| 6080午夜不卡| 亚洲国产va精品久久久不卡综合| 国产伦精品一区二区三区视频青涩| 91老师片黄在线观看| 国产欧美日韩不卡免费| 激情综合网天天干| 9191久久久久久久久久久| 亚洲天天做日日做天天谢日日欢| 国产福利一区二区三区视频在线| 日韩精品一区二区在线观看| 亚洲成人资源网| 欧洲精品视频在线观看| 亚洲视频每日更新| 91丝袜呻吟高潮美腿白嫩在线观看| 国产女主播视频一区二区| 久久99精品国产麻豆婷婷| 日韩欧美在线123| 欧美96一区二区免费视频| 欧美日本视频在线| 亚洲午夜精品久久久久久久久| 丁香天五香天堂综合| 中文在线一区二区| 成人av影视在线观看| 亚洲国产高清在线| 成人一区二区三区视频 | 欧美日韩国产大片| 亚洲mv大片欧洲mv大片精品| 欧美在线视频全部完| 亚洲1区2区3区4区| 日韩欧美一级特黄在线播放| 日韩二区三区在线观看| 精品国产99国产精品| 国产精品一区二区x88av| 中文字幕不卡的av| 色久综合一二码| 首页国产欧美久久| 欧美xxxxx裸体时装秀| 国产成人av影院| 亚洲欧美aⅴ...| 欧美日韩激情一区二区| 麻豆精品精品国产自在97香蕉| 欧美成人video| 国产91对白在线观看九色| 亚洲视频图片小说| 69堂亚洲精品首页| 国产精品一区三区| 亚洲精品国产品国语在线app| 欧美图区在线视频| 九九热在线视频观看这里只有精品| 欧美v国产在线一区二区三区| 国产成人免费视频一区| 亚洲猫色日本管| 日韩欧美国产一区二区在线播放| 国产美女久久久久| 亚洲一区二区四区蜜桃| 精品国产一区二区三区不卡 | 国产在线播放一区二区三区| 国产精品亲子伦对白| 欧美日韩在线直播| 国产大陆a不卡| 亚洲成a人片综合在线| 中文字幕欧美区| 69p69国产精品| 99re在线视频这里只有精品| 蜜臀国产一区二区三区在线播放| 国产精品久久久久四虎| 日韩欧美123| 色婷婷综合视频在线观看| 精品无人区卡一卡二卡三乱码免费卡| 国产精品久久久久aaaa樱花| 日韩免费性生活视频播放| 一本高清dvd不卡在线观看| 久久99国内精品| 亚洲一区二区三区在线播放| 国产女主播在线一区二区| 欧美一区二区性放荡片| 91免费观看国产| 高清久久久久久| 男女男精品视频| 一区二区三区国产精品| 中文字幕精品一区二区精品绿巨人 | 久久久久久久性| 欧美一区二区视频在线观看2022| 91首页免费视频| 成人av在线播放网址| 国产盗摄视频一区二区三区| 久久99久久99| 奇米综合一区二区三区精品视频| 亚洲精品视频免费看| 亚洲欧洲日韩综合一区二区| 国产视频一区二区在线| 精品国产第一区二区三区观看体验| 欧美日韩卡一卡二| 色悠悠亚洲一区二区| 99re66热这里只有精品3直播 | 成人黄色免费短视频| 国内精品免费**视频| 久久99精品久久久久久国产越南| 天天综合天天做天天综合| 亚洲影视资源网| 亚洲综合在线电影| 亚洲午夜成aⅴ人片| 亚洲自拍偷拍网站| 亚洲一区二区四区蜜桃| 夜夜嗨av一区二区三区| 亚洲成人资源网| 日韩精品一二三四| 日本va欧美va精品发布| 麻豆精品视频在线观看免费| 狠狠色综合色综合网络| 精品在线一区二区| 久久国产精品第一页| 精一区二区三区| 国产成人精品影视| 99久久99久久精品免费观看 | 91在线看国产| 在线免费观看成人短视频| 欧美视频中文字幕| 欧美另类高清zo欧美| 精品久久人人做人人爱| 久久久亚洲高清| 综合久久久久久| 午夜一区二区三区视频| 麻豆国产精品视频| 国产91高潮流白浆在线麻豆| 色综合天天综合网国产成人综合天 | 中文字幕永久在线不卡| 一区二区三区在线视频播放| 日韩国产成人精品| 国产成人精品三级| 日本韩国欧美在线| 欧美电影免费观看高清完整版在线| 久久久国产午夜精品| 一区二区三区日韩欧美精品| 日韩国产欧美三级| 成人精品国产一区二区4080| 欧美日韩国产系列| 国产亚洲欧美激情| 一区二区三区 在线观看视频| 日韩va欧美va亚洲va久久| 国产二区国产一区在线观看| 欧美亚洲国产bt| 欧美成人性福生活免费看| 国产精品国产三级国产三级人妇| 天天爽夜夜爽夜夜爽精品视频| 国产剧情一区二区| 欧美三级乱人伦电影| 中文字幕欧美日本乱码一线二线| 亚洲第一久久影院| 成人av在线一区二区| 欧美一级午夜免费电影| 亚洲欧洲制服丝袜| 国内外成人在线视频| 欧美日韩午夜在线视频| 国产精品美女久久久久久久久| 日一区二区三区| 99精品视频一区二区三区| 欧美大片国产精品| 亚洲成av人**亚洲成av**| 成人黄色电影在线 | 欧美精品久久99| 国产精品不卡一区| 国产中文一区二区三区| 欧美精品成人一区二区三区四区| 日韩一区中文字幕| 国产91精品在线观看| 欧美一区二区在线视频| 亚洲综合色噜噜狠狠| 色综合久久天天| 国产精品伦一区| 国产成人精品一区二区三区网站观看| 69成人精品免费视频| 亚洲一区二区视频| 色八戒一区二区三区| 国产精品麻豆视频| 国产成人午夜精品5599| 久久这里只有精品首页| 免费人成网站在线观看欧美高清| 欧美亚洲一区三区| 亚洲综合色丁香婷婷六月图片| 97se亚洲国产综合在线| 亚洲视频一二三| 91免费视频网址| 亚洲欧美韩国综合色| 99精品一区二区三区| 中文字幕一区二区三区四区| 国产91在线|亚洲| 国产亚洲精品aa| 成人性色生活片免费看爆迷你毛片| 久久精品日产第一区二区三区高清版 | 精品久久久久av影院| 久久精品国产一区二区三 | 亚洲一区二区在线观看视频| 欧亚洲嫩模精品一区三区|