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

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

?? utlab.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一区二区三区免费野_久草精品视频
一区二区三区 在线观看视频 | 麻豆91小视频| 日韩一级大片在线观看| 精品一区二区三区在线播放视频| 欧美日韩国产影片| 精品亚洲国产成人av制服丝袜| 欧美国产日韩在线观看| 欧美亚洲日本国产| 国产一区二区免费在线| 亚洲色图视频网站| 欧美成人一级视频| 欧美无砖专区一中文字| 国产精品综合视频| 全部av―极品视觉盛宴亚洲| 国产欧美日韩激情| 精品美女一区二区| 欧美日韩一本到| 91蜜桃网址入口| 成人18精品视频| 成人av在线一区二区三区| 精久久久久久久久久久| 日韩和欧美的一区| 亚洲成人在线免费| 亚洲影视在线播放| 亚洲香肠在线观看| 亚洲成人tv网| 石原莉奈一区二区三区在线观看| 亚洲日穴在线视频| 欧美国产精品专区| 亚洲欧洲日韩在线| 亚洲欧美区自拍先锋| 一区二区三区中文字幕电影| 亚洲精品伦理在线| 日韩专区在线视频| 国产一区二区三区黄视频 | 国产麻豆视频精品| 国产91精品一区二区| 97久久精品人人做人人爽50路| 99久久久无码国产精品| 91捆绑美女网站| 日韩欧美成人激情| 1区2区3区国产精品| 日本一区二区三区免费乱视频| 日韩毛片在线免费观看| 五月天一区二区三区| 国产精品夜夜爽| 欧美性感一类影片在线播放| 久久久亚洲精华液精华液精华液 | 国产一区二区毛片| 色婷婷亚洲综合| 久久久久久亚洲综合| 亚洲国产精品自拍| 色综合中文字幕| 精品国产免费久久| 秋霞成人午夜伦在线观看| 欧美日韩国产在线观看| 日韩一区在线看| 丁香网亚洲国际| 26uuu国产日韩综合| 日韩中文字幕区一区有砖一区 | 欧美96一区二区免费视频| 成人免费高清视频| 国产精品乱子久久久久| 国产一区二区三区高清播放| 欧美性受xxxx黑人xyx| 中文字幕欧美一| 99免费精品视频| 国产精品黄色在线观看| 高清不卡一二三区| 国产精品女主播av| 国产suv一区二区三区88区| 国产日韩精品一区二区三区| 六月丁香综合在线视频| 91精品福利在线一区二区三区 | 亚洲一区二区偷拍精品| 欧美三级在线看| 另类调教123区| 精品国产免费视频| 成人不卡免费av| 婷婷久久综合九色综合绿巨人| 91精品国产综合久久久久久| 久久99精品网久久| 久久这里只有精品6| 成人av在线播放网站| 亚洲色图在线播放| 精品国产一区二区三区久久久蜜月| 乱一区二区av| 国产精品另类一区| 91精品国产综合久久婷婷香蕉| 麻豆精品久久久| 成人免费在线播放视频| 日韩欧美亚洲另类制服综合在线| 国产高清久久久| 日本欧美一区二区三区| 国产精品电影一区二区三区| 欧美一区二区三区视频免费| 国产成人福利片| 国产尤物一区二区| 欧美aaaaaa午夜精品| 亚洲国产综合91精品麻豆| 日本一区二区视频在线| 精品国偷自产国产一区| 欧美日韩美少妇| 色拍拍在线精品视频8848| 成人av电影在线| 国产91精品久久久久久久网曝门| 久久成人精品无人区| 偷拍亚洲欧洲综合| 亚洲欧洲一区二区在线播放| 26uuu久久天堂性欧美| 日韩一区二区三区av| 欧美精品三级日韩久久| 色av成人天堂桃色av| 成人三级伦理片| 91美女在线观看| 欧美日韩久久不卡| 欧美久久久久中文字幕| 91精品福利在线一区二区三区| 欧美疯狂性受xxxxx喷水图片| 5858s免费视频成人| 91精品国产一区二区| 久久免费电影网| 一区二区三区成人| 久久精品国产精品亚洲红杏| 成人一级片网址| 欧美日韩电影一区| 日本一区二区综合亚洲| 五月天视频一区| 91亚洲男人天堂| 久久精品人人做人人综合| 中文字幕制服丝袜成人av | 777午夜精品视频在线播放| 精品日本一线二线三线不卡| 国产精品免费人成网站| 亚洲高清免费观看| 国产成人av自拍| 日韩欧美激情在线| 亚洲日穴在线视频| 国产精品白丝jk白祙喷水网站 | 欧美日韩夫妻久久| 亚洲另类中文字| 成人黄色av网站在线| 精品久久久久久久久久久久久久久 | 91福利在线导航| 中国av一区二区三区| 精品一区二区三区蜜桃| 99国产精品久久久久久久久久久 | 色诱视频网站一区| 国产欧美综合色| 日本aⅴ亚洲精品中文乱码| 欧美日韩国产综合一区二区三区| 国产精品久久久久久久浪潮网站 | 成人黄色国产精品网站大全在线免费观看 | 91精品国产麻豆| 香蕉久久一区二区不卡无毒影院| 成人爱爱电影网址| 综合久久国产九一剧情麻豆| 成人精品小蝌蚪| 国产欧美一区二区三区网站| 国产aⅴ综合色| 国产精品国产a级| av一区二区不卡| 亚洲在线视频一区| 欧美精品第一页| 国产精品一二三区| 成人免费一区二区三区视频 | 欧美日韩一级大片网址| 亚洲一区二区三区美女| 69av一区二区三区| 懂色一区二区三区免费观看| 亚洲柠檬福利资源导航| 欧洲一区二区三区在线| 久久99国产精品免费| 亚洲免费观看高清完整版在线| 欧美这里有精品| 国产成人在线色| 日韩不卡在线观看日韩不卡视频| 欧美精品一区在线观看| 国产激情精品久久久第一区二区| 一区二区三区四区在线播放| 久久精品一区二区| 欧美精选在线播放| 99国产精品国产精品毛片| 精品一区二区综合| 日韩专区一卡二卡| 一区二区三区av电影| 欧美激情一区二区三区不卡| 日韩欧美亚洲国产另类| 91精品在线麻豆| 欧美吻胸吃奶大尺度电影| 国产福利91精品一区二区三区| 亚洲成人免费影院| 亚洲一区免费在线观看| 一区二区三区四区在线| 亚洲女同一区二区| 亚洲男同1069视频| 樱花草国产18久久久久| 亚洲中国最大av网站| 亚洲人成网站影音先锋播放| 亚洲欧洲国产日韩|