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

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

?? chc.cpp

?? CHC源代碼
?? CPP
字號:
#include <afxwin.h>
#include <iostream.h>
#include<windows.h>
#include <stdio.h>
#include<stdlib.h>
#include<time.h>
#include<math.h>
#include<fstream.h> 
#define POPSIZE 500
#define MAX 300

#define C 1   //目標函數界限保守估計
#define length1 10
#define length2 10
#define chromlength length1+length2  //染色體長度
#define d length1/4
#define R 0.35
#define L length1

int generation;      //世代數
int best_index;
int worst_index;
int popsize;        //種群大小
int cksize;
int maxgeneration;  //最大世代數
struct individual
 {
      char  chrom[chromlength+1];
      double value;         
      double fitness;      //適應度
 };
struct individual bestindividual;  //最佳個體
struct individual worstindividual; //最差個體
struct individual currentbest;
struct individual population[MAX][POPSIZE];
struct individual copyone[MAX][POPSIZE];
struct individual mixedone;
struct individual p[MAX][POPSIZE];
//函數聲明                                       
void generateinitialpopulation();                 
void generatenextpopulation();
void evaluatepopulation();
long decodechromosome(char *,int,int);
void calculateobjectvalue();
void calculatefitnessvalue();
void findbestandworstindividual();
void performevolution();
void select();
void crossover();
void partinitial();
void input();
void output();
//種群初始化
void generateinitialpopulation()
{
	int i,j;
	for(i=0;i<popsize;i++)
	{
		for(j=0;j<chromlength;j++)
		{
			population[generation][i].chrom[j]=(rand()%10<5)?'0':'1';
		}
		population[generation][i].chrom[chromlength]='\0';
	}
	cksize=popsize;
}
//復制混合種群
void copy()
{   int i;
    for(i=0;i<popsize;i++)
   {
	  copyone[generation][i]=population[generation][i];
	  copyone[generation][popsize+i]=population[generation-1][i]; //產生混合種群C(K)
   }
}
//交叉
void crossover()
{
	int i,j,point,m,hm;
	struct individual temp;
	int mm=2*popsize;
    int index[2*POPSIZE];
	char ch;

	for(i=0;i<mm;i++)   //隨機配對
	{
		point=rand()%(2*popsize-i);
		temp=index[i];
		index[i]=index[point+i];
		index[point+i]=temp;
	}
	for(i=0;i<mm-1;i+=2)
	{    
		 hm=0;
	     for(j=0;j<chromlength;j++)//計算配對個體間海明距離
		 {
		     if(copyone[generation][index[i]].chrom[j]!=copyone[generation][index[i+1]].chrom[j])
			 {  hm++;}
		 }
		 if(hm>2*d)  //執行改進均勻交叉--->c(k)'
		 {    
			 m=(hm/2);
			 ch=copyone[generation][index[i]].chrom[m];
			 copyone[generation][index[i]].chrom[m]=copyone[generation][index[i+1]].chrom[m];
			 copyone[generation][index[i+1]].chrom[m]=ch;
		 }
		 else
		 {
			 if(i=popsize-1)
			 {
                copyone[generation][index[i]].value=NULL;
			    copyone[generation][index[i+1]].value=NULL;
			 }
             else
			 {  
				copyone[generation][index[i]]=copyone[generation][index[i+2]];
			    copyone[generation][index[i+1]]=copyone[generation][index[i+3]];
				i=i-2;
				mm=mm-2;
			 }
		 }
	}
	cksize=mm-1;
	for(i=0;i<cksize;i++)
	{
      population[generation][i]=copyone[generation][i];
	}
}
//選擇
void select()
{
    int i,index,j;
	double p,sum=0.0;
	int cP=cksize+POPSIZE;
	double cfitness[2*POPSIZE];
	struct individual newpopulation[2*POPSIZE];
	struct individual t;

	//c(k)'與p(k-1)混合起來
	for(i=0;i<cksize;i++)
	{
	     copyone[generation][popsize+i]=population[generation-1][i];
	}
	//c(k)'與p(k-1)混合種群按適應度從大到小排序
	for(i=0;i<cP;i++)
	{
		for(j=i+1;j<popsize;j++)
		{
			if(copyone[generation][i].fitness<copyone[generation][j].fitness)
			{
				t=copyone[generation][i];
				copyone[generation][i]=copyone[generation][j];
		        copyone[generation][j]=t;
			}
		}
	}

  //計算選擇概率
	for(i=0;i<cP;i++)
	{
		sum+=copyone[generation][i].fitness;
	}

    for(i=0;i<cP; i++)
	{
		cfitness[i]=copyone[generation][i].fitness/sum;
	}

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

   //輪盤賭選取popsize個較優的個體組成p(k)
	for (i=0;i<popsize;i++)
	{
		p=rand()%1000/1000.0;
		index=0;
	   while (p>cfitness[index])
		{
			index++;
		}
		newpopulation[i]=copyone[generation][index];
	}
	for(i=0;i<popsize; i++)
	{
		population[generation][i]=newpopulation[i];
	}
	cksize=popsize;
}
//部分個體初始化
void partinitial()
{
	int i,j;
	double p;
	int RL=4;
	for (i=0;i<popsize-1;i++)
	{
		for(j=0;j<RL;j++)
		{
			p=rand()%chromlength;
		    population[generation-1][i].chrom[j]=(rand()%10<5)?'0':'1';
		}
  		population[generation][i]=population[generation-1][i];
	}

		population[generation][popsize-1]=population[generation-1][popsize-1];
		cksize=popsize;
}
//評價個體,求最佳個體
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 x,y,tt; 
	for (i=0; i<cksize; i++)
	{
		 temp1=decodechromosome(population[generation][i].chrom,0,length1);
         temp2=decodechromosome(population[generation][i].chrom,length1,length2);
         x=20.0*temp1/1023.0-10.0;    
         y=20.0*temp2/1023.0-10.0;  
		 tt=pow(x,2)+pow(y,2);
		 population[generation][i].value=0.5-(pow(sin(sqrt(tt)),2)-0.5)/pow((1+0.001*pow(tt,2)),2);
	}
}
//計算適應度
void calculatefitnessvalue()
{
	int  i;
    double temp;
    for(i=0;i<cksize;i++)
    {
		  if((C-population[generation][i].value)>0.0)
		  {
			  temp=1/(1+C-population[generation][i].value);
		  }
          else
		  {
			  temp=0.0;
		  }
     population[generation][i].fitness=temp;
   }
}
//求最佳個體和最差個體
void findbestandworstindividual( ) 
{
	int i;
	
	bestindividual=population[generation][0];
	worstindividual=population[generation][0];

	for (i=1;i<cksize; i++)
	{
		if (population[generation][i].fitness>bestindividual.fitness)
		{
			bestindividual=population[generation][i];
			best_index=i;
		}
		else if (population[generation][i].fitness<worstindividual.fitness)
		{
			worstindividual=population[generation][i];
			worst_index=i;
			
		}
	}

    if (generation==0)
	{
		currentbest=bestindividual;
	}
	else
	{
		if(bestindividual.fitness>=currentbest.fitness)
		{
			currentbest=bestindividual;
		}
	}
  
}
//演示評價結果
void performevolution() 
{
	if (bestindividual.fitness>currentbest.fitness)
	{
		currentbest=population[generation][best_index];
	}
	else
	{
		population[generation][worst_index]=currentbest;
	}
}
//數據輸入
void input() 
{   
	printf("初始化全局變量:\n");
	printf("    種群大小(50-500):");  /**/
    scanf("%d", &popsize);
    if((popsize%2) != 0)
	{ 
    	printf( "   種群大小已設置為偶數\n");
	    popsize++;
	}
        printf("     最大世代數(100-300):");
        scanf("%d", &maxgeneration);
}
//數據輸出
void output()
{

	int i;
    double sum;
    double average;
    sum=0.0;
    for(i=0;i<popsize;i++)
	{
		sum+=population[generation][i].value;
	}
    average=sum/popsize;
    printf("當前世代=%d\n當前世代平均函數值=%f\n當前世代最高函數值=%f\n",generation,average,currentbest.value);
}
void main()
{
	int i;
    printf("本程序為求shaffer's F6函數的最大值\n");
    printf("其中-10.0<x,y<10.0\n");   /**/
	input();
    generation=0;
    generateinitialpopulation();
	evaluatepopulation();
	while(generation<maxgeneration)
	{
		generation++;
        copy();
		crossover();
		evaluatepopulation();
		for(i=0;i<cksize;i++)
		{
            copyone[generation][i]=population[generation][i];
		}
		select();
		performevolution();
		output();
		if(population[generation]==population[generation-1])
		{
			d==d-1;
		   if(d<0)
		   {
			   partinitial();
			   d==(R*(1-R)*L);
		   }
		}
		else
		{
			 generateinitialpopulation();
			 evaluatepopulation();
		}
	}
	printf("\n");
	printf("統計結果:\n");
    printf("最大函數值等于:%f\n",currentbest.value);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美三级日韩三级国产三级| 亚洲一区二区三区免费视频| 亚洲欧洲综合另类| 日日夜夜免费精品| 不卡在线观看av| 久久一区二区三区四区| 亚洲国产人成综合网站| 成人精品国产福利| 精品国产区一区| 亚洲国产精品久久人人爱蜜臀| 懂色av中文一区二区三区| 成人免费视频caoporn| 日韩欧美一二三四区| 亚洲日本丝袜连裤袜办公室| 国产一区二区0| 日韩一级免费观看| 午夜久久久久久久久久一区二区| 亚洲无线码一区二区三区| 成人污视频在线观看| 日韩欧美一级二级| 日本成人中文字幕在线视频| 欧美三级日韩在线| 亚洲影院在线观看| 一本大道久久a久久综合| 日本一区二区三区视频视频| 久久福利视频一区二区| 宅男噜噜噜66一区二区66| 亚洲伊人伊色伊影伊综合网| 91丝袜美女网| 亚洲免费观看高清完整版在线| 亚洲综合一区在线| 99久久婷婷国产| 亚洲女爱视频在线| 成人av电影观看| 国产精品国产自产拍高清av| 成人av电影在线网| 亚洲欧洲www| 色哟哟国产精品| 亚洲综合久久久| 欧美日韩视频在线一区二区 | 色综合一区二区三区| 国产清纯美女被跳蛋高潮一区二区久久w| 精品国产免费一区二区三区四区| 精品999在线播放| 国产中文字幕精品| 久久亚洲捆绑美女| 国产成人福利片| 中文字幕一区二区三区在线播放| 天天影视涩香欲综合网| 日韩一区二区在线看| 日本最新不卡在线| 精品国产污污免费网站入口| 国产91露脸合集magnet| 自拍偷拍亚洲综合| 欧美日韩在线免费视频| 日韩福利视频网| 国产亚洲视频系列| 91国内精品野花午夜精品| 午夜精品久久久久影视| 久久这里只精品最新地址| 福利电影一区二区| 亚洲主播在线播放| 欧美电影免费观看高清完整版在 | 蜜桃视频在线观看一区| 2023国产精品| 色偷偷88欧美精品久久久| 五月激情综合婷婷| 精品精品国产高清a毛片牛牛| 亚洲精品网站在线观看| 91精品国产综合久久久久| 卡一卡二国产精品 | 欧美精品一区二区蜜臀亚洲| 粉嫩aⅴ一区二区三区四区| 亚洲最大成人网4388xx| 精品欧美一区二区在线观看| 91首页免费视频| 美女精品自拍一二三四| 亚洲欧美激情一区二区| 亚洲精品一区二区三区99| 91福利视频久久久久| 久久精品国产久精国产| 一区二区三区久久久| 日韩精品一区二区三区三区免费| 麻豆91在线观看| 国产精品免费久久久久| 欧美精品在线视频| 99精品欧美一区二区蜜桃免费| 日本一区二区三区国色天香| 欧美福利视频一区| 成人免费毛片片v| 国产一区二区三区在线观看精品| 欧美一区二区三区四区五区 | 欧美吻胸吃奶大尺度电影 | 精品少妇一区二区三区视频免付费| 亚洲电影中文字幕在线观看| 久久蜜桃av一区二区天堂| 欧美性大战久久久久久久| 成人免费视频免费观看| 国产精品夜夜嗨| 美女视频免费一区| 午夜久久久久久久久| 亚洲欧美日韩人成在线播放| 久久久久99精品一区| 欧美一级久久久久久久大片| 色婷婷一区二区三区四区| 不卡一二三区首页| 国产福利91精品一区二区三区| 日韩西西人体444www| 欧美日本精品一区二区三区| 日本乱码高清不卡字幕| 91在线无精精品入口| 国产+成+人+亚洲欧洲自线| 久久99精品久久久久婷婷| 午夜精品久久久| 亚洲第一综合色| 亚洲福利一二三区| 亚洲最大的成人av| 亚洲国产aⅴ成人精品无吗| 一区二区三区**美女毛片| 亚洲综合色视频| 亚洲成人av福利| 日韩成人av影视| 美女免费视频一区二区| 韩国三级中文字幕hd久久精品| 亚洲日韩欧美一区二区在线| 亚洲欧洲日本在线| 亚洲日本在线a| 亚洲国产色一区| 日日夜夜一区二区| 激情伊人五月天久久综合| 国产美女一区二区| 波多野结衣亚洲一区| 不卡一区中文字幕| 欧美三级视频在线| 欧美一区二区三区视频在线 | 欧美中文字幕一二三区视频| 在线免费av一区| 欧美一级欧美三级在线观看| 亚洲精品一区二区在线观看| 性做久久久久久免费观看| 五月天丁香久久| 国产精品自拍毛片| 99视频在线精品| 欧美日韩高清一区二区| 久久午夜国产精品| 综合色天天鬼久久鬼色| 日韩综合小视频| 国产激情91久久精品导航| 日本电影亚洲天堂一区| 91精品国产乱| 国产精品传媒入口麻豆| 日韩av网站在线观看| 成人免费视频一区| 欧美一级日韩免费不卡| 国产精品麻豆99久久久久久| 五月天视频一区| 成人精品视频.| 欧美日韩国产一级二级| 国产日韩欧美制服另类| 亚洲综合色自拍一区| 国产成人在线网站| 精品1区2区3区| 中文字幕免费在线观看视频一区| 欧美精品一区二区三区很污很色的 | 亚洲另类色综合网站| 琪琪久久久久日韩精品| 国产精品一区二区三区网站| 色中色一区二区| 午夜精品在线视频一区| 成人免费观看男女羞羞视频| 欧美一级二级三级蜜桃| 亚洲精选免费视频| 国产一区二区中文字幕| 911国产精品| 亚洲三级在线免费| 国产精品亚洲一区二区三区妖精| 国产一区二区导航在线播放| 欧美午夜不卡在线观看免费| 国产精品欧美久久久久无广告| 久久精品水蜜桃av综合天堂| 日韩综合在线视频| 在线区一区二视频| 亚洲少妇中出一区| 国产成人精品三级麻豆| 精品黑人一区二区三区久久| 伊人性伊人情综合网| 成人精品鲁一区一区二区| 精品国产髙清在线看国产毛片| 日本一区二区视频在线| 老司机精品视频导航| 欧美日韩一区在线观看| 最新久久zyz资源站| 国产91在线看| 国产欧美精品国产国产专区 | 久久综合av免费| 日本91福利区| 欧美一二三四在线| 美女视频一区二区三区| 欧美va亚洲va在线观看蝴蝶网| 欧美精品一区二区三区蜜臀|