24小时热门版块排行榜    

查看: 3028  |  回复: 9

shixin0403

银虫 (正式写手)

[求助] 模式搜索MATLAB程序

最近看了一篇 吴兴远《模式搜索法在最优化问题中应用》
想学习一下模式搜索法,特定的将吴的程序抄写出来,但是运行一直出错。
我用的MATLAB的版本是7.11.0
求助各位大侠,看看程序哪里出错了?
现将程序附下:
%1、编写m函数
function y = myfun(z,noise);
y=zeros(1,size(z,1));noise=1;
for i=1:size(z,1)
x=(z,;
if x(1)^2+x(2)^2<=25
y(i)=x(1)^2+x(2)^2-25+noise*randn;
elseif x(1)^2+(x(2)-9)^2<=16
y(i)=x(1)^2+(x(2)-9)^2-16+noise*randn;
else y(i)=0+noise*randn;
end end end
%2、确定初始点

%3、编写主程序
X0=[-8 8];
LB =[-10 -10];
UB =[10 15];
range=[LB(1) UB(1) LB(2) UB(2)];
Objfcn = @myfun;
Clf;showSmoothFcn(Objfcn,range); hold on;
Title('objective function')
fig = gcf;
PSoptions = psoptimset('Display','iter','OutputFcn',@psOut);
[x,z]=patternsearch(Objfcn,X0,[],[],[],[],LB,UB,Psoptions)
Figure(fig);
hold on;
plot3(x(1),x(2),z,'dr','MarkerSize',12,'MarkerFaceColor','r');
hold off;
回复此楼
朝着正确的方向奋斗!
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

shixin0403

银虫 (正式写手)

那个笑脸应该是:x=(z, : ) ;
朝着正确的方向奋斗!
2楼2012-05-25 21:25:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuanmd

至尊木虫 (知名作家)

衔头义定自

【答案】应助回帖

感谢参与,应助指数 +1
function y = myfun(z,noise)
y=zeros(1,size(z,1));noise=1;
for i=1:size(z,1)
    x=z(i,;
    if x(1)^2+x(2)^2<=25
        y(i)=x(1)^2+x(2)^2-25+noise*randn;
    elseif x(1)^2+(x(2)-9)^2<=16
        y(i)=x(1)^2+(x(2)-9)^2-16+noise*randn;
    else y(i)=0+noise*randn;
    end
end



clc
X0=[-8 8];
LB =[-10 -10];
UB =[10 15];
range=[LB(1) UB(1);
    LB(2) UB(2)];
Objfcn = @myfun;
Clf;showSmoothFcn(Objfcn,range); hold on;
Title('objective function')
fig = gcf;
PSoptions = psoptimset('Display','iter','OutputFcn',@psOut);
[x,z]=patternsearch(Objfcn,X0,[],[],[],[],LB,UB,PSoptions);
figure(fig);
hold on;
plot3(x(1),x(2),z,'dr','MarkerSize',12,'MarkerFaceColor','r');
hold off;
梦想总是要有的,万一实现了呢?
3楼2012-05-26 18:31:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuanmd

至尊木虫 (知名作家)

衔头义定自

【答案】应助回帖

人脸那行为     x=z(i,;
上面的程序 分别放到两个不同的文件中
梦想总是要有的,万一实现了呢?
4楼2012-05-26 18:33:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuanmd

至尊木虫 (知名作家)

衔头义定自

部分运行结果:(图附不上来)
Iter     f-count          f(x)      MeshSize     Method
    0        1        1.92336             1      
    1        2       -14.6523             2     Successful Poll
    2        2       -14.6523             1     Refine Mesh
    3        5       -14.6523           0.5     Refine Mesh
    4        8       -23.4429             1     Successful Poll
    5       10       -23.4429           0.5     Refine Mesh
    6       14       -23.4429          0.25     Refine Mesh
    7       18       -23.4429         0.125     Refine Mesh
    8       19       -23.7399          0.25     Successful Poll
    9       22       -24.4088           0.5     Successful Poll
   10       26       -24.4088          0.25     Refine Mesh
   11       27       -24.5167           0.5     Successful Poll
   12       31       -24.5167          0.25     Refine Mesh
   13       35       -24.5167         0.125     Refine Mesh
   14       38       -25.9035          0.25     Successful Poll
   15       42       -25.9035         0.125     Refine Mesh
   16       46       -25.9035        0.0625     Refine Mesh
   17       50       -25.9035       0.03125     Refine Mesh
   18       54       -25.9035       0.01563     Refine Mesh
   19       57       -26.2087       0.03125     Successful Poll
   20       61       -26.2087       0.01563     Refine Mesh
   21       65       -26.2087      0.007813     Refine Mesh
   22       69       -26.2087      0.003906     Refine Mesh
   23       73       -26.2087      0.001953     Refine Mesh
   24       77       -26.2087     0.0009766     Refine Mesh
   25       81       -26.2087     0.0004883     Refine Mesh
   26       85       -26.2087     0.0002441     Refine Mesh
   27       89       -26.2087     0.0001221     Refine Mesh
   28       93       -26.2087    6.104e-005     Refine Mesh
   29       95       -27.2486     0.0001221     Successful Poll
   30       99       -27.2486    6.104e-005     Refine Mesh

Iter     f-count        f(x)       MeshSize      Method
   31      103       -27.2486    3.052e-005     Refine Mesh
   32      107       -27.2486    1.526e-005     Refine Mesh
   33      111       -27.2486    7.629e-006     Refine Mesh
   34      115       -27.2486    3.815e-006     Refine Mesh
   35      119       -27.2486    1.907e-006     Refine Mesh
   36      123       -27.2486    9.537e-007     Refine Mesh
Optimization terminated: mesh size less than options.TolMesh.

» 本帖已获得的红花(最新10朵)

梦想总是要有的,万一实现了呢?
5楼2012-05-26 18:35:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

shixin0403

银虫 (正式写手)

送鲜花一朵
引用回帖:
5楼: Originally posted by yuanmd at 2012-05-26 18:35:15
部分运行结果:(图附不上来)
Iter     f-count          f(x)      MeshSize     Method
    0        1        1.92336             1      
    1        2       -14.6523             2     Successful Po ...

谢谢啊!
朝着正确的方向奋斗!
6楼2012-05-28 21:56:31
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

shixin0403

银虫 (正式写手)

??? Error using ==> feval
Undefined function or method 'myfun' for input arguments of type 'double'.

Error in ==> showSmoothFcn at 23
values = feval(fcn,pop);

大侠,我将程序复制到MATLAB中,建立M文件,然后复制程序,但是结果是这样的?难道是我用的版本有问题?
朝着正确的方向奋斗!
7楼2012-05-28 22:05:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuanmd

至尊木虫 (知名作家)

衔头义定自

引用回帖:
7楼: Originally posted by shixin0403 at 2012-05-28 22:05:29
??? Error using ==> feval
Undefined function or method 'myfun' for input arguments of type 'double'.

Error in ==> showSmoothFcn at 23
values = feval(fcn,pop);

大侠,我将程序复制到MATLAB ...

将myfun 函数部分复制并建立M文件命名为myfun
再将2楼的clc及以下的部分复制到另一个M文件,命名任意,只要符合命名规则即可。注意这两个文件要放在同一个文件夹下,运行第二个即可。
梦想总是要有的,万一实现了呢?
8楼2012-05-28 22:34:19
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuanmd

至尊木虫 (知名作家)

衔头义定自

引用回帖:
7楼: Originally posted by shixin0403 at 2012-05-28 22:05:29
??? Error using ==> feval
Undefined function or method 'myfun' for input arguments of type 'double'.

Error in ==> showSmoothFcn at 23
values = feval(fcn,pop);

大侠,我将程序复制到MATLAB ...

注意:不要把所有的程序放在同一个M文件中!分别放,因为一个是函数文件,一个是脚本文件。
梦想总是要有的,万一实现了呢?
9楼2012-05-28 22:35:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

shixin0403

银虫 (正式写手)

找到错误了。
错误出在PSoptions函数上,S没有大写。
朝着正确的方向奋斗!
10楼2012-05-29 21:52:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 shixin0403 的主题更新
信息提示
请填处理意见