预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共18页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

最优化问题的计算机求解 7.1无约束最优化问题求解 无约束最优化问题是最简单的一类最优化问题,其一般数学描述为 (7-1-1) 其中,称为优化变量,函数称为目标函数,该数学表示的含义亦即求取一组向量,使得最优化目标函数为最小,故这样的问题又称为最小化问题。其实,最小化是最优化问题的通用描述,它不失普遍性。如果要想解最大化问题,那么只需给目标函数乘一个负号就能立即将最大化问题转换成最小化问题。所以本书中描述的全部问题都是最小化问题。 解析解法和图解法 无约束最优化问题的最优点处,目标函数对各个分量的一阶导数为0,从而可以列出下面的方程: (7-1-2) 求解这些方程构成的联立方程可以得出极值点。其实,解出的一阶导数均为0的极值点不一定都是极小值的点,其中有的还可能是极大值点。极小值问题还应该有正的二阶导数。对于单变量的最优化问题可以考虑采用解析解的方法进行来解。然而多变量最优化问题因为需要将其转换成求解多元非线性方程,其难度也不低于直接采取最优化问题,所以没有必要采用解析解方法求解。 一元函数最优化问题的图解法也是很直观的,应绘制出该函数的曲线,在曲线上就能看出其最优值点。二元函数的最优化也可以通过图解法求出。但三元或多元函数,由于用图形没有办法表示,所以不适合用图解法来解。 【例7-1】函数,试用解析求解和图形求解的方法研究该函数的最优性。 【求解】可以先表示该函数,并解析地求解该函数的一阶导教,用ezplot()函数可以给制出区间内一阶导函数的曲线,如图7-1a所示。 >>symst;y=exp(-3*t)*sin(4*t+2)+4*exp(-0.5*t)*cos(2*t)-0.5; y1=diff(y,t); %求取一阶导数 ezplot(y1,[0,4]) 绘制出选定区间内一阶导函数的曲线 其实求解导数等于0的方程不比直接求解其最优值简单。用图解法可以看出,在这个区域内有两点:,使得它们的一阶导数为0,但从其一阶导数走向看,点对应负的二阶导数值,所以该点对应于极大值点,而点对应于正的二阶导数值,故为极小值点。点的值可以由下面的语句直接解出。 >>t0=solve(y1),ezplot(y,[0,4]) %求出一阶导数等于零的点 t0= >>y2=diff(y1);b=subs(y2,t,t0) %并验证二阶导数为正 b= 这样,就可以求出函数的最小值。还可以用图形绘制的方法进一步验证得出的结果.如图7-1b所示,可见,为最小值点,为最大值点。 然而因为给定的函数是非线性函数.所以用解析法或类似的方法求解最小值问题一点都不比直接求解最优化问题简单。因此.除演示之外,不建议用这样的方法求解该问题,而直接采用最优化问题求解程序得出问题的解。 图7-1联立方程图解法示意图 基于MATLAB的数值解法 MATLAB语言中提供了求解无约束最优化的函数fminsearch(),其最优化工具箱中还提供了函数fminunc(),二者的调用格式完全一致,为 x=fminunc(Fun,x0) 最简求解语句 [x,f,flag,out]=fminunc(Fun,x0,opt,p1,p2,……) 一般求解格式 opt为控制参数。该函数主要采用了单纯形算法。下面将通过例子来演示无约束最优化问题的数值解法。 【例7-2】已知二元函数,试用MATLAB提供的求解函数求出其最小值.并用图形方法表示其求解过程。 【求解】因为函数中给出的自变量是,而最优化函数需要求取的是自变量向量。故在求解前应该先进行变量替换,如令,这样就可以用下面的语句由inline()形式定义出目标函数f,然后将求解控制变量中的Display属性设置为‘iter’,这样可以显示中间的搜索结果。用下面的语句求解出最优解。 >>f=inline('(x(1)^2-2*x(1))*exp(-x(1)^2-x(2)^2-x(1)*x(2))','x'); x0=[0;0];ff=optimset;ff.Display='iter'; x=fminsearch(f,x0,ff) IterationFunc-countminf(x)Procedure 010 13-0.000499937initialsimplex 24-0.000499937reflect …… …… ……………… ………… 72137-0.641424contractoutside Optimizationterminated: thecurrentxsatisfiestheterminationcriteriausingOPTIONS.TolXof1.000000e-004 andF(X)satisfiestheconvergencecriteriausingOPTIONS.TolFunof1.00