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

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

?? ga-2.cpp

?? 幾個C++程序
?? CPP
字號:
// Genetic Algorithm
// Written by Microsoft Visual C++
// Copyright by UTLab @ Tsinghua University
// http://orsc.edu.cn/UTLab

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include "UTLab.h"

static void  initialization(void);
static void  evaluation(int gen);
static void  selection(void);
static void  crossover(void);
static void  mutation(void);
static void  objective_function(void);
static int   constraint_check(double x[]);

#define N 3  // number of variables
#define M 3  // number of objectives
#define TYPE -1 // 1=max;-1=min
#define GEN 2000 // maximum generation number
#define POP_SIZE 30
#define P_MUTATION 0.2
#define P_CROSSOVER 0.3

double  CHROMOSOME[POP_SIZE+1][N+1];
double  OBJECTIVE[POP_SIZE+1][M+1];
double  q[POP_SIZE+1];

static void objective_function(void)
{
	double x1,x2,x3;
	int i;
	for(i = 1; i <= POP_SIZE; i++) {
		x1 = CHROMOSOME[i][1];
		x2 = CHROMOSOME[i][2];
		x3 = CHROMOSOME[i][3];
		OBJECTIVE[i][1] = 3-sqrt(x1);
		if(OBJECTIVE[i][1]<0) OBJECTIVE[i][1]=0;
        OBJECTIVE[i][2] = 4-sqrt(x1+2*x2);
		if(OBJECTIVE[i][2]<0) OBJECTIVE[i][2]=0;
		OBJECTIVE[i][3] = 5-sqrt(x1+2*x2+3*x3);
		if(OBJECTIVE[i][3]<0) OBJECTIVE[i][3]=0;
	}
	for(i=1;i<=POP_SIZE;i++)
	  OBJECTIVE[i][0]= 10000*OBJECTIVE[i][1]+100*OBJECTIVE[i][2]+OBJECTIVE[i][3];
}

static int constraint_check(double x[])
{
	double a;
	int n; 
	for(n=1;n<=N;n++) if(x[n]<0) return 0;
	a = x[1]*x[1]+x[2]*x[2]+x[3]*x[3];
	if(a>100) return 0;
	return 1;
}

static void initialization(void)
{
  double x[N+1]; // N is the number of variables
  int i,j;
  for(i=1; i<=POP_SIZE; i++){
	  mark:
	  for(j=1; j<=N; j++) x[j]=myu(0,10);
	  if(constraint_check(x)==0) goto mark;
	  for(j=1; j<=N; j++) CHROMOSOME[i][j]=x[j];
  }
}

main()
{
  int i, j;
  double a;

  q[0]=0.05; a=0.05;
  for(i=1; i<=POP_SIZE; i++) {a=a*0.95; q[i]=q[i-1]+a;}
  initialization();
  evaluation(0);
  for(i=1; i<=GEN; i++) {
	  selection();
	  crossover();
	  mutation();
	  evaluation(i);
	  printf("\nGeneration NO.%d\n", i);
	  printf("x=(");
	  for(j=1; j<=N; j++) {
		  if(j<N) printf("%3.4f,",CHROMOSOME[0][j]);
		  else printf("%3.4f",CHROMOSOME[0][j]);
	  }
	  if(M==1) printf(")\nf=%3.4f\n", OBJECTIVE[0][1]);
	  else {
	      printf(")\nf=(");
	      for(j=1; j<=M; j++) {
		     if(j<M) printf("%3.4f,", OBJECTIVE[0][j]);
		     else printf("%3.4f", OBJECTIVE[0][j]);
		  }
          printf(")  Aggregating Value=%3.4f\n",OBJECTIVE[0][0]);
	  }
  }
  printf("\n");
  return 1;
}

static void evaluation(int gen)
{
  double a;
  int   i, j, k, label;
  objective_function();
  if(gen==0){
	 for(k=0; k<=M; k++) OBJECTIVE[0][k]=OBJECTIVE[1][k];
	 for(j = 1; j <= N; j++) CHROMOSOME[0][j]=CHROMOSOME[1][j];
  }
  for(i=0; i<POP_SIZE; i++){
	  label=0;  a=OBJECTIVE[i][0];
	  for(j=i+1; j<=POP_SIZE; j++)
		 if((TYPE*a)<(TYPE*OBJECTIVE[j][0])) {
			 a=OBJECTIVE[j][0];
			 label=j;
		 }
	  if(label!=0) {
		 for(k=0; k<=M; k++) {
			 a=OBJECTIVE[i][k];
			 OBJECTIVE[i][k]=OBJECTIVE[label][k];
			 OBJECTIVE[label][k]=a;
		 }
		 for(j=1; j<=N; j++) {
			 a=CHROMOSOME[i][j];
			 CHROMOSOME[i][j]=CHROMOSOME[label][j];
			 CHROMOSOME[label][j]=a;
		 }
	  }
  }
}

