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

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

?? population.cpp

?? 多目標優化進化算法目前公認效果收斂性最好的算法NSGA2c++源碼,具有一般性
?? CPP
字號:
///////////////////////////////////////////////////////////////////
/*****************************************************************
Copyright: Artificial Life and Adaptive Robotics Laboratory - ALAR
School of ITEE, UNSW@ADFA, Australia, 2005
*******************************************************************/
///////////////////////////////////////////////////////////////////#include "population.h"//////////////////////////////////////////////////////////////////////// Construction/Destruction//////////////////////////////////////////////////////////////////////population::population(){	pop_size=0;	individuals=NULL;	//rank=NULL;}population::population(int size){	individuals=NULL;	//rank=NULL;	set_pop_size(size);}population::~population(){		if (individuals) {	delete [] individuals;	individuals=NULL;}			//if (rank) {	delete [] rank;	rank=NULL;}	}int  population::check_dominationN(individual &id1, individual &id2){	int i;	int check1=TRUE,check2=FALSE;	for(i=0;i<id1.InumberofObjs;i++)	{		if (id1.DfitnessN[i]>id2.DfitnessN[i])		{			check1=FALSE;		}		else if (id1.DfitnessN[i]<id2.DfitnessN[i])		{			check2=TRUE;		}	}	return check1&&check2;}int  population::check_dominationC(individual &id1, individual &id2){	int i;	int check1=TRUE,check2=FALSE;	for(i=0;i<id1.InumberofObjs;i++)	{		if (id1.DfitnessC[i]>id2.DfitnessC[i])		{			check1=FALSE;		}		else if (id1.DfitnessC[i]<id2.DfitnessC[i])		{			check2=TRUE;		}	}	return check1&&check2;}int  population::check_ParetoOptimalN(individual &id1,int level){	int i,check=TRUE;	for(i=0;i<pop_size;i++)	{		if ((individuals[i].rank==-1)||(individuals[i].rank==level))			if (check_dominationN(individuals[i],id1))			{				check=FALSE;				break;			}	}	return check;}int  population::check_ParetoOptimalC(individual &id1,int level){	int i,check=TRUE;	for(i=0;i<pop_size;i++)	{		if ((individuals[i].rank==-1)||(individuals[i].rank==level))			if (check_dominationC(individuals[i],id1))			{				check=FALSE;				break;			}	}	return check;}void population::statistic(int g,ofstream &f){	cal_averagefitness();	cal_standarddeviation();	//population	print(g,f);	//print_ParetoOptimal(f);}void population::rankingC(){	int i,check=TRUE,level=0;		for (i=0;i<pop_size;i++)		individuals[i].rank=-1;
		while (1)	{		check=TRUE;		for (i=0;i<pop_size;i++)		{			if (individuals[i].rank==-1)			{				if (check_ParetoOptimalC(individuals[i],level))				{					individuals[i].rank=level;				}				check=FALSE;			}		}				if (check) break;		level++;	}		//rank store	rank_level=level;	}void population::rankingN(){	int i,check=TRUE,level=0;		for (i=0;i<pop_size;i++)		individuals[i].rank=-1;	while (1)	{		check=TRUE;		for (i=0;i<pop_size;i++)		{						if (individuals[i].rank==-1)			{				if (check_ParetoOptimalN(individuals[i],level))				{					individuals[i].rank=level;				}				check=FALSE;			}		}				if (check) break;		level++;	}		//rank store	rank_level=level;	}void population::cal_averagefitness(){	average_fitness=0;	for (int i=0;i<pop_size;i++)		average_fitness +=individuals[i].DglobalFitness;	average_fitness=average_fitness/pop_size;}void population::cal_standarddeviation(){	double s1=0,s2=0,temp=0;	for (int i=0;i<pop_size;i++)	{		temp=individuals[i].DglobalFitness;		s1+=temp*temp;		s2+=temp;	}	standard_deviation=(pop_size*s1-s2*s2)/(pop_size*(pop_size-1));}void population::set_pop_size(int s){	if (s!=pop_size)	{				pop_size=s;		if (individuals) {delete [] individuals; individuals=NULL;}		individuals= new individual[s];						for (int i=0;i<pop_size;i++)			individuals[i].rank=-1;	}}void population::print(int g, ofstream &f){	int i;	f<< "-----------GENERATION: " << g << " pop size: "<< pop_size << "--------------------------------------------------------" << endl;		for (i=0;i<pop_size;i++)		individuals[i].print_fn(f); 	//individuals[i].print_x(f); }void population::print_ParetoOptimal_fn(int g, ofstream &f,ofstream &f1){	//int c=0;	n_nondominated_set=0;	//	f << g << endl;	double min=D_MAX;    int i;	for (i=0;i<pop_size;i++)	{
		if (individuals[i].rank==0)		{			//individuals[i].print_fn(f);			n_nondominated_set++;			if (individuals[i].DfitnessN[1]<min) min=individuals[i].DfitnessN[1];		}	}	f1 << setiosflags(ios::fixed|ios::showpoint) << setprecision(3) << min << endl;		//f << "number of pareto set: " << n_nondominated_set << endl;}void population::print_ParetoOptimal_x(int g, ofstream &f){	//f << g << endl;	for (int i=0;i<pop_size;i++)		if (individuals[i].rank==0)		{			individuals[i].print_x(f);		}}

double population::diversity()
{
	int chromi,j;//,k;//,l;
	double diversity=0.0;
	int tt=pop_size*(pop_size-1)/2;
	for (chromi=0;chromi<pop_size-1;chromi++)
	{
		for (j=chromi+1;j<pop_size;j++)
			diversity += eDistance(individuals[chromi],individuals[j]);
	}
	return(diversity/(double)tt);
}

double population::eDistance(individual &id1, individual &id2)
{
	
	int i,N=id1.InumberofGenes;
	double temp=0;
	for (i=0;i<N;i++)
		temp+=pow((id1.Dgenes[i]-id2.Dgenes[i])/(id2.Dupper[i]-id2.Dlower[i] ),2) ;
	return sqrt(temp);
}

population &population::operator=(const population &pop){	int i;		set_pop_size(pop.pop_size);		rank_level			=	pop.rank_level;  	n_nondominated_set	=	pop.n_nondominated_set;		if (pop.individuals) 	{		for (i=0;i<pop_size;i++)			individuals[i] = pop.individuals[i]; 	}		for (i=0;i<pop_size;i++)		individuals[i].rank=pop.individuals[i].rank; 	return *this;		}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美性大战xxxxx久久久| 欧美四级电影在线观看| 亚洲尤物视频在线| 亚洲精品一区在线观看| 色美美综合视频| 韩日av一区二区| 婷婷中文字幕综合| 玉米视频成人免费看| 国产日韩精品久久久| 欧美一级片在线看| 欧美亚洲国产bt| av在线一区二区三区| 国产资源精品在线观看| 午夜欧美2019年伦理| 亚洲欧美色综合| 亚洲国产精品v| 337p日本欧洲亚洲大胆精品| 欧美亚洲尤物久久| 亚洲精品自拍动漫在线| 91久久奴性调教| 国产精品一区一区| 六月丁香婷婷久久| 亚洲国产wwwccc36天堂| 国产精品萝li| 久久久久99精品一区| 日韩欧美国产wwwww| 欧美日本在线看| 色琪琪一区二区三区亚洲区| 成人国产一区二区三区精品| 一本大道久久精品懂色aⅴ| 偷拍亚洲欧洲综合| 亚洲精品一二三四区| 最新高清无码专区| 国产精品毛片大码女人| 欧美国产丝袜视频| 国产清纯在线一区二区www| 久久九九影视网| 久久久久久久电影| 国产清纯白嫩初高生在线观看91 | 成人自拍视频在线观看| 国产伦精品一区二区三区免费迷| 国产在线麻豆精品观看| 精品一区二区三区免费| 久久99国产乱子伦精品免费| 麻豆国产欧美日韩综合精品二区| 美女性感视频久久| 久久91精品国产91久久小草| 精一区二区三区| 国产一区二区主播在线| 国产精品中文字幕欧美| 粉嫩aⅴ一区二区三区四区| 成人免费视频一区| 色综合色综合色综合色综合色综合| 91久久精品网| 欧美一区日本一区韩国一区| 日韩欧美视频在线| 国产日韩欧美综合一区| 国产精品久久久久久一区二区三区| 国产精品久久毛片a| 亚洲你懂的在线视频| 无码av中文一区二区三区桃花岛| 免费视频最近日韩| 国产精品自在欧美一区| 99久久婷婷国产综合精品| 欧美日韩一区二区三区高清| 日韩精品一区二区三区视频在线观看| 国产偷国产偷精品高清尤物| 亚洲精品视频免费观看| 天堂一区二区在线免费观看| 精品亚洲国内自在自线福利| 成人少妇影院yyyy| 欧美午夜片在线观看| 日韩一区二区精品在线观看| 国产精品天天摸av网| 亚洲va欧美va人人爽午夜| 麻豆精品一区二区综合av| 成人国产免费视频| 69久久99精品久久久久婷婷| 久久久精品欧美丰满| 亚洲一区二区在线观看视频| 精品一区二区三区在线视频| 99麻豆久久久国产精品免费优播| 欧美日韩你懂的| 国产色产综合产在线视频| 一区二区在线观看免费视频播放| 美日韩一级片在线观看| 成人福利在线看| 日韩欧美国产系列| 亚洲天堂网中文字| 国内精品免费**视频| 欧美影院一区二区三区| 国产欧美精品区一区二区三区 | 欧美激情一区在线| 香港成人在线视频| 9久草视频在线视频精品| 日韩欧美一区电影| 亚洲一区二区三区自拍| 国产不卡视频在线观看| 日韩精品一区二区在线观看| 亚洲色图一区二区| 国产成人激情av| 日韩欧美精品在线| 亚洲综合色视频| 99国产精品国产精品毛片| 2023国产精品视频| 蜜芽一区二区三区| 欧美色图第一页| 亚洲三级视频在线观看| 粉嫩aⅴ一区二区三区四区 | 在线亚洲一区二区| 日本一二三不卡| 国产乱码精品1区2区3区| 91精品国产91久久综合桃花| 亚洲综合视频在线观看| 99re这里只有精品6| 国产精品乱人伦| 国产精品主播直播| 亚洲精品一区二区精华| 欧美96一区二区免费视频| 欧美视频在线观看一区二区| 一区二区三区在线高清| 91一区在线观看| 国产精品久久久久久户外露出| 国产不卡在线播放| 国产三级精品三级| 国产精品综合二区| 久久亚洲欧美国产精品乐播| 老鸭窝一区二区久久精品| 日韩一区二区三区在线视频| 日韩精品每日更新| 91精品国产色综合久久| 日韩影院精彩在线| 欧美一区二区三区四区在线观看| 婷婷一区二区三区| 91精品欧美久久久久久动漫| 日韩精品一二区| 日韩你懂的电影在线观看| 九一九一国产精品| 欧美不卡激情三级在线观看| 精品在线亚洲视频| 久久久久久久久久看片| 国产电影一区在线| 中文字幕在线一区免费| 91碰在线视频| 亚洲国产一区视频| 欧美日韩激情一区二区三区| 免费看欧美女人艹b| 久久中文字幕电影| 岛国精品在线播放| 亚洲欧洲精品一区二区精品久久久| 波多野结衣中文字幕一区二区三区| 日韩理论片网站| 欧美日韩一区二区在线视频| 免费在线看成人av| 国产色产综合产在线视频| 99国产精品久| 婷婷国产在线综合| 久久这里只精品最新地址| 粉嫩久久99精品久久久久久夜| 亚洲免费观看高清完整版在线| 欧美麻豆精品久久久久久| 久久99精品久久久| 国产精品日韩精品欧美在线| 97精品超碰一区二区三区| 亚洲午夜一区二区| ww亚洲ww在线观看国产| 不卡电影一区二区三区| 天天免费综合色| 国产日本欧美一区二区| 在线视频欧美精品| 老司机精品视频导航| 国产精品久久久爽爽爽麻豆色哟哟| 色网站国产精品| 极品瑜伽女神91| 亚洲蜜臀av乱码久久精品蜜桃| 91精品一区二区三区在线观看| 国产在线播放一区二区三区| 伊人婷婷欧美激情| 久久婷婷成人综合色| 色久优优欧美色久优优| 狠狠色综合播放一区二区| 亚洲免费av网站| 久久色视频免费观看| 欧洲国产伦久久久久久久| 国内精品免费在线观看| 一区二区三国产精华液| 2021久久国产精品不只是精品| 91福利在线导航| 国产九九视频一区二区三区| 亚洲午夜精品网| 欧美经典三级视频一区二区三区| 欧美日韩大陆一区二区| 日韩一级片在线观看| 一本色道久久综合亚洲91 | 国产一区二区91| 亚洲欧美国产三级| 国产日韩精品一区二区三区 | 亚洲天堂成人网| 久久综合视频网| 欧美精品久久一区二区三区|