没有合适的资源?快使用搜索试试~ 我知道了~
分布估计算法 C++
5星 · 超过95%的资源 需积分: 10 49 下载量 87 浏览量
2011-05-07
11:13:28
上传
评论 1
收藏 8KB TXT 举报
温馨提示
试读
14页
使用C++实现的一个简单的分布估计算法,可实现多峰函数的最优化
资源推荐
资源详情
资源评论
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#include <time.h>
#include <iostream.h>
#define PI acos(-1.0)
struct Point
{
double *x;
double y;
};
int itercount=0;
int dimension;
double localbest;
double currentbest;
int OptFound;
int OptNum[4]={3,18,81,324};
int lambda;
double *C;
double *U;
double **X;
double *Y;
struct Point*Optqueue;
double (*fitness)(double *MX,int Dim);
void Tofile();
int InsertOpt(double *ex,double ey);
void AllocateMemory(int dim,int lam);
void Init();
#include <math.h>
#include <stdlib.h>
#include <time.h>
#include <iostream.h>
#define PI acos(-1.0)
struct Point
{
double *x;
double y;
};
int itercount=0;
int dimension;
double localbest;
double currentbest;
int OptFound;
int OptNum[4]={3,18,81,324};
int lambda;
double *C;
double *U;
double **X;
double *Y;
struct Point*Optqueue;
double (*fitness)(double *MX,int Dim);
void Tofile();
int InsertOpt(double *ex,double ey);
void AllocateMemory(int dim,int lam);
void Init();
void SamplerIndiv(double *randx, int Dim,double *C,double *u);
int IsPeak(double *u,double y);
void MatrixTimes(double *lm,double* rm,double * tm ,int m,int d,int n);
void AdaptCU(double *C,double *U,double *Xbest,int dimension);
void printMatrix(double *M,int N,int c)
{
int i;
for(i=1;i<=N*c;i++)
{
printf("%.8f ",M[i-1]);
if(i%c==0)
printf("\n");
}
}
int testBound(double *x,int dim)
{
int i;
for(i=0;i<dim;i++)
{
if((x[i]>10)||(x[i]<-10))
return 0;
}
return 1;
}
double f5(double* X,int N)
{
double sum=1;
double temp=0;
for(int i=0;i<N;i++){
int IsPeak(double *u,double y);
void MatrixTimes(double *lm,double* rm,double * tm ,int m,int d,int n);
void AdaptCU(double *C,double *U,double *Xbest,int dimension);
void printMatrix(double *M,int N,int c)
{
int i;
for(i=1;i<=N*c;i++)
{
printf("%.8f ",M[i-1]);
if(i%c==0)
printf("\n");
}
}
int testBound(double *x,int dim)
{
int i;
for(i=0;i<dim;i++)
{
if((x[i]>10)||(x[i]<-10))
return 0;
}
return 1;
}
double f5(double* X,int N)
{
double sum=1;
double temp=0;
for(int i=0;i<N;i++){
剩余13页未读,继续阅读
资源评论
- statdlut2013-11-09挺好的代码段,希望多分享一点
- doubleulzj2015-10-07很不错的代码,值得借鉴
zhonganyuan
- 粉丝: 0
- 资源: 11
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功