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

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

?? utlab(1).h

?? 清華大學某教授做的遺傳算法源程序, GA1.cpp對應GA1.pdf
?? H
字號:
// Random Number Generation & Useful subfunctions
// Written by Microsoft Visual C++
// Copyright by UTLab, Tsinghua University
// http://orsc.edu.cn/UTLab

double myu(double a, double b) // Uniform Distribution
{
  double y;
  if(a>b) {
	printf("\nThe first parameter should be less than the second!");
	exit(1);
  }
  y = (double)rand()/(RAND_MAX);
  return (a+(b-a)*y); 
}

double myexp(double beta) // Exponential Distribution
{
  double u;
  do {
     u = myu(0,1);
  }  while(u<=0||u>=1);
  return (-1*beta*log(u));
}

double myn(double mu, double sigma2) // Normal Distribution
{
  double mu1, mu2, z;
  do {
    mu1 = myu(0,1);
    mu2 = myu(0,1);
  } while (mu1<=0||mu1>=1);
  z = sqrt(-2*log(mu1))*sin(2*3.14159*mu2);
  return (mu+sqrt(sigma2)*z);
}

double randomoptimistic(double *p, int samplenumber, double alpha)
{       
  int i, j;
  double w;
  for(i=1; i<=samplenumber; i++)
    for(j=i+1; j<=samplenumber; j++) 
      if(*(p+i) < *(p+j)) {
         w = *(p+j);
	     *(p+j) = *(p+i);
	     *(p+i) = w;
      }
  return *(p+(int)(alpha*samplenumber));
}

double randompessimistic(double *p, int samplenumber, double alpha)
{
  int i, j;
  double w;
  for(i=1; i<=samplenumber; i++)
    for(j=i+1; j<=samplenumber; j++) 
      if(*(p+i) > *(p+j)) {
         w = *(p+j);
	     *(p+j) = *(p+i);
	     *(p+i) = w;
      }
  return *(p+(int)(alpha*samplenumber));
}

double triangle(double x, double a, double b, double c)
{
  if(a<x&&x<b) return (x-a)/(b-a);
  if(b<=x&&x<c) return (x-c)/(b-c);
  return 0;
}

double trapezoidal(double x, double a, double b, double c, double d)
{
  if(a<x&&x<b) return (x-a)/(b-a);
  if(b<=x&&x<=c) return 1;
  if(c<x&&x<d) return (x-d)/(c-d);
  return 0;
}

double fuzzyoptimistic(double x[], double mu[], int samplenumber, double alpha)
 {
   double v1, v2, v, xx, min, max;
   int    i;
   
   min=x[1];
   max=x[1];
   for(i=2; i<=samplenumber; i++) {
       if(min>x[i]) min=x[i];
	   if(max<x[i]) max=x[i];
   }
	
   do {
       	xx=(min+max)/2;
        v1=0;
		v2=0;
		for(i=1; i<=samplenumber; i++)  {
  	       if((x[i]>=xx)&&(v1<mu[i])) v1=mu[i];
	       if((x[i]<xx)&&(v2<mu[i]))  v2=mu[i];
		}
        if(v1>v2) v1=1; else v2=1;
        v=(v1+1-v2)/2;
        if(v>=alpha) min=xx;
    	else max=xx;
   }while((max-min)>0.0001);
 
   return (max+min)/2;
}

double fuzzypessimistic(double x[], double mu[], int samplenumber, double alpha)
 {
   double v1, v2, v, xx, min, max;
   int    i;
  
   min=x[1];
   max=x[1];
   for(i=2; i<=samplenumber; i++) {
       if(min>x[i]) min=x[i];
	   if(max<x[i]) max=x[i];
   }
   
   do {
       	xx=(min+max)/2;
        v1=0;
		v2=0;

		for(i=1; i<=samplenumber; i++)  {
   	       if((x[i]<=xx)&&(mu[i]>v1)) v1=mu[i];
	       if((x[i]>xx)&&(mu[i]>v2))  v2=mu[i];
		}
        if(v1>v2) v1=1; else v2=1;
        v=(v1+1-v2)/2;
        if(v>=alpha) max=xx;
     	else min=xx;
   }while((max-min)>0.0001);
 
   return (max+min)/2;
}

double credibility(double x[], double mu[], int samplenumber, char relation, double a)
 {
   double v1=0, v2=0;
   int    i;

   if(relation=='<')
      for(i=1; i<=samplenumber; i++)  {
   	     if((x[i]<=a)&&(v1<mu[i])) v1=mu[i];
	     if((x[i]>a)&&(v2<mu[i])) v2=mu[i];
	  }
   if(relation=='>')
      for(i=1; i<=samplenumber; i++)  {
   	     if((x[i]>=a)&&(v1<mu[i])) v1=mu[i];
	     if((x[i]<a)&&(v2<mu[i])) v2=mu[i];
	  }
   if(v1>v2) v1=1; else v2=1;
   return (v1+1-v2)/2;
}

double fuzzymean(double x[], double mu[], int samplenumber, int integralnumber=2000)
{
	int i,k;
	double Expect=0, left, right, b1, b2, r;
	
	left=x[1];
	right=x[1];
	for(i=2;i<=samplenumber;i++) {
	  if(left>x[i]) left=x[i];
	  if(right<x[i]) right=x[i];
	}
	for(k=1; k<=integralnumber; k++) {
	  r=myu(left,right);
	  b1=0;
	  b2=0;
	  if(r>=0) {
		for(i=1; i<=samplenumber; i++) {
		  if(x[i]>=r&&b1<mu[i]) b1 = mu[i];
		  if(x[i]<r&&b2<mu[i]) b2 = mu[i];
		}		
		Expect = Expect+(b1+1-b2)/2.0;
	  }
	  else {
		for(i=1; i<=samplenumber; i++) {
		  if(x[i]<=r&&b1<mu[i]) b1 = mu[i];
		  if(x[i]>r&&b2<mu[i]) b2 = mu[i];
		}		
		Expect = Expect-(b1+1-b2)/2.0;
	  }
	}
	return Expect*(right-left)/integralnumber+((left>0)?left:0)+((right<0)?right:0);
}


////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////



void sortminmax(double *p,int min,int max)
{
  int i,j;
  double w;
  for(i=min; i<max; i++)
    for(j=i+1; j<=max; j++)
       if(*(p+i) > *(p+j)) {
	      w = *(p+i);
	      *(p+i) = *(p+j);
	      *(p+j) = w;
       }
}

void sortmaxmin(double *p,int min,int max)
{
  int i, j;
  double w;
  for(i=min; i<max; i++)
    for(j=i+1; j<=max; j++)
      if(*(p+i) < *(p+j)) {
         w = *(p+i);
	     *(p+i) = *(p+j);
	     *(p+j) = w;
      }
}

double findmaxn(double *p,int min,int max,int n)
{
  int i, j;
  double w;
  for(i=min; i<=n; i++)
    for(j=i+1; j<=max; j++) 
      if(*(p+i) < *(p+j)) {
         w = *(p+j);
	     *(p+j) = *(p+i);
	     *(p+i) = w;
      }
  return *(p+n);
}

double findminn(double *p,int min,int max,int n)
{
  int i, j;
  double w;
  for(i=min; i<=n; i++)
    for(j=i+1; j<=max; j++) 
      if(*(p+i) > *(p+j)) {
         w = *(p+j);
	     *(p+j) = *(p+i);
	     *(p+i) = w;
      }
  return *(p+n);
}

int mybe(double p) // Bernoulli Distribution
{
  if(p>1||p<0) {
	 printf("\nParameter is out of bound!\n");
	 exit(1);
  }
  if(myu(0,1)<=p) return 1;
  else return 0;
}


int mybn(int n, double p)
{
 int i, y=0;
 for(i=1; i<=n; i++)
	y=y+mybe(p);
 return y;
}


double myc(double alpha, double beta)
{
  double u;
  do {
	 u = myu(0,1);
  } while (u<=0);
  return (alpha-beta/tan(3.14159*u));
}


double myemp(double *a,int n) // Empirical Distribution
{
 int i,m;
 double mu;
 for(i=1;i<n;i++)
   {
	if(a[i-1]>a[i])
	  {
	   printf("\nThe observations should be ordered from small to large!\n");
	   exit(1);
	  }
   }
 mu=myu(0,1);
 m=(int)((n-1)*mu+1);
 return (a[m-1]+((n-1)*mu-m+1)*(a[m]-a[m-1]));
}


double mychi(int k)
{
  int i;
  double z,y=0;
  if(k<1)
	{
	 printf("\nThe parameter should be a integer larger than zero!\n");
	 exit(1);
	}
  for(i=1;i<=k;i++)
	{
	 z=myn(0,1);
	 y=y+z*z;
	}
  return y;
}


double myf(int k1, int k2)
{
  double y1, y2;
  y1 = mychi(k1);
  for(;;){
  y2 = mychi(k2);
  if(y2!=0) break;
  }
  return((y1/k1)/(y2/k2));
}


double mys(int k)
{
  double y, z;
  z = myn(0,1);
  y = mychi(k);
  return (z/sqrt(y/k));
}

double myer(int k,double beta)
{
 int i;
 double y;
 y=0;
 if(k<=0)
   {
	printf("\nThe first parameter should be a integer larger than zero!\n");
	exit(1);
   }
 for(i=1;i<=k;i++)
   y=y+myexp(beta);
 return y;
}


