来知道电脑站

您的位置: 主页>软件> 怎样用MATLAB求解非线性规划?

怎样用MATLAB求解非线性规划?

 飞 

怎样用MATLAB求解非线性规划?


解决方法



(一)非线性一元函数的最小值

Matlab函数为fminbnd(),其使用格式为:

X=fminbnd(fun,x1,x2)

[X,fval,exitflag,output]= fminbnd(fun,x1,x2)

其中:fun为目标函数,x1,x2为变量的边界约束,即x1≤x≤x2,X为返回的满足fun取得最小值的x的值,而fval则为此时的目标函数值。exitflag>0表示计算收敛,exitflag=0表示超过了最大的迭代次数,exitflag<0表示计算不收敛,返回值output有3个分量,其中iterations是优化过程中迭代次数,funcCount是代入函数值的次数,algorithm是优化所采用的算法。

例1:求函数 在区间 的最小值和相应的 值。

解决此问题的Matlab程序为:

clear

fun='(x^5 x^3 x^2-1)/(exp(x^2) sin(-x))'

ezplot(fun,[-2,2])

[X,fval,exitflag,output]= fminbnd(fun,-2,2)

结果为:

X = 0.2176

fval =-1.1312

exitflag = 1

output = iterations: 13

funcCount: 13

algorithm: 'golden section search, parabolic interpolation'

(二)无约束非线性多变量优化问题

这里我们介绍两个命令:fminsearch()和fminunc(),前者适合处理阶次低但是间断点多的函数,后者则对于高阶连续的函数比较有效。

命令fminsearch()的格式为:

X= fminsearch(fun,X0)

[X,fval,exitflag,output]= fminsearch(fun,X0,options)

该命令求解目标函数fun的最小值和相应的x值,X0为x的初始值,fval为返回的函数值,exitflag=1表示优化结果收敛,exitflag=0表示超过了最大迭代次数。返回值output有3个分量,其中iterations是优化过程中的迭代次数,funcCount是代入函数值的次数,algorithm是优化所采用的算法。options是一个结构,里面有控制优化过程的各种参数,参考optimset()命令来设置,一般情况下我们不必改动它,即使用缺省设置就可以了。

例2:求函数 的最小值以及最小值点。

完成该计算的Matlab程序如下:

clear

fun1='sin(x) cos(y)'

fun2='sin(x(1)) cos(x(2))'

ezmesh(fun1)

[X,fval]=fminsearch(fun2,[0,0])

X = -1.5708 3.1416

fval = -2.0000

其中语句ezmesh()是为了画出函数的图形,注意这里fun1和fun2的不同,考虑如果用相同的是否可行。

命令fminunc()的格式为:

X=fminunc(fun,X0)

[X,fval,exitflag,output,grad,hessian]=fminunc(fun,X0,options)

命令fminunc()通过计算寻找多变量目标函数fun的最小值,X0为优化的初始值,X为返回的变量的值,grad返回解点的梯度,hessian返回解点的汉森矩阵。其它参数的意义和命令fminsearch()相同。

例3:求函数 的最小值。

解:Matlab程序为

clear

fun='exp(x(1))*(2*x(1)^2 3*x(2)^2 2*x(1)*x(2) 3*x(2) 1)';

x0=[0,0];

options=optimset('largescale','off','display','iter','tolx',1e-8,'tolfun',1e-8);

[x,fval,exitflag,output,grad,hessian]=fminunc(fun,x0,options)

运行结果为:

Iteration
Func-count

共2页: 上一页 1 [2] 下一页

上一篇:photoshop cs3可以做到动画合成吗?    下一篇:没有了

软件相关文章

软件热门文章

软件推荐文章