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

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

?? genetic.cpp

?? 用C++語言在VC++環境下編寫的遺傳算法源程序
?? CPP
字號:
//頭文件:		Genetic.hpp
//目的:			為遺傳算法提供基類,該基類將評價函數值直接作為適合度,采用
//				新個體直接替換老個體的整體再生法
//語言:			VC++ 6.0
//注意:			EvalVal(INDIVIDUAL&)應由用戶類覆蓋,以提供正確的評價函數.
//////////////////////////////////////////////////////////////////////

#include <stdlib.h>
#include "Genetic.hpp"

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

Genetic::Genetic()
{
	IndNumber = 0;
	GeneLen = 0;
	Elitism = ELITISM;
	Cross = ONE_POINT;
	Parameter = GEN_FIXED;
	OperatorFit[0]=60;  OperatorFit[1]=OperatorFit[0]+40;
	OperatorStart[0] = 70; OperatorStart[1] = 30;
	OperatorEnd[0] = 50; OperatorEnd[1] = 50;
	CrossProb = 0.8;
	MutProb = 0.01;
	ElitismProb = 0.1;
	CurrentChild = 0;
	ChildrenNum = IndNumber;
	Individual = 0;
	Children = 0;
	IndIndex = 0;
	FitIndex = 0;
	Communication = NULL;
}
Genetic::Genetic(int n, int gl)
{
	IndNumber = n;
	GeneLen = gl;
	Elitism = ELITISM;
	Cross = ONE_POINT;
	Parameter = GEN_FIXED;
	OperatorFit[0]=60;  OperatorFit[1]=OperatorFit[0]+40;
	OperatorStart[0] = 70; OperatorStart[1] = 30;
	OperatorEnd[0] = 50; OperatorEnd[1] = 50;
	CrossProb = 0.8;
	MutProb = 0.01;
	ElitismProb = 0.1;
	CurrentChild = 0;
	ChildrenNum = IndNumber;
	IndInit();
	Communication = NULL;
}
Genetic::Genetic(Genetic& g)
{
	Elitism = g.Elitism;
	Cross = g.Cross;
	Parameter = g.Parameter;
	OperatorFit[0] = g.OperatorFit[0];
	OperatorFit[1] = g.OperatorFit[1];
	OperatorStart[0] = g.OperatorStart[0];
	OperatorStart[1] = g.OperatorStart[1];
	OperatorEnd[0] = g.OperatorEnd[0];
	OperatorEnd[1] = g.OperatorEnd[1];
	CrossProb = g.CrossProb;
	MutProb = g.MutProb;
	IndNumber = g.IndNumber;
	GeneLen = g.GeneLen;
	CurrentChild = g.CurrentChild;
	ChildrenNum = g.ChildrenNum;
	ElitismProb = g.ElitismProb;
	Communication = g.Communication;
	IndInit();
	for(int i=0; i<IndNumber; i++)
	{
		Individual[i].Chrom = g.Individual[i].Chrom;
		Individual[i].Fit = g.Individual[i].Fit;
		Individual[i].Val = g.Individual[i].Val;
		FitIndex[i] = g.FitIndex[i];
		IndIndex[i] = g.IndIndex[i];
	}
}

Genetic::~Genetic()
{
	if(Individual) delete []Individual;
	if(Children) delete []Children;
	if(IndIndex) delete []IndIndex;
	if(FitIndex) delete []FitIndex;
}

//設置個體數和個體長度
void Genetic::SetNumLen(int IndN, int GLen)
{
	if(Individual) delete []Individual;
	if(Children) delete []Children;
	if(IndIndex) delete []IndIndex;
	if(FitIndex) delete []FitIndex;
	IndNumber = IndN;
	GeneLen = GLen;
	ChildrenNum = IndNumber;
	IndInit();
}

