|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
自定义的函数:
! S( t& |. G) I/ r# C, Yfunction f=largejfun(x)
4 G5 X" [0 y2 Z, o4 q# _7 M, Q/ \f=(x-1./1:100).^2;. b0 t* e4 M# Z
end
# u3 N4 Y) L6 a% a8 E0 {
# l& C3 @- T" J2 d调用函数的时候:& [4 v- O* M/ Y' t
clc
8 T' ~, @, J2 }' I) z# A7 Q3 Xx0=10*ones(1,100);
/ \3 }+ E* p+ v' ~1 P; t* {- |options=optimset('display','iter','TolFun',1e-8);! s: y6 h* y" r3 O4 |. o
[x,fval,exitflag,output]=fminunc(@largejfun,x0,options)
: G$ |2 [9 ^; ]# }2 `" |
4 e1 d) q/ v8 v5 A1 F A
8 e7 C% d; Z2 X% m5 A9 A运行结果出错,出错结果显示如下:
1 Z; x7 O- G, Y8 l, M! r6 D错误使用 fminunc (line 348)
& x* Q8 f1 ?2 s) F( ~" H: f( }8 c1 r. ESupplied objective function must return a scalar value.# r1 a' D/ @4 F$ g7 ?
" n+ B, A% V# R! R5 i# Z, O
4 @' F: x2 `$ G# A* A$ m
出错 fminu1 (line 4)5 K3 P8 G& N" z) B G
[x,fval,exitflag,output]=fminunc(@largejfun,x0,options)( K" l' e* Z, A" C# e+ M
9 z0 n- y. H8 [: U8 T" ~
. B, z, G: r3 ^/ l% d; a- l( s+ j- _) R) _* [7 S5 m) j
# j' m6 Q2 ^3 \# W: b/ s) @. ~1 x( F% e
0 X8 ?0 X! \5 ]0 h- M& R5 g
' k3 T: r+ R: e& F- [& i; I2 T$ ~; w* S9 [1 a: l j/ v) ]& ~+ c
我将自定义函数改为如下:
9 c" o1 k+ ?. T: W5 m1 [9 Y( _function f=largejfun(x)7 ]4 f: P ]! M1 ^4 a! a
f=0;4 y6 [, ^& N( `* ?: N e6 s
for i=1:100
/ {, r7 }& _! Z ^: ]6 J f=f+(x(i)-1/i)^2;! ?5 I! h/ y) C6 O" j, I
end- A1 _4 q/ q* ~3 m, Y$ N& ]
; i$ `$ C+ E; D& t( _5 v0 Z0 a
最后运行结果没有任何问题。$ u; q) U- r. C7 w- U4 {
那是哪里有问题呢?1 ^5 X$ A' f0 B' d
|
|