声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 3566|回复: 7

[综合讨论] 求助fminsearch用法

[复制链接]
发表于 2010-7-21 13:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
哪位高手帮忙看看

我的M文件是:

function [G5]=fun(x);
syms n1 n2 k1 k2 d;
[subwave,nsub]=textread('subout.txt','%f %f');
[filmwave,filmtran]=textread('filmtr.dat','%f %f');
[p,q]=size(subwave);
for j=1:p;
    wavel(j)=subwave(j,1); n(j)=n1+n2/((wavel(j))^2); k(j)=k1*exp(k2/wavel(j)); N(j)=n(j)-i*k(j);
    phase(j)=2*pi*N(j)*d/wavel(j); ns(j)=nsub(j,1);
    B(j)=cos(phase(j))+ns(j)*i*sin(phase(j))/N(j);C(j)=i*N(j)*sin(phase(j))+ns(j)*cos(phase(j));
    T(j)=4*ns(j)/((B(j)+C(j))*conj(B(j)+C(j)));
    ts(j)=1-((1-ns(j))/(1+ns(j)))^2;
    t1(j)=ts(j)*T(j); tf(j)=filmtran(j,1)/100;
    difference(j)=(t1(j)-tf(j))^2;
end
G=symsum(difference(j),1,401); G1=subs(G,n1,sym('x(1)')); G2=subs(G1,n2,sym('x(2)'));
G3=subs(G2,k1,sym('x(3)')); G4=subs(G3,k2,sym('x(4)')); G5=subs(G4,d,sym('x(5)'));

在命令窗口运行
>> options=optimset('tolfun',1e-8,'tolx',1e-8);
>> [xmin,value,flag,output]=fminsearch(@fun,[1.7,4000,0.005,400,500],options);

结果出现如下错误提示

??? Conversion to double from sym is not possible.

Error in ==> fminsearch at 175
fv(:,1) = funfcn(x,varargin{:});

M文件拷贝到命令窗口运行正常,就是用fminsearch是出错,大侠们帮帮忙吧

各位,我都转了好几个论坛了,怎么就没有高手呢?
潜水的高手,冒个泡吧

[ 本帖最后由 ChaChing 于 2010-8-3 08:22 编辑 ]
回复
分享到:

使用道具 举报

发表于 2010-7-22 11:28 | 显示全部楼层
...??? Conversion to double from sym is not possible...

个人水平专业有限, 试试不要使用sym!
ref:http://forum.vibunion.com/forum/viewthread.php?tid=94049&;highlight=

[ 本帖最后由 ChaChing 于 2010-7-22 23:12 编辑 ]
 楼主| 发表于 2010-7-22 12:55 | 显示全部楼层

回复 板凳 ChaChing 的帖子

由于我的方程表达式太长,401个循环,没有办法直接拷贝。电脑会假死。
请问楼上,表达式中的未知量必须是X(1),X(2)这种形式的吧,不能用x1,x2形式的吧??
 楼主| 发表于 2010-7-26 12:03 | 显示全部楼层

回复 沙发 ChaChing 的帖子

谢谢楼上,根据你的链接,我的问题已经解决
发表于 2010-7-26 23:24 | 显示全部楼层

回复 地板 fanyushan 的帖子

虽然没给实质帮忙, 但很高兴LZ已经解决问题!
建议与大家分享你的成果:loveliness:
 楼主| 发表于 2010-7-28 09:26 | 显示全部楼层

回复 5楼 ChaChing 的帖子

将M文件改为:

function G=fun(x);
n1=x(1);
n2=x(2);
k1=x(3);
k2=x(4);
d=x(5);
[subwave,nsub]=textread('subout.txt','%f %f');
[filmwave,filmtran]=textread('filmtr.dat','%f %f');
[p,q]=size(subwave);
for j=1:p;
    wavel(j)=subwave(j,1);
    n(j)=n1+n2/((wavel(j))^2);
    k(j)=k1*exp(k2/wavel(j));
    N(j)=n(j)-i*k(j);
    phase(j)=2*pi*N(j)*d/wavel(j);
    ns(j)=nsub(j,1);
    B(j)=cos(phase(j))+ns(j)*i*sin(phase(j))/N(j);
    C(j)=i*N(j)*sin(phase(j))+ns(j)*cos(phase(j));
    T(j)=4*ns(j)/((B(j)+C(j))*conj(B(j)+C(j)));
    ts(j)=1-((1-ns(j))/(1+ns(j)))^2;
    t1(j)=ts(j)*T(j);
    tf(j)=filmtran(j,1)/100;
    difference(j)=(t1(j)-tf(j))^2;
end
G=sum(difference);

然后运行
>> options=optimset('tolfun',1e-8,'tolx',1e-8);
>> [xmin,value,flag,output]=fminsearch(@fun,[1.7,4000,0.005,400,500],options);


不过又出现新问题,应该是不收敛,解出来的答案是初始点附近的局部极小值,我在考虑如何收敛。
上周买了精通matlab最优化,学习中

评分

1

查看全部评分

 楼主| 发表于 2010-8-2 11:13 | 显示全部楼层

如何求得全局极小值

matlab下,求得的是局部极小值,且在给出的初始点附近。
我的方程很复杂,5个未知数,400个循环。个参数的变化很大,小的是2左右,大的可能是200000左右,
初始值不好选,我如何来求极小值????
发表于 2011-1-17 10:19 | 显示全部楼层
回复 7 # fanyushan 的帖子

lz 这个问题解决没呢,可否分享下你的成果啊~~
小弟现在也遇到了类似的问题了!!
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-9-21 19:09 , Processed in 0.065363 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表