⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cec2005.c

📁 这是Clerc最新的文章balanced PSO,包括论文和与其配套的源程序
💻 C
字号:
		case 100: // Parabola (Sphere) CEC 2005
		f=-450;
		for (d = 0; d < xs.size; d++) 
	  {
			xd = xs.x[d];			xs.x[d]=xd-offset_0[d];			f = f + xd * xd;  
		} 
		break;					case 102:  // Rosenbrock /*xs.x[0]=-2; // Local minimum		for (d = 1; d < xs.size; d++) 
		{
			xs.x[d]=0;
		}*/
		for (d = 0; d < xs.size; d++) 
		{
			xs.x[d]=xs.x[d]-offset_2[d];
		}
		f=390;
		t0 = xs.x[0]  + 1;	// Solution on (0,...0) when	  															// offset=0
	  for (d = 1; d < xs.size; d++)
	  {     
			
			t1 = xs.x[d]  + 1;	      
			tt = 1 - t0;	      
			f += tt * tt;      
			tt = t1 - t0 * t0;      
			f += 100 * tt * tt;	      
			t0 = t1;    
		} //printf("\n f %f",f); exit(0); 
		break;				case 103: // Rastrigin 
		for (d = 0; d < xs.size; d++) 
		{
			xs.x[d]=xs.x[d]-offset_3[d];
		}
		f=-330;
	  k = 10;  
	
		for (d = 0; d < xs.size; d++)    
	  {     
			xd = xs.x[d];	      
			f =f+ xd * xd - k * cos (2 * pi * xd);	    
		}	  
		f =f+ xs.size * k;  
		break;			case 104: // Schwefel (F2)		for (d = 0; d < xs.size; d++) 
		{
			xs.x[d]=xs.x[d]-offset_4[d];
		}    f = -450;    for (d=0; d<xs.size; d++)    {        sum2 = 0.0;        for (k=0; k<=d; k++)        {            sum2 += xs.x[k];        }        f += sum2*sum2;    }		break;		case 105: // Griewank. WARNING: in the CEC 2005 benchmark it is rotated	   sum1 = 0.0;	   sum2 = 1.0;		 f=-180;	   for (d=0; d<xs.size; d++)		 {		    xd=xs.x[d]-offset_5[d];				sum1 += xd*xd;        sum2 *= cos(xd/sqrt(1.0+d)); 		 }    f =f+ 1.0 + sum1/4000.0 - sum2;		break;		case 106: // Ackley 
		f=-140;    sum1 = 0.0;    sum2 = 0.0;    for (d=0; d<xs.size; d++)    {        xd = xs.x[d]-offset_6[d];				sum1 += xd*xd;        sum2 += cos(2.0*pi*xd);    }    sum1 = -0.2*sqrt(sum1/xs.size);    sum2 /= xs.size;    f = f+ 20.0 + E - 20.0*exp(sum1) - exp(sum2);		break;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -