|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
原本使用 function f=myfun(x)
* C- C1 e- r" ]' M9 D f=sin(x(1))+*cos(x(2))) {7 N2 t4 E; W: ?& G/ ~1 o1 _
对其用[x,fval]=fminsearch(@myfun,[-1 -1])便会返回x=【值 值 】一个1*2矩阵 和 fval=【值】一个1*1矩阵
; g) p! p- c; |+ x& h& e- k7 h+ l4 u0 D- @3 m
现在加入循环 function f=myfun(x,a)
5 d: y* l$ M$ v: S2 J' A f=sin(x(1))+a.*cos(x(2))
7 ~( V0 l7 W1 l& N
% v6 V& _; p9 U8 U$ i) } fval=zeros(1,2);
6 E9 R3 m1 J- q' h. U M: T+ @ for a=1:2
* A. l, o0 Z4 _. T! G' e$ s [x,fval(a)]=fminsearch(@(x)myfun(x,a),1000)# E( U4 m3 q& N U* O" `; W% F
; K' D) S }, a
end3 Y9 Y" w, [5 ^) [. y
便可以把两次循环的fval的值存起来,但用相同方法,由于x=【值 值 】返回一个1*2矩阵便会无法执行赋值
1 @6 ^- h0 s1 N* ? } k! a2 a请问有没有什么好的解决方法! `9 h6 ]9 F9 |; @% f1 S' K' N# q
/ X! Q/ @9 P' t* \
4 y- d' [5 m0 z
& O* r" Z& K! X+ _# m |
|