static void selection()
{
  double r, temp[POP_SIZE+1][N+1];
  int   i, j, k;
  for(i=1; i<=POP_SIZE; i++) {
	  r=myu(0, q[POP_SIZE]);
	  for(j=0; j<=POP_SIZE; j++) {
		  if(r<=q[j]) {
			  for(k=1; k<=N; k++) temp[i][k]=CHROMOSOME[j][k];
			  break;
		  }
	  }
  }
  for(i=1; i<=POP_SIZE; i++)
	 for(k=1; k<=N; k++)
		 CHROMOSOME[i][k]=temp[i][k];
}

static void crossover()
{
  int   i, j, jj, k, pop;
  double r, x[N+1], y[N+1];
  pop=POP_SIZE/2;
  for(i=1; i<=pop; i++) {
	 if(myu(0,1)>P_CROSSOVER) continue;
	 j=(int)myu(1,POP_SIZE);
	 jj=(int)myu(1,POP_SIZE);
	 r=myu(0,1);
	 for(k=1; k<=N; k++) {
		 x[k]=r*CHROMOSOME[j][k]+(1-r)*CHROMOSOME[jj][k];
		 y[k]=r*CHROMOSOME[jj][k]+(1-r)*CHROMOSOME[j][k];
	 }
	 if(constraint_check(x)==1)
		 for(k=1; k<=N; k++) CHROMOSOME[j][k]=x[k];
	 if(constraint_check(y)==1)
		 for(k=1; k<=N; k++) CHROMOSOME[jj][k]=y[k];
  }
}

