亚洲欧美第一页_禁久久精品乱码_粉嫩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 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精品国产aⅴ一区二区| 亚洲成人综合视频| 8x福利精品第一导航| 日日夜夜免费精品| 日韩精品专区在线影院重磅| 激情图片小说一区| 国产日韩欧美精品综合| 成人一区二区三区视频| 亚洲人成网站在线| 欧美精品色一区二区三区| 青青草国产精品97视觉盛宴 | 色综合久久久久久久| 亚洲免费观看视频| 欧美精品v国产精品v日韩精品| 另类调教123区 | 国内精品久久久久影院色| 久久久久久免费| 99久久精品国产一区二区三区 | 91国产丝袜在线播放| 樱桃视频在线观看一区| 欧美日韩国产小视频| 激情综合五月婷婷| 中文成人av在线| 欧美三级一区二区| 九一九一国产精品| 亚洲精品一二三| 精品三级av在线| 91亚洲男人天堂| 久久av老司机精品网站导航| 综合色天天鬼久久鬼色| 91麻豆精品国产91久久久更新时间| 国产麻豆欧美日韩一区| 亚洲一本大道在线| 久久久久久免费网| 欧美精品丝袜中出| 99精品欧美一区二区蜜桃免费 | 国产成人福利片| 亚洲成人av福利| 国产日本欧美一区二区| 欧美伦理电影网| 99re成人精品视频| 国产在线精品免费| 午夜影院在线观看欧美| 国产精品欧美一区喷水| 欧美精品久久一区| 色偷偷久久一区二区三区| 国产一区视频网站| 日本在线不卡视频一二三区| 亚洲免费在线观看视频| 久久久久亚洲蜜桃| 91精品免费观看| 在线观看国产一区二区| 成人精品一区二区三区中文字幕| 秋霞午夜av一区二区三区| 一级精品视频在线观看宜春院 | 欧美日韩精品免费观看视频| 94-欧美-setu| 不卡av在线免费观看| 久久精品国产精品青草| 亚洲成人午夜电影| 一区二区三区精品在线| 国产精品成人午夜| 国产午夜精品一区二区三区嫩草| 日韩欧美一区二区在线视频| 欧美日本一区二区三区四区| 欧美手机在线视频| 色综合久久中文综合久久牛| 99精品热视频| a级精品国产片在线观看| 国产一区二区毛片| 精久久久久久久久久久| 蜜桃视频一区二区三区在线观看| 日韩电影网1区2区| 亚洲成在线观看| 午夜电影网一区| 午夜精品免费在线观看| 五月天中文字幕一区二区| 亚洲一区影音先锋| 亚洲第一狼人社区| 午夜精品一区在线观看| 午夜精品视频在线观看| 日韩精品乱码免费| 美国毛片一区二区三区| 久久国产日韩欧美精品| 精品一区二区综合| 国产一区在线观看视频| 国产精品99久久不卡二区| 国产高清在线观看免费不卡| 成人午夜看片网址| proumb性欧美在线观看| 99精品桃花视频在线观看| 91丨porny丨蝌蚪视频| 欧美亚洲国产一区二区三区| 欧美伦理电影网| 欧美成人一区二区三区| 国产亚洲人成网站| 国产精品成人一区二区艾草| 一区二区三区 在线观看视频| 亚洲va国产va欧美va观看| 日韩av在线播放中文字幕| 美女视频黄 久久| 成人夜色视频网站在线观看| 色8久久精品久久久久久蜜| 欧美日韩大陆在线| 精品久久久久久综合日本欧美 | 91免费观看视频在线| 在线观看日韩精品| 正在播放一区二区| 国产亚洲欧美中文| 一区二区三区日本| 久久国产精品色婷婷| av在线不卡网| 在线播放中文一区| 久久久亚洲高清| 亚洲影院在线观看| 国产一区二区三区在线看麻豆| 97se亚洲国产综合自在线| 4438x成人网最大色成网站| 国产午夜精品久久| 亚洲成人在线免费| 风间由美一区二区三区在线观看 | 精品国产伦一区二区三区观看方式 | 狠狠色伊人亚洲综合成人| 99久久99久久精品免费看蜜桃 | 国产成人精品免费网站| 色哟哟亚洲精品| 亚洲精品一区二区三区福利| 亚洲精品乱码久久久久久日本蜜臀| 久久电影网电视剧免费观看| 91黄视频在线| 久久久精品2019中文字幕之3| 亚洲在线视频一区| 成人一区在线观看| 日韩精品最新网址| 亚洲国产精品人人做人人爽| 成人久久久精品乱码一区二区三区 | 日韩你懂的在线观看| 亚洲美女少妇撒尿| 国产成人免费视频一区| 91麻豆精品国产91久久久资源速度| 中文字幕亚洲区| 国产一二三精品| 日韩一区二区电影网| 一区二区三区欧美久久| 不卡的av网站| 久久精品视频免费| 蜜臀久久99精品久久久久宅男 | 精品国产乱码久久久久久老虎| 一区二区三区波多野结衣在线观看| 国产91精品露脸国语对白| 91精品国产麻豆| 亚洲不卡在线观看| 99精品国产视频| 国产精品亲子乱子伦xxxx裸| 国产精品亚洲视频| 久久久久9999亚洲精品| 蜜臀精品一区二区三区在线观看 | 久久99久久精品| 日韩亚洲欧美在线| 午夜精品久久久久久不卡8050| 欧洲国内综合视频| 亚洲一区欧美一区| 在线看国产一区二区| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 高清国产一区二区| 欧美高清在线精品一区| 国产成人综合在线观看| 久久久综合九色合综国产精品| 国产精品996| 国产精品久久久久久久久搜平片| 成人激情图片网| 国产精品国产三级国产aⅴ入口 | 91精品国产一区二区三区| 亚洲国产精品欧美一二99| 精品视频免费在线| 日韩国产欧美三级| 日韩午夜小视频| 另类欧美日韩国产在线| 久久这里只有精品视频网| 国产精品18久久久久久vr| 中文字幕乱码亚洲精品一区| 91蜜桃婷婷狠狠久久综合9色| 亚洲精品国产第一综合99久久| 在线中文字幕一区二区| 图片区小说区区亚洲影院| 在线成人av网站| 国产黄色精品视频| 亚洲天堂免费看| 91精品国产综合久久小美女| 美国毛片一区二区三区| 国产日韩av一区| 欧美在线免费播放| 蜜桃视频免费观看一区| 国产欧美一区视频| 色欧美日韩亚洲| 蜜桃视频免费观看一区| 中文字幕高清不卡|