double myg(double alpha, double beta)
{
  double x, v;
  x = 0;
  if(alpha<=0||beta<=0)
	{
	 printf("\nParameter should all larger than zero!\n");
	 exit(1);
	}
  mark:
  v = myexp(1);
  x = x + v;
  if(alpha == 1) {
	 x = beta*x;
	 return x;
  }
  alpha = alpha -1;
  goto mark;
}


double myb(int alpha, int beta)
{
  double y1, y2;
  y1 = myg(alpha,1);
  y2 = myg(beta,1);
  return (y1/(y1+y2));
}


double myw(double alpha, double beta)
{
  double v;
  if(alpha<=0||beta<=0)
	{
	 printf("\nParameter should all larger than zero!\n");
	 exit(1);
	}
  v = myexp(1);
  return (beta*pow(v,(1/alpha)));
}


int myge(double p)
{
 int x;
 double r;
 if(p>=1||p<=0)
	{
	 printf("\nParameter is out of bound!\n");
	 exit(1);
	}
 do {
	r=myu(0,1);
 } while (r<=0||r>=1);
 x= (int)(log(r)/log(1-p));
 return x;
}


int mynb(int k,double p)
{
 int i,y;
 if(k<=0)
   {
	printf("\nThe first parameter should be a integer larger than zero!\n");
	exit(1);
   }
 y=0;
 for(i=1;i<=k;i++)
   y=y+myge(p);
 return y;
}


double myl(double a,double b) 
{
  double mu;
   do {
    mu = myu(0,1);
    } while (mu<=0||mu>=1);
  return(a-b*log(1/mu-1));
}

int myp(double lamd) // Poisson Distribution
{
 int x;
 double b,u;
 if(lamd<=0)
   {
	printf("\nThe parameter should be larger than zero!\n");
	exit(1);
   }
 x=0;
 b=1;
 do
   {
	u=myu(0,1);
	b=b*u;
	x=x+1;
   }while(b>=exp(-lamd));
 return(x-1);
}

double mynormal(double x, double c, double w)
{
	return(exp(-(x-c)*(x-c)/(w*w)));
}

double mylogn(double mu, double sigma2) // Lognormal Distribution
{
  double z;
  z = myn(mu,sigma2);
  return (exp(z));
}

double myt(double a,double b,double m) // Triangular Distribution
{
 double c,u,y;
 if(a>=m||m>=b) {
	printf("\nThe first parameter should be the smallest!");
	printf("\nAnd the second one should be the largest!\n");
	exit(1);
   }
 c=(m-a)/(b-a);
 u=myu(0,1);
 if(u<c)
   y=sqrt(c*u);
 else
   y=1-sqrt((1-c)*(1-u));
 return(a+(b-a)*y);
}

