fanyushan 发表于 2010-7-21 13:00

求助fminsearch用法

哪位高手帮忙看看

我的M文件是:

function =fun(x);
syms n1 n2 k1 k2 d;
=textread('subout.txt','%f %f');
=textread('filmtr.dat','%f %f');
=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);
>> =fminsearch(@fun,,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 编辑 ]

ChaChing 发表于 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 编辑 ]

fanyushan 发表于 2010-7-22 12:55

回复 板凳 ChaChing 的帖子

由于我的方程表达式太长,401个循环,没有办法直接拷贝。电脑会假死。
请问楼上,表达式中的未知量必须是X(1),X(2)这种形式的吧,不能用x1,x2形式的吧??

fanyushan 发表于 2010-7-26 12:03

回复 沙发 ChaChing 的帖子

谢谢楼上,根据你的链接,我的问题已经解决

ChaChing 发表于 2010-7-26 23:24

回复 地板 fanyushan 的帖子

虽然没给实质帮忙, 但很高兴LZ已经解决问题!
建议与大家分享你的成果:loveliness:

fanyushan 发表于 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);
=textread('subout.txt','%f %f');
=textread('filmtr.dat','%f %f');
=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);
>> =fminsearch(@fun,,options);


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

fanyushan 发表于 2010-8-2 11:13

如何求得全局极小值

matlab下,求得的是局部极小值,且在给出的初始点附近。
我的方程很复杂,5个未知数,400个循环。个参数的变化很大,小的是2左右,大的可能是200000左右,
初始值不好选,我如何来求极小值????

btee123 发表于 2011-1-17 10:19

回复 7 # fanyushan 的帖子

lz 这个问题解决没呢,可否分享下你的成果啊~~
小弟现在也遇到了类似的问题了!!
页: [1]
查看完整版本: 求助fminsearch用法