static void mutation(void)
{
  int i, j, k;
  double x[N+1], y[N+1], infty, direction[N+1];
  double INFTY=10, precision=0.0001;
  for(i=1; i<=POP_SIZE; i++) {
	  if(myu(0,1)>P_MUTATION) continue;
	  for(k=1; k<=N; k++) x[k] = CHROMOSOME[i][k];
	  for(k=1; k<=N; k++)
		  if(myu(0,1)<0.5) direction[k]=myu(-1,1);
		  else direction[k]=0;
	  infty=myu(0,INFTY);
	  while(infty>precision) {
		  for(j=1; j<=N; j++) y[j]=x[j]+infty*direction[j];
		  if(constraint_check(y)==1) {
			 for(k=1; k<=N; k++) CHROMOSOME[i][k]=y[k];
			 break;
		  }
		  infty=myu(0,infty);
	  }
  }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品欧美一区二区在线观看| 日本韩国一区二区三区| 高清日韩电视剧大全免费| 成人免费毛片嘿嘿连载视频| 国产精品亲子乱子伦xxxx裸| 99麻豆久久久国产精品免费| 国产在线播精品第三| 精品一区二区三区在线播放视频| 日韩激情在线观看| 久久国内精品自在自线400部| 亚洲视频免费在线观看| 一区二区三区成人| 亚洲va在线va天堂| 日韩在线一二三区| 国产美女主播视频一区| 日韩一区二区免费电影| 91精品在线麻豆| 综合精品久久久| 国产成人av一区| 91精品国产手机| 亚洲人成网站精品片在线观看| 蜜臀精品一区二区三区在线观看 | 最新国产成人在线观看| 视频一区视频二区中文字幕| 蜜桃一区二区三区在线| 色综合天天综合网天天看片| 国产日韩欧美不卡| 国产美女精品在线| 91久久线看在观草草青青| 最新高清无码专区| 中文幕一区二区三区久久蜜桃| 欧美一区二区三区在线观看视频| 日韩一区二区三区视频在线| 欧美日韩亚洲综合一区二区三区| 精品国产一区二区三区不卡 | 国产成人精品三级麻豆| 这里只有精品电影| 三级影片在线观看欧美日韩一区二区 | 日韩影院精彩在线| 欧美精品日韩一本| 日韩av网站在线观看| 欧美一区二区视频免费观看| 日韩毛片高清在线播放| 91免费视频网| 亚洲.国产.中文慕字在线| 91成人网在线| 日韩不卡手机在线v区| 欧美精品欧美精品系列| 久久成人av少妇免费| 精品国产a毛片| 91在线观看美女| 亚洲aⅴ怡春院| 国产欧美视频一区二区三区| 国产成人免费网站| 一区二区三区日韩精品视频| 欧美在线观看视频在线| 美女一区二区三区| 亚洲视频图片小说| 久久综合九色综合欧美亚洲| 91一区在线观看| 美女在线观看视频一区二区| 日本一二三四高清不卡| 91行情网站电视在线观看高清版| 日本成人中文字幕在线视频| 国产欧美日韩卡一| 777奇米四色成人影色区| 国产大片一区二区| 麻豆精品蜜桃视频网站| 夜夜爽夜夜爽精品视频| 久久久国产精品不卡| 91精品国产综合久久精品麻豆 | 精品国产乱码久久久久久闺蜜| 91免费国产在线观看| 久久99精品久久久久婷婷| 婷婷六月综合网| 亚洲一区在线播放| 亚洲你懂的在线视频| 日本一区二区免费在线观看视频 | 日本中文在线一区| 五月天欧美精品| 日韩国产欧美三级| 天堂va蜜桃一区二区三区 | 在线观看国产一区二区| 豆国产96在线|亚洲| 国内成+人亚洲+欧美+综合在线| 亚欧色一区w666天堂| 天天综合网 天天综合色| 亚洲自拍都市欧美小说| 亚洲成av人片在www色猫咪| 亚洲欧美一区二区久久| 亚洲综合一二区| 日本欧美一区二区三区乱码| 五月天一区二区| 国产在线精品免费| 丁香亚洲综合激情啪啪综合| 国产不卡一区视频| 欧美特级限制片免费在线观看| 一区二区三区日韩欧美| 91麻豆精品国产91久久久久久 | 在线免费观看日韩欧美| 精品美女被调教视频大全网站| 依依成人精品视频| 91在线观看高清| 亚洲同性同志一二三专区| 国产不卡在线播放| 久久综合九色综合久久久精品综合 | 亚洲欧美中日韩| 国产sm精品调教视频网站| 欧美日韩国产另类一区| 亚洲欧洲99久久| 91蜜桃免费观看视频| 久久久亚洲欧洲日产国码αv| 亚洲成av人影院| 91国偷自产一区二区三区成为亚洲经典| 日韩一区二区三区视频在线观看| 成人免费一区二区三区视频| 日本美女视频一区二区| 欧美亚洲综合网| 亚洲一区二区三区中文字幕在线| 97se亚洲国产综合自在线观| 成人欧美一区二区三区在线播放| 国产成人精品亚洲777人妖 | 亚洲人成精品久久久久久| 成人av在线电影| 亚洲欧美激情插| 91麻豆免费视频| 日本伊人色综合网| 国产欧美一区二区精品婷婷 | 狠狠色狠狠色综合| 国产亚洲精品久| 99精品视频在线观看| 亚洲人精品一区| 日韩一区二区三区视频在线观看| 日韩制服丝袜先锋影音| 久久综合一区二区| 91蜜桃视频在线| 久久99久久久久| 国产欧美va欧美不卡在线| av一区二区三区黑人| 一区二区日韩av| 中文字幕av资源一区| 欧美一区二区国产| 99国产精品久久久| av午夜精品一区二区三区| 国产一区二区美女诱惑| 精品无人区卡一卡二卡三乱码免费卡| 亚洲国产aⅴ成人精品无吗| 亚洲综合丝袜美腿| 午夜久久久久久久久 | 成人午夜免费av| 日韩精品一级中文字幕精品视频免费观看 | 一区二区三区高清不卡| 26uuu欧美日本| 制服丝袜日韩国产| 日本国产一区二区| www.成人网.com| 成人小视频免费观看| 国产精品一区一区| 成人av在线资源网| 久久99热狠狠色一区二区| 日韩av在线播放中文字幕| 日韩av一级片| 日本久久电影网| 国产精品一区不卡| 丁香亚洲综合激情啪啪综合| 99久久精品免费| 欧美午夜在线观看| 91精品国产欧美一区二区18| 日韩一区二区免费高清| 精品成人佐山爱一区二区| 国产亚洲一区字幕| 亚洲影视在线播放| 国产伦精品一区二区三区免费迷| 国产成人精品在线看| 亚洲人成小说网站色在线| 色噜噜久久综合| 亚洲成人av电影| 99精品在线免费| 青青国产91久久久久久| 日韩免费在线观看| 欧美午夜片在线观看| 国产在线精品一区在线观看麻豆| 亚洲国产精品t66y| 欧美zozozo| 欧美一区二区三区色| 本田岬高潮一区二区三区| 首页亚洲欧美制服丝腿| 国产精品久久久久一区二区三区 | 91精品一区二区三区久久久久久 | 一区二区中文视频| 6080午夜不卡| 色哟哟在线观看一区二区三区| 麻豆视频观看网址久久| 国产麻豆成人精品| 亚洲一区二区三区在线看| 亚洲柠檬福利资源导航| 午夜精品久久一牛影视| 极品少妇一区二区| 欧美色图免费看| 色婷婷国产精品|