//個體初始化
bool Genetic::IndInit()
{
	Individual = new INDIVIDUAL[IndNumber];
	Children = new INDIVIDUAL[IndNumber];
	IndIndex = new int[IndNumber];
	FitIndex = new double[IndNumber];
	if(Individual && Children && IndIndex && FitIndex) 
	{
		for(int i=0; i<IndNumber; i++)
		{
			Individual[i].Chrom.SetLen(GeneLen);
			Children[i].Chrom.SetLen(GeneLen);
			IndIndex[i] = i;
		}
		return true;
	}
	else return false;
}
//計算總適合度
void Genetic::CalFitIndex()
{
	double allfit = 0;
	for(int i=0; i<IndNumber; i++)
	{
		allfit += Individual[i].Fit-Individual[IndIndex[IndNumber-1]].Fit;
		FitIndex[i] = allfit;
	}
}
//設置交叉變異適合度
void Genetic::SetOperator(double c, double m)
{
	OperatorFit[0] = c;
	OperatorFit[1] = OperatorFit[0]+m;
}
//設置標志集
void Genetic::SetFlags(CROSS_METHOD c, ELITISM_METHOD e, PARAMETER_METHOD p)
{
	Cross = c;
	Elitism = e;
	Parameter = p;
}
//設置交叉率和變異率
void Genetic::SetProbability(double c, double m)
{
	CrossProb = c;
	MutProb = m;
}
//獲得第i個個體基因字串
const char* Genetic::GetGeneStr(int i)
{
	return Individual[i].Chrom.GetGeneStr();
}
//計算所有個體適合度
void Genetic::AllFit()
{
	for(int i=0; i<IndNumber; i++)
		GetFit(i);
}
//個體適合度計算
double Genetic::GetFit(int i)
{
	Individual[i].Fit = Individual[i].Val;
	return Individual[i].Fit;
}
//計算所有個體評價函數值
void Genetic::AllVal()
{
	for(int i=0; i<IndNumber; i++)
		GetVal(i);
}
//計算個體評價函數值
double Genetic::GetVal(int i)
{
	return EvalVal(Individual[i]);
}
//滾輪選擇方法
int Genetic::Wheel(double* index, int len)
{
	double random = (rand()/(double)RAND_MAX)*index[len-1];
	int i = 0;
	while(random>index[i] && i<len-1) i++;
	return i;
}
//雙親選擇方法
int Genetic::ParentSelect()
{
	return Wheel(FitIndex,IndNumber);
}
//按適合度排序索引數組
void Genetic::IndexSort()
{
	for(int i=0; i<IndNumber; i++)
	{
		int max = i;
		for(int j=i; j<IndNumber; j++)
			if(Individual[IndIndex[max]].Val<Individual[IndIndex[j]].Val)
				max = j;
		int t = IndIndex[max];
		IndIndex[max] = IndIndex[i];
		IndIndex[i] = t;
	}
}
//算子選擇方法:0-交叉算子,1-變異算子
int Genetic::OperatorSelect()
{
	return Wheel(OperatorFit,2);
}
//變異再生方法
void Genetic::GenMutation()
{
	if(CurrentChild>=ChildrenNum) return;
	int parent = ParentSelect();
	Children[CurrentChild].Chrom = Individual[parent].Chrom.Mutation(MutProb);
	CurrentChild++;
}
//交叉再生方法
void Genetic::GenCross()
{
	if(CurrentChild>=ChildrenNum-1) return;
	int parent1 = ParentSelect();
	int parent2 = ParentSelect();
	if((rand()/(double)RAND_MAX)<CrossProb)
	{
		if(Cross == ONE_POINT)
			Individual[parent1].Chrom.OneCross(Individual[parent2].Chrom,
											   Children[CurrentChild].Chrom,
											   Children[CurrentChild+1].Chrom);
		else if(Cross == TWO_POINT)
			Individual[parent1].Chrom.TwoCross(Individual[parent2].Chrom,
											   Children[CurrentChild].Chrom,
											   Children[CurrentChild+1].Chrom);
		else
			Individual[parent1].Chrom.UniCross(Individual[parent2].Chrom,
											   Children[CurrentChild].Chrom,
											   Children[CurrentChild+1].Chrom);
	}
	else
	{
		Children[CurrentChild].Chrom = Individual[parent1].Chrom;
		Children[CurrentChild+1].Chrom = Individual[parent2].Chrom;
	}
	CurrentChild += 2;
}
//精英方法
void Genetic::GenElitism()
{
	int elitismNum = int(ChildrenNum*ElitismProb);
	if(elitismNum <1) elitismNum = 1;
	if(CurrentChild+elitismNum>IndNumber)
		elitismNum = IndNumber-CurrentChild;
	for(int i=CurrentChild; i<CurrentChild+elitismNum; i++)
		Children[i].Chrom = Individual[IndIndex[i]].Chrom;
	CurrentChild += elitismNum;
}
//產生新一代
void Genetic::Generation()
{
	CurrentChild = 0;
	if(Elitism==ELITISM) GenElitism();
	while(CurrentChild < ChildrenNum-1)
	{
		if(OperatorSelect()==1 || CurrentChild>=ChildrenNum-1)
			GenMutation();
		else
			GenCross();
	}
	INDIVIDUAL *tmpInd;
	tmpInd = Individual;
	Individual = Children;
	Children = tmpInd;
//	for(int i=0; i<ChildrenNum; i++)
//		Individual[IndIndex[IndNumber-i-1]].Chrom = Children[i].Chrom;
	Prepare();
}
//運行遺傳算法
const char* Genetic::Run(unsigned long gn)
{
	Prepare();
	double OperatorStep=0;
	if(Parameter == GEN_INTERPOLATION)
		OperatorStep = (OperatorEnd[0]-OperatorStart[0])/gn;
	for(unsigned long generator=0; generator<gn; generator++)
	{
		if(Parameter == GEN_INTERPOLATION)
			OperatorFit[0] += OperatorStep;
		Generation();
		if(Communication!=NULL)
			Communication(Individual[IndIndex[0]].Chrom.GetGeneStr(),
				Individual[IndIndex[0]].Fit,
				Individual[IndIndex[0]].Val);
	}
	return Individual[IndIndex[0]].Chrom.GetGeneStr();
}
//準備遺傳運算
void Genetic::Prepare()
{
	AllVal();
	IndexSort();
	AllFit();
	CalFitIndex();
}
//設置初始算子適合度
void Genetic::SetOptStartEnd(double s1,double e1,double s2,double e2)
{
	OperatorStart[0] = s1;
	OperatorStart[1] = s2;
	OperatorEnd[0] = e1;
	OperatorEnd[1] = e2;
	OperatorFit[0] = OperatorStart[0];
	OperatorFit[1] = OperatorStart[0]+OperatorEnd[0];
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99天天综合性| 亚洲青青青在线视频| 97精品久久久午夜一区二区三区| 欧美一级淫片007| 不卡av电影在线播放| 久久免费偷拍视频| 精品国产污污免费网站入口 | av在线不卡免费看| 免费看欧美女人艹b| 日韩电影在线看| 国产高清不卡一区二区| 奇米色777欧美一区二区| 日韩高清在线一区| 久久精品国产一区二区| 国产乱国产乱300精品| 丁香五精品蜜臀久久久久99网站| 成人综合婷婷国产精品久久免费| 成人动漫av在线| 一道本成人在线| 91麻豆精品国产| 久久婷婷久久一区二区三区| 国产日韩av一区二区| 综合中文字幕亚洲| 精品一区二区三区香蕉蜜桃 | 在线免费观看日本欧美| 色偷偷久久人人79超碰人人澡| 99麻豆久久久国产精品免费优播| yourporn久久国产精品| 91国在线观看| 欧美成人r级一区二区三区| 国产日产欧美一区二区三区| 中文字幕乱码日本亚洲一区二区| 亚洲欧洲精品天堂一级| 亚洲国产色一区| 精品一区二区三区视频在线观看| 99视频精品在线| 欧美精品亚洲一区二区在线播放| 久久亚洲影视婷婷| 亚洲人成亚洲人成在线观看图片 | 午夜婷婷国产麻豆精品| 国产精品亚洲第一| 欧美亚洲综合色| 久久看人人爽人人| 亚洲福利一区二区| 成人激情av网| 欧美成人一级视频| 亚洲自拍偷拍九九九| 日本韩国精品一区二区在线观看| 91精品国产综合久久蜜臀| 国产精品美女久久久久aⅴ国产馆| 亚洲午夜精品一区二区三区他趣| 国产裸体歌舞团一区二区| 精品视频在线视频| 欧美国产精品一区二区| 美腿丝袜在线亚洲一区| 色噜噜久久综合| 久久久久久久久一| 全国精品久久少妇| 一本久久精品一区二区| 中文av一区特黄| 免费高清在线视频一区·| 91视频在线看| 中文字幕中文字幕在线一区 | 国产精品一卡二卡在线观看| 在线这里只有精品| 91麻豆精品国产91久久久久 | 欧美v国产在线一区二区三区| 久久久91精品国产一区二区精品| 亚洲图片欧美色图| www.在线欧美| 国产欧美日韩另类一区| 九色综合国产一区二区三区| 欧美日韩三级一区二区| 亚洲特黄一级片| 波多野结衣中文一区| 国产欧美一区二区在线观看| 精品一区二区三区av| 日韩亚洲欧美一区二区三区| 婷婷丁香激情综合| 欧美久久一区二区| 成人精品视频一区二区三区| 26uuu国产一区二区三区| 久久国产夜色精品鲁鲁99| 日韩欧美高清在线| 亚洲欧美日韩久久| 97久久超碰国产精品电影| 欧美在线视频全部完| 夜夜精品视频一区二区 | 99久久99久久免费精品蜜臀| 国产校园另类小说区| 粉嫩嫩av羞羞动漫久久久| 国产精品免费人成网站| 99免费精品在线| 伊人色综合久久天天| 欧美日本在线看| 青草国产精品久久久久久| 欧美大片拔萝卜| 成人美女视频在线看| 亚洲女子a中天字幕| 51精品秘密在线观看| 韩国女主播成人在线观看| 亚洲国产电影在线观看| 在线观看亚洲a| 男女男精品视频| 国产精品卡一卡二卡三| 亚洲aⅴ怡春院| 日韩电影免费一区| 国内成人免费视频| 国产欧美一区二区三区在线看蜜臀| 成人国产一区二区三区精品| 亚洲国产精品一区二区www | www.激情成人| 亚洲成人手机在线| 久久久久97国产精华液好用吗| 99re免费视频精品全部| 人禽交欧美网站| 中文字幕一区在线观看视频| 91麻豆精品国产91久久久使用方法| 国产麻豆91精品| 天天亚洲美女在线视频| 欧美韩国日本不卡| 欧美一区二区在线免费观看| 99精品在线观看视频| 免费在线一区观看| 一区二区三区免费| 久久久综合精品| 久久99精品久久久久久动态图| 亚洲不卡一区二区三区| 国产欧美日韩在线| 欧美一级欧美三级在线观看| 波多野结衣的一区二区三区| 久久超级碰视频| 午夜影院在线观看欧美| 中文字幕日本不卡| 久久九九国产精品| 日韩午夜激情av| 欧美日韩亚洲综合在线| 9人人澡人人爽人人精品| 国产一本一道久久香蕉| 日本在线不卡视频一二三区| 亚洲制服丝袜av| 最新国产の精品合集bt伙计| 久久午夜色播影院免费高清 | 全国精品久久少妇| 国产69精品久久久久毛片| 久久精品久久精品| 蜜臀av一区二区| 美腿丝袜亚洲色图| 日日夜夜免费精品| 成人在线视频首页| 精品日韩欧美一区二区| 五月天激情综合网| 一区二区在线看| 亚洲视频一二三| 亚洲免费观看高清完整| 亚洲欧美在线观看| 亚洲色图在线看| 中文字幕亚洲精品在线观看| 中文字幕一区二区视频| 国产精品久久久久久亚洲毛片| 国产女主播在线一区二区| 国产日韩欧美一区二区三区综合| 欧美成人乱码一区二区三区| 精品欧美久久久| 337p粉嫩大胆色噜噜噜噜亚洲| 精品国产伦理网| 国产亚洲精久久久久久| 国产色产综合产在线视频| 国产精品你懂的在线| 国产精品剧情在线亚洲| 亚洲黄一区二区三区| 亚洲国产一区二区视频| 水蜜桃久久夜色精品一区的特点| 亚洲成av人片在线| 亚洲成人av在线电影| 免费观看日韩电影| 欧美美女直播网站| 日韩欧美国产一区二区三区| 久久在线免费观看| 《视频一区视频二区| 亚洲一区二区精品视频| 麻豆91精品视频| 岛国精品一区二区| 欧美三区免费完整视频在线观看| 538在线一区二区精品国产| 久久午夜免费电影| 亚洲欧美日韩人成在线播放| 日韩电影在线看| 99热精品一区二区| 欧美浪妇xxxx高跟鞋交| 久久理论电影网| 亚洲国产乱码最新视频| 国产精品1区2区3区| 欧美优质美女网站| 久久久www成人免费毛片麻豆| 一区二区三区四区在线免费观看| 久久疯狂做爰流白浆xx| 91久久精品一区二区三| 久久久久久久久久久久久女国产乱| 一区二区在线观看不卡|