double randommean(double x[], int samplenumber)
{
	int i;
	double Expect=0;
	
	for(i=1;i<=samplenumber;i++) 
		Expect=Expect+x[i];

	return Expect/samplenumber;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产日韩v精品一区二区| 美国十次综合导航| 国产精品一级片在线观看| 欧美一区二区福利在线| 男人的j进女人的j一区| 欧美xxxxx牲另类人与| 国精产品一区一区三区mba桃花| 欧美午夜片在线看| 免费成人av在线播放| 久久老女人爱爱| 成人午夜免费av| 亚洲一区二区三区国产| 欧美日韩亚洲综合在线 | 99久久99久久精品免费看蜜桃| 久久一区二区视频| 日韩精品电影在线观看| 欧美乱妇一区二区三区不卡视频| 一区二区欧美视频| 国产亚洲一区二区三区在线观看| 99综合电影在线视频| 一区二区三区高清在线| 久久久影视传媒| 欧美人与性动xxxx| 国产成人在线观看免费网站| 国产欧美精品一区| 欧美日韩日日骚| 久久99精品国产.久久久久久| 国产日韩欧美a| 日韩三级视频中文字幕| 色综合天天视频在线观看| 一区二区三区成人在线视频| 久久久五月婷婷| 欧美色中文字幕| av高清久久久| 蜜臀av亚洲一区中文字幕| 亚洲色图欧美偷拍| 中文字幕av一区二区三区高| 欧美一区二区三区喷汁尤物| 成人黄色av网站在线| 日韩中文字幕区一区有砖一区| 亚洲女同一区二区| 亚洲男人的天堂在线观看| 国产亚洲婷婷免费| 欧美电影免费提供在线观看| 欧美探花视频资源| 日本韩国欧美一区二区三区| 国产91精品在线观看| 另类小说图片综合网| 奇米影视一区二区三区| 石原莉奈一区二区三区在线观看| 亚洲国产日韩一级| 亚洲综合一区在线| 亚洲国产中文字幕在线视频综合 | 欧美日韩在线亚洲一区蜜芽| 欧美一区二区三区在线看| 久久久亚洲综合| 日韩精品成人一区二区三区| 蜜桃视频在线观看一区二区| 粉嫩欧美一区二区三区高清影视| 91精品在线观看入口| 国产精品久久久久精k8| 免费成人小视频| 91久久国产综合久久| 国产视频911| 懂色中文一区二区在线播放| 日韩午夜在线观看视频| 亚洲地区一二三色| 色综合天天综合网国产成人综合天 | 亚洲在线视频免费观看| 成人av网站大全| 欧美电影免费观看高清完整版| 亚洲成人在线免费| 欧美日韩的一区二区| 亚洲综合色婷婷| 91精品国产麻豆| 日韩—二三区免费观看av| 91精品久久久久久蜜臀| 亚洲高清在线精品| 欧美日韩日日夜夜| 亚洲国产精品一区二区久久 | 国产suv精品一区二区6| 26uuu另类欧美| 国内精品久久久久影院薰衣草| 日韩一区国产二区欧美三区| 天天综合网天天综合色| 日韩一区二区三区在线观看| 久久99精品久久久久久国产越南| 91精品综合久久久久久| 久草中文综合在线| 国产三级一区二区| 色综合天天性综合| 人人超碰91尤物精品国产| 精品久久国产老人久久综合| 亚洲不卡av一区二区三区| 精品国产一二三| 成人h动漫精品| 日韩成人精品在线观看| 久久久综合精品| 色婷婷av一区二区三区大白胸| 麻豆中文一区二区| 中文字幕一区二区在线播放| 91精品久久久久久久久99蜜臂| 国产成人精品1024| 国产综合色在线视频区| 天堂一区二区在线免费观看| 久久九九99视频| 欧美精选一区二区| 色综合久久天天| 国产一区日韩二区欧美三区| 亚洲欧美成aⅴ人在线观看| 欧美一区二区日韩| 99久久精品99国产精品| 麻豆成人久久精品二区三区小说| 中文字幕中文字幕在线一区| 制服.丝袜.亚洲.中文.综合| 色综合夜色一区| av在线播放不卡| 国产91精品精华液一区二区三区| 美女视频网站久久| 蜜桃视频免费观看一区| 午夜日韩在线观看| 日本最新不卡在线| 日本欧美一区二区在线观看| 五月婷婷久久丁香| 热久久一区二区| 精品一区二区免费| 国产成人综合精品三级| 国产一区福利在线| 国产成人在线免费观看| 国产成人免费av在线| 色综合天天性综合| 日本丶国产丶欧美色综合| 97se亚洲国产综合自在线不卡| 成人午夜激情在线| 欧美性色黄大片手机版| 在线不卡a资源高清| 久久午夜免费电影| 1000精品久久久久久久久| 亚洲综合色成人| 国产高清不卡二三区| 欧美性感一区二区三区| 久久综合99re88久久爱| 亚洲精品国产高清久久伦理二区| 日本成人在线视频网站| 99久久99久久免费精品蜜臀| 91超碰这里只有精品国产| 国产精品美女久久久久久久久久久 | 精品剧情在线观看| 亚洲综合一二三区| 高清久久久久久| 日韩欧美色电影| 亚洲一卡二卡三卡四卡| 国产91在线|亚洲| 一本色道久久综合狠狠躁的推荐| 精品盗摄一区二区三区| 性做久久久久久免费观看| 99re成人在线| 国产欧美一区二区在线观看| 毛片av一区二区| 久久久久久久综合| 国产制服丝袜一区| 日韩视频一区在线观看| 亚洲国产精品尤物yw在线观看| 成人av网站在线| 一区二区三区日韩欧美精品| 欧美又粗又大又爽| 综合久久久久久| 在线亚洲一区二区| 日本vs亚洲vs韩国一区三区二区| 欧美精品1区2区| 高清成人免费视频| 亚洲一级二级在线| 337p日本欧洲亚洲大胆色噜噜| 国产成人精品亚洲日本在线桃色| 亚洲国产精品ⅴa在线观看| 国产a区久久久| 亚洲综合区在线| 欧美日韩另类一区| 热久久免费视频| 亚洲免费视频中文字幕| 日韩一区二区不卡| 欧美日韩一区三区四区| 国产乱子伦一区二区三区国色天香| 最新久久zyz资源站| 欧美成人一区二区三区片免费| 成人av片在线观看| 日本亚洲欧美天堂免费| 国产亚洲欧洲一区高清在线观看| eeuss国产一区二区三区| 婷婷综合五月天| **性色生活片久久毛片| 国产日韩欧美激情| 欧美一区二区三区在线电影| 成人成人成人在线视频| 国产精品538一区二区在线| 亚洲日本va在线观看| 日韩欧美国产1| 成人avav在线| 99久久精品一区二区| 国产传媒一区在线|