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

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

?? utlab.h

?? 猴群算法
?? 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 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 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, xx, min=9999, max=-9999;
   int    i;
   
   for(i=1; i<=samplenumber; i++) {
       if(x[i]<min) min=x[i];
	   if(x[i]>max) 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];
		}
        v1=(v1+1-v2)/2;
        if(v1>=alpha) min=xx;
    	else max=xx;
   }while((max-min)>0.001);
 
   return (max+min)/2;
}

 double fuzzypessimistic(double x[], double mu[], int samplenumber, double alpha)
 {
   double v1, v2, xx, min=9999, max=-9999;
   int    i;
  
   for(i=1; i<=samplenumber; i++){
     
	   if(x[i]<min) min=x[i];
	   if(x[i]>max) 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];
		}

        v1=(v1+1-v2)/2;

        if(v1>=alpha) max=xx;
        
		else min=xx;
   }while((max-min)>0.001);
 
   return (max+min)/2;
}


double fuzzymean(double x[], double mu[], int samplenumber, int integralnumber=2000)
{
	int i,k;
	double Expect=0, left=9999, right=-9999, b1,b2,r;
	
	for(i=1;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);
}

double expect(double f[], double mu[], int m1, int m2=2000)
{
	int i,k;
	double Expect=0, left=9999, right=-9999, b1,b2,r;
	
	for(i=1;i<=m1;i++) {
	  if(left>f[i]) left=f[i];
	  if(right<f[i]) right=f[i];
	}
	for(k=1; k<=m2; k++) {
	  r=myu(left,right);
	  b1=0;
	  b2=0;
	  if(r>=0) {
		for(i=1; i<=m1; i++) {
		  if(f[i]>=r&&b1<mu[i]) b1 = mu[i];
		  if(f[i]<r&&b2<mu[i]) b2 = mu[i];
		}		
		Expect = Expect+(b1+1-b2)/2.0;
	  }
	  else {
		for(i=1; i<=m1; i++) {
		  if(f[i]<=r&&b1<mu[i]) b1 = mu[i];
		  if(f[i]>r&&b2<mu[i]) b2 = mu[i];
		}		
		Expect = Expect-(b1+1-b2)/2.0;
	  }
	}
	return Expect*(right-left)/m2+((left>0)?left:0)+((right<0)?right:0);
}


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 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一区二区三区免费野_久草精品视频
麻豆国产精品777777在线| 亚洲国产aⅴ天堂久久| 亚洲综合视频在线| 老色鬼精品视频在线观看播放| 成人一区二区三区| 91麻豆精品久久久久蜜臀| 国产精品久久久99| 极品少妇一区二区三区精品视频| 欧美在线视频日韩| 日韩一区中文字幕| 国产激情视频一区二区三区欧美 | 99精品视频一区二区| 欧美一级免费大片| 亚洲国产精品久久人人爱| 成人激情黄色小说| 亚洲国产精品t66y| 国产美女一区二区三区| 欧美一区二区三区免费观看视频| 一区二区免费在线| 99国产精品国产精品久久| 亚洲国产精品t66y| 国产91对白在线观看九色| 久久先锋影音av| 国产精品资源在线| 久久亚洲一级片| 国产综合成人久久大片91| 欧美日韩中文国产| 亚洲成人激情av| 欧美亚洲一区三区| 亚洲成人中文在线| 欧美日韩久久不卡| 日日骚欧美日韩| 欧美久久高跟鞋激| 免费成人在线播放| 欧美成人女星排名| 国产一区二区在线观看视频| 精品成人a区在线观看| 精品午夜久久福利影院| 久久久三级国产网站| 国产一区二区精品久久91| 国产亚洲精品资源在线26u| 国产美女在线观看一区| 国产精品乱人伦| 色婷婷综合久久久中文字幕| 亚洲一区二区三区自拍| 欧美日韩亚洲综合在线 | 国产精品国产三级国产a | 国产91在线看| 亚洲三级电影全部在线观看高清| 91小视频免费看| 香蕉久久一区二区不卡无毒影院 | 国产乱码精品一品二品| 欧美韩日一区二区三区| 色婷婷香蕉在线一区二区| 亚洲一区二区中文在线| 日韩亚洲欧美一区二区三区| 国产一区二区三区免费看| 亚洲国产经典视频| 欧美日韩亚洲综合一区| 国产一区二区福利| 一区二区成人在线| 精品毛片乱码1区2区3区| 成人免费视频一区| 亚洲第一会所有码转帖| 久久欧美一区二区| 91国在线观看| 久久99国产精品免费| 亚洲人精品午夜| 日韩免费看的电影| 色综合久久综合网97色综合 | 成人高清免费观看| 亚洲444eee在线观看| 国产性色一区二区| 欧美精品久久久久久久多人混战 | 日韩欧美一级二级三级久久久| 国产剧情在线观看一区二区| 亚洲一级不卡视频| 国产欧美一区二区精品秋霞影院| 欧美在线小视频| 不卡一区中文字幕| 美女诱惑一区二区| 一区二区三区欧美久久| 久久精品亚洲一区二区三区浴池 | 92精品国产成人观看免费| 天天影视网天天综合色在线播放| 国产欧美日韩麻豆91| 日韩精品自拍偷拍| 欧美亚洲国产一卡| 99久久伊人精品| 国产传媒欧美日韩成人| 男男成人高潮片免费网站| 一区二区三区精品| 亚洲天堂2014| 国产精品人妖ts系列视频| 精品国产一二三| 欧美精品一卡二卡| 91九色最新地址| 成人做爰69片免费看网站| 日韩福利电影在线| 欧美日韩久久久| 在线视频你懂得一区二区三区| 成人性视频网站| 国产精品一区二区久久不卡| 人人精品人人爱| 视频一区国产视频| 亚洲午夜三级在线| 亚洲一区二区三区三| 亚洲综合男人的天堂| 中文字幕乱码日本亚洲一区二区| 久久亚洲精品国产精品紫薇| 精品欧美一区二区久久| 精品国产123| 日韩欧美成人一区二区| 精品欧美一区二区久久| 久久色.com| 国产三级欧美三级| 国产精品污污网站在线观看| 国产精品美女视频| 国产精品黄色在线观看| 中文字幕日本不卡| 一区二区三区四区激情| 五月天网站亚洲| 精品国产一区二区三区久久久蜜月| 精品乱码亚洲一区二区不卡| 国产欧美一区二区在线| 成人妖精视频yjsp地址| 99国产一区二区三精品乱码| 色婷婷综合在线| 亚洲国产精品久久人人爱蜜臀| 亚洲国产成人av好男人在线观看| 亚洲一区二区三区四区五区中文 | 天使萌一区二区三区免费观看| 午夜亚洲国产au精品一区二区| 午夜精品福利一区二区三区蜜桃| 奇米精品一区二区三区在线观看 | 91九色最新地址| 欧美一区欧美二区| 久久久久久久综合| 亚洲人成精品久久久久| 亚洲成人一区二区在线观看| 蜜臀91精品一区二区三区| 国产精品亚洲一区二区三区妖精 | 国产精品欧美极品| 亚洲午夜国产一区99re久久| 日韩国产欧美三级| 福利一区二区在线观看| 色成年激情久久综合| 日韩欧美一二区| 国产精品久久国产精麻豆99网站 | 69久久夜色精品国产69蝌蚪网| 日韩精品一区二区三区蜜臀| 国产精品美女久久久久av爽李琼| 亚洲国产成人av| 成人动漫一区二区| 日韩欧美国产综合| 亚洲欧洲精品一区二区三区不卡| 水野朝阳av一区二区三区| 国产xxx精品视频大全| 欧美日本在线视频| 国产精品入口麻豆原神| 麻豆国产一区二区| 日本韩国精品一区二区在线观看| 精品国产成人系列| 艳妇臀荡乳欲伦亚洲一区| 国产酒店精品激情| 日韩视频一区二区在线观看| 亚洲欧美另类久久久精品| 久久电影国产免费久久电影| 欧美在线小视频| ㊣最新国产の精品bt伙计久久| 九一久久久久久| 欧美日韩高清一区二区不卡 | 日本高清视频一区二区| 2020国产成人综合网| 亚洲成a人片在线不卡一二三区| 成人免费视频caoporn| 欧美一级精品在线| 亚洲国产成人av网| 91精品1区2区| 亚洲欧洲日本在线| 国产精品综合二区| 精品盗摄一区二区三区| 蜜臀av性久久久久蜜臀aⅴ| 欧美丝袜丝交足nylons图片| 最新中文字幕一区二区三区| 不卡一区中文字幕| 国产精品久久三| 成人午夜激情影院| 久久久精品国产免费观看同学| 美女视频黄免费的久久| 91精品国产高清一区二区三区蜜臀| 亚洲另类春色国产| 色综合咪咪久久| 亚洲精品第一国产综合野| 色婷婷综合久久久中文字幕| 亚洲人一二三区| 色8久久精品久久久久久蜜| 尤物av一区二区| 欧美视频一区二| 亚洲va欧美va人人爽|