




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、函数的极值与优化2MATLAB在优化中的应用在优化中的应用 在研究与解决具体问题中,经常遇到有关优化问在研究与解决具体问题中,经常遇到有关优化问题,它起源于工业生产组织管理的题,它起源于工业生产组织管理的决策问题决策问题。本节的。本节的目的是学会用目的是学会用MATLAB软件求解一些优化问题,包软件求解一些优化问题,包括求解括求解线性规划和非线性规划线性规划和非线性规划问题。问题。 1、线性规划求解、线性规划求解多变量线性函数多变量线性函数在变量满足在变量满足线性约束线性约束条件下的条件下的最优最优值值。随着计算机的发展,出现了如单纯形法等有效。随着计算机的发展,出现了如单纯形法等有效算法,它
2、在工农业、军事、交通运输、决策管理与算法,它在工农业、军事、交通运输、决策管理与规划等领域中有广泛的应用。规划等领域中有广泛的应用。3某厂每日某厂每日8小时的产量不低于小时的产量不低于1800件。为了进行质量控制,计件。为了进行质量控制,计划聘请两种不同水平的检验员。一级检验员的标准为:速度划聘请两种不同水平的检验员。一级检验员的标准为:速度25件件/小时,正确率小时,正确率98%,计时工资,计时工资4元元/小时;二级检验员的小时;二级检验员的标准为:速度标准为:速度15件件/小时,正确率小时,正确率95%,计时工资,计时工资3元元/小时。小时。检验员每错检一次,工厂要损失检验员每错检一次,工
3、厂要损失2元。为使总费用最省,该工元。为使总费用最省,该工厂应聘一级、二级检验员各几名?厂应聘一级、二级检验员各几名?12128 48 33224xxxx 解解 设需要一级和二级检验员的人数分别为设需要一级和二级检验员的人数分别为x1x1、x2x2人人, , 则应付则应付检验员的工资检验员的工资为:为:因因检验员错检而造成的损失检验员错检而造成的损失为:为:1212(8 25 2%8 15 5%) 2812xxxx 121212min(3224)(812)4036zxxxxxx故故目标函数目标函数为:为:例例14约束条件为:约束条件为:线性规划模型:线性规划模型:121212min403653
4、45. .0,0zxxxxs txx 12128 258 1518000,0 xxxx 5一般线性规划问题的数学表达式:一般线性规划问题的数学表达式: max(min) f =nnxcxcxc2211s.t .11212111),(bxaxaxann22222121),(bxaxaxann mnmnmmbxaxaxa),(2211 0,21nxxx.用矩阵向量符号表示:用矩阵向量符号表示: max(min)f=cX.( , )stAXb 0X 6MATLAB优化工具箱解线性规划优化工具箱解线性规划1. 模型:模型: min z=cTX s.t AXb 命令:命令:x=linprog(c,A,b
5、) 2. 模型:模型: min z=cTX s.t AXb Aeq X=beq 命令:命令:x=linprog(c,A,b,Aeq,beq)如果没有不等式:如果没有不等式:AXb不存在,则令不存在,则令A=,b=.7 命令:命令:x=linprog(c,A,b,Aeq,beq,vlb,vub)如果没有等式约束如果没有等式约束存在,存在, 则令则令Aeq=,beq=.4. 命令:命令:x=linprog(c,A,b,Aeq,beq,vlb,vub,x0)也用于求模型也用于求模型3,其中,其中x0表示初始值。表示初始值。5. 命令:命令:x,fval=linprog()返回最优解及处的目标函数值返
6、回最优解及处的目标函数值fval. 3. 模型:模型: min z=cTX s.t AXb Aeq X=beq vlb x vub 8解解 编写编写M文件文件xxgh1.m如下:如下:c =-0.4;-0.28;-0.32;-0.72;-0.64;-0.6;A=0.01 0.01 0.01 0.03 0.03 0.03; 0.02 0 0 0.05 0 0;0 0.02 0 0 0.05 0; 0 0 0.03 0 0 0.08;b=850;700;100;900;Aeq=; beq=; vlb=0;0;0;0;0;0; vub=;x,fval=linprog(c,A,b,Aeq,beq,vl
7、b,vub)9例例 用用MATLAB求解例求解例1:编写编写M文件文件xxgh2.m如下:如下:c = 40;36;A = -5 -3;b = -45;Aeq = ; beq = ;vlb = 0;0; vub = ; x,fval = linprog(c,A,b,Aeq,beq,vlb,vub)121212min40365345. .0,0zxxxxs txx 10结果为:结果为:x = 9.0000 0.0000fval =360即只需聘用即只需聘用9个一级检验员。个一级检验员。 注:本问题应还有一个约束条件:注:本问题应还有一个约束条件:x1、x2取整数取整数。故它是。故它是一个一个整数
8、线性规划问题整数线性规划问题。这里把它当成一个线性规划来解,。这里把它当成一个线性规划来解,求得其最优解刚好是整数:求得其最优解刚好是整数:x1=9,x2=0,故它就是该整数,故它就是该整数规划的最优解。规划的最优解。若用线性规划解法求得的最优解不是整数,若用线性规划解法求得的最优解不是整数,将其取整后不一定是相应整数规划的最优解将其取整后不一定是相应整数规划的最优解,这样的整数,这样的整数规划应用专门的方法求解。规划应用专门的方法求解。Matlab中,求一元函数极值的函数为中,求一元函数极值的函数为 fminbnd l此函数最简输入格式为:此函数最简输入格式为:x=fminbnd(f,a,b
9、)含义为:含义为:求函数求函数f在区间在区间a,b上的极小值点上的极小值点(自变量值自变量值).2. 非线性优化问题的求法非线性优化问题的求法n 非线性一元函数极值的求法非线性一元函数极值的求法l常用格式如下:常用格式如下:(1)x= fminbnd(fun,x1,x2)(2)x= fminbnd(fun,x1,x2,options)(3)x,fval= fminbnd(.)(4)x,fval,exitflag= fminbnd(.)n 非线性优化问题指的是目标函数或者约束函非线性优化问题指的是目标函数或者约束函数中至少有一个非线性函数的优化问题数中至少有一个非线性函数的优化问题非线性函数极值
10、的求法非线性函数极值的求法l函数函数fminbnd的算法要求目标函数必须是连续函的算法要求目标函数必须是连续函数,并可能只给出局部最优解。数,并可能只给出局部最优解。l对于对于极大值问题极大值问题,需,需转化为极小值问题转化为极小值问题来处理。来处理。 ( -f(x)在区间在区间a,b上取极小值的点就是上取极小值的点就是f(x)在在a,b上取极大值的点)上取极大值的点) 运行结果:运行结果: xmin = 3.9270 ymin = -0.0279 xmax = 0.7854 y = -0.6448 ymax = -y 解解 在在matlab命令窗口中输入:命令窗口中输入: f=2*exp(-
11、x)*sin(x); ezplot(f,0,8);%作图语句作图语句 xmin,ymin=fminbnd(f,0,8) f1=-2*exp(-x)*sin(x); xmax,y=fminbnd(f1,0,8)非线性函数极值的求法非线性函数极值的求法 多元函数的无约束极小值问题,在多元函数的无约束极小值问题,在Matlab中有中有2个经常使用的函数:个经常使用的函数: 1、fminsearch 2、fminunc 注意注意: (1)在使用这两个函数时,必须首先用)在使用这两个函数时,必须首先用M文件文件的形式存储待求最值的函数,该函数需以向量函数的形式存储待求最值的函数,该函数需以向量函数的形式
12、表达;的形式表达; ( 2)极大值问题需转化为极小值问题。)极大值问题需转化为极小值问题。n多元函数极值的求法多元函数极值的求法非线性函数极值的求法非线性函数极值的求法u使用格式:使用格式:x,fval,exitflag,output=fminsearch(f,x0)u输入参数:输入参数:f: 目标函数;目标函数;x0: 初始点初始点(向量向量).u输出参数:输出参数:x: 最优解;最优解;fval: 最优解对应的函数值;最优解对应的函数值;exitflag: 函数退出优化运算的原因:函数退出优化运算的原因:1,收敛于最优解;收敛于最优解;0,迭迭代次数超过优化属性设置;代次数超过优化属性设置
13、;-1,迭代算法被迭代算法被output函数终止;函数终止;output:有关优化的属性信息,如优化迭代次数和优化算法有关优化的属性信息,如优化迭代次数和优化算法等等.例:例:fminsearch(f,1,2) 含义为:从点含义为:从点1,2开始开始 搜寻函数搜寻函数f 的最小值。的最小值。 n fminsearch 非线性规划的单纯型法搜索最值非线性规划的单纯型法搜索最值非线性无约束优化问题非线性无约束优化问题例:求函数例:求函数 在在x=1,y=2附近的最附近的最小值点。小值点。解决步骤:解决步骤:1、建立、建立M文件,保存函数文件,保存函数f; M文件内容为:文件内容为: functio
14、n f2=fun2(x) f2=-(x(1)+x(2)+(x(1)2+x(2)2+1); 2、调用、调用fminsearch函数求最值函数求最值. 在命令窗口中,输入:在命令窗口中,输入: x0=1,2; x,fval=fminsearch(fun2,x0) 3、输出结果为:、输出结果为: x = 0.5000 0.5000 fval =0.5000非线性无约束优化问题非线性无约束优化问题22()(1)fxyxy u 此函数与此函数与fminsearch不同的地方在于使用的搜索方法,不同的地方在于使用的搜索方法,它使用它使用牛顿法(拟牛顿)牛顿法(拟牛顿)搜索最值,在搜索最值,在效率上有所提高
15、效率上有所提高;u 使用格式与使用格式与fminsearch类似:类似: x,fval= fminunc(f,x0) 其中其中f为待求极值的向量函数,为待求极值的向量函数,x0为搜索过程开始时自为搜索过程开始时自变量的初始值。变量的初始值。例例:fminunc(f,1,2)含义为:从点含义为:从点1,2开始开始搜寻函搜寻函数数f的极小值。的极小值。 n fminunc非线性无约束优化问题非线性无约束优化问题n 例例 求解二元函数求解二元函数 的最小值的最小值.n 输入目标函数的程序代码:输入目标函数的程序代码: function f=optfun(x) f=3*x(1)2+2*x(1)*x(2
16、)+x(2)2;将上述代码保存为将上述代码保存为 optfun.m 文件。文件。n x,fval=fminunc(optfun,x0)或或 x1,fval1=fminsearch(optfun,x0)221122( )32f xxx xx非线性无约束优化问题非线性无约束优化问题n Matlab默认的二次规划默认的二次规划n 用用MATLAB软件求解软件求解,其输入格式如下其输入格式如下:x,fval=quadprog(H,c,A,b);x,fval=quadprog(H,c,A,b,Aeq,beq);x,fval=quadprog(H,c,A,b,Aeq,beq,LB,UB); x,fval=
17、quadprog(H,c,A,b,Aeq,beq,LB,UB,X0); 1min( ),2. .,.TTf xx Hxc xs t A xbAeq xbeqlbxub 二次规划问题二次规划问题20例例 写成标准形式:写成标准形式:1212 1 12.1 2200 xstxxx 2212121122121212min(,)2622.2220,0f xxxxxx xxs txxxxxx 212121624222),(21minxxxxxxzT二次规划问题二次规划问题21H=2 -2; -2 4; c=-2 ;-6;A=1 1; -1 2;b=2;2;Aeq=;beq=; VLB=0;0;VUB=;
18、x,z=quadprog(H,c,A,b,Aeq,beq,VLB,VUB) 运算结果为:运算结果为:x = 0.8000 1.2000z = -7.2000 输入命令:输入命令:二次规划问题二次规划问题n求解约束非线性优化问题求解约束非线性优化问题n Matlab 求解约束非线性优化问题求解约束非线性优化问题 fminconn 常用调用格式如下:常用调用格式如下:nx,fval = fmincon(fun,x0,A,b,Ae,be,lb,ub,nonlcon)min( ),. .( )0,( )0,.f xs t c xce xA xbAe xbelbxub 约束非线性优化问题约束非线性优化问
19、题nx,fval = fmincon(fun,x0,A,b,Ae,be,lb,ub,nonlcon)n输入参数:输入参数:ufun 表示优化目标函数,表示优化目标函数,x0 表示优化的初始值表示优化的初始值uA,b 表示满足线性关系式表示满足线性关系式 的系数矩阵和右端项的系数矩阵和右端项uAe,be 表示线性等式约束表示线性等式约束 的系数矩阵和右端项的系数矩阵和右端项ulb,ub 表示取值范围表示取值范围 的上限和下限的上限和下限unonlcon 表示需要参数满足的非线性关系式表示需要参数满足的非线性关系式 和和 Axb Ae xbelbxub ( )0c x ( )0ce x 24例例
20、1221212212121212min( )(42421)0.1.50100 xf xexxx xxxxstx xxxx x1) 先建立先建立 M 文件文件 fun3.m, 定义目标函数定义目标函数: function f=fun3(x); f=exp(x(1)*(4*x(1)2+2*x(2)2+4*x(1)*x(2)+2*x(2)+1); 2) 再建立再建立 M 文件文件 myc.m 定义非线性约束:定义非线性约束: function c,ceq=myc(x) c= 1.5+x(1)*x(2)-x(1)-x(2);-x(1)*x(2)-10; ceq=;253) 主程序主程序youh.m为为
21、: x0=-1;1; A=;b=; Aeq=1 1;beq=0; vlb=;vub=; x,fval=fmincon(fun3,x0,A,b,Aeq,beq,vlb,vub,myc)3. 运算结果为:运算结果为: x = -1.2247 1.2247 fval = 1.8951上机作业上机作业n1.求解如下问题求解如下问题 n2.求函数求函数 在区间在区间-10,10内的极大极内的极大极小值点小值点. n3.求函数求函数 在区间在区间-10,10内的极小值内的极小值点,并通过该函数的图象体会局部极小值的含义点,并通过该函数的图象体会局部极小值的含义.12121212min( )612. .37
22、34,0f xxxs txxxxxx 2( )32f xxx 2( )sin( )f xxx n4.求解求解n5.求解二次规划问题求解二次规划问题上机作业上机作业12212122min( )(42421)xf xxxx xxe 22121212121212121min( )262. .2,22,23,0,0.f xxxx xxxs t xxxxxxxx n6.求解求解初始点为初始点为10,10,10上机实验上机实验123123min( ). . 02372f xx x xs txxx 选学内容选学内容 例:供应与选址例:供应与选址某公司有某公司有6 6个建筑工地,位置坐标为个建筑工地,位置坐标
23、为(a(ai i, b, bi i) () (单位:公单位:公里里),),水泥日用量水泥日用量d di i ( (单位:吨)单位:吨)ia1.258.750.55.7537.25b1.250.754.7556.57.75d3547611假设:假设:料场和工地之间有直线道路料场和工地之间有直线道路2 , 1, 6,.,1, 02 , 1,6,.,1,. .)()(min612121612/122jicjecidctsbyaxcijjijiiijjjiijijij线性规划模型线性规划模型决策变量:决策变量:ci j 12维维(料场料场j到到工地工地i运量)运量)例:供应与选址例:供应与选址用例中数用例中数据计算,据计算,xuanzhi.m最优解为最优解为i1234561ic(料料场场 A)3507012ic(料料场场 B)0040610总吨公里数为总吨公里数为136.22622 1/2112161min()() . .,1,.,6,1,2,1,.,6,1,20ijjijijiijijijjiijcxaybs tcdicejcij线性规划模型线性规划模型决策变量:
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度企业间合同终止协议书及后续处理方案
- 2025年度艺术品租赁合同到期退还及保值增值服务通知书
- 实习律师实习合同及实习协议8篇
- 两位数加两位数计算自我检测练习题带答案
- 美容师中级模考试题(含答案)
- 2025年大型娱乐设施服务项目发展计划
- Unit3 presenting ideas 教学设计 -2024-2025学年外研版英语七年级下册
- 哈密风电基地二期三塘湖第一风电场b区200mw项目环境影响报告书
- 烹饪原料知识测试题(含参考答案)
- 核工业试试题库+参考答案
- 中国纺织服装制造业年度授信政策指引研究报告
- 零基础学机器学习
- 西方绘画艺术流派(最全)课件
- 预防保健科护理管理质量控制考核标准
- JCT548-2016 壁纸胶粘剂标准
- 皮下抗凝剂的注射规范
- 食管癌护理小讲课课件
- 护理组长竞聘讲稿-护理组长竞聘主题教学课件
- 2023北京市高级中等学校招生考试英语答题卡A4版word版可以编辑
- 水泥考试试题(含答案)
- 北师大版七年级(下)数学全册教案
评论
0/150
提交评论