收藏 分销(赏)

matlab5二次规划问题.doc

上传人:xrp****65 文档编号:5957342 上传时间:2024-11-24 格式:DOC 页数:5 大小:34.50KB
下载 相关 举报
matlab5二次规划问题.doc_第1页
第1页 / 共5页
matlab5二次规划问题.doc_第2页
第2页 / 共5页
点击查看更多>>
资源描述
二次规划的标准形式为: min    (1/2)X’HX+f’X 约束条件:Ax£b Aeqx=beq,lb£x£ub,其中:f、b、beq、lb、ub、x是矢量,H、 A、Aeq为矩阵。 在MATLAB中可以使用quadprog函数来求最小值。 调用格式: x=quadprog (H,f,A,b) x=quadprog (H,f,A,b,Aeq,beq) x=quadprog (H,f,A,b,Aeq,beq,lb,ub) x=quadprog (H,f,A,b,Aeq,beq,lb,ub,x0) x=quadprog (H,f,A,b,Aeq,beq,lb,ub,x0,options) x=quadprog (H,f,A,b,Aeq,beq,lb,ub,x0,options,P1,P2,…) [x,fval]= quadprog (…) [x,fval,exitflag]= quadprog (…) [x,fval,exitflag,output]= quadprog (…) [x,fval,exitflag,output,lambda]= quadprog (…) fval为目标函数的最优值;其中:H,f,A,b为标准形中的参数,x为目标函数的最小值;x0为初值;Aeq,beq满足等式约束Aeq.x=beq;lb,ub满足lb lambda是Lagrange乘数,它体现有效约束的个数;output输出优化信息;exitflag为终止迭代的条件:若exitflag>0,表示函数收敛于解x;若exitflag=0,表示超过函数估值或迭代的最大次数;exitflag<0表示函数不收敛于解x;output为优化信息:若参数output=iterations表示迭代次数,output=funccount表示函数赋值次数,output=algorithm表示所使用的算法。 例0-6 计算下面二次规划问题 minf(x)= (1/2)x1^2+x2^2- x1x2-2x1-6x2 约束条件: x1+x2£2 -x1+x2£2, 2x1+x2£3; x1£0; x2£0 解:把二次规划问题写成标准形式:(1/2)XTHX+fTX 这里:H=  1  -1     f=   -2       X=  x1          -1   2          -6           x2 在命令窗口键入命令: >>H=[1 –1;-1 2]; >>f=[-2;-6]; >>A=[1 1;-1 2;2 1]; >>b=[2;2;3]; >>lb=[zeros(2,1)]; >>[x,fval,exitflag,output,lambda]=quadprog(H,f,A,b,[],[],lb) 运行以上命令得到的显示结果如下: x=                          %最优值点 §3 二次规划模型 数学模型: 其中H为二次型矩阵,A、Aeq分别为不等式约束与等式约束系数矩阵,f,b,beq,lb,ub,x为向量。 求解二次规划问题函数为quadprog( ) 调用格式: X= quadprog(H,f,A,b) X= quadprog(H,f,A,b,Aeq,beq) X= quadprog(H,f,A,b,Aeq,beq,lb,ub) X= quadprog(H,f,A,b,Aeq,beq,lb,ub,x0) X= quadprog(H,f,A,b,Aeq,beq,lb,ub,x0,options) [x,fval]= quadprog(…) [x,fval,exitflag]= quadprog(…) [x,fval,exitflag,output]= quadprog(…) [x,fval,exitflag,output,lambda]= quadprog(…) 说明:输入参数中,x0为初始点;若无等式约束或无不等式约束,就将相应的矩阵和向量设置为空;options为指定优化参数。输出参数中,x是返回最优解;fval是返回解所对应的目标函数值;exitflag是描述搜索是否收敛;output是返回包含优化信息的结构。Lambda是返回解x入包含拉格朗日乘子的参数。 例1:求解:二次规划问题 min f(x)= x1-3x2+3x12+4x22-2x1x2 s.t 2x1+x2≤2 -x1+4x2≤3 程序: f=[1;-3] H=[6 -2;-2 8] A=[2 1;-1 4] b=[2;3] [X,fval,exitflag]=quadprog(H,f,A,b) 结果: X = -0.0455 0.3636 fval = -0.5682 exitflag = 1 例2:求解:二次规划问题 min +x12+2x22-2x1x2-4x1-12x2 s.t x1+x2≤2 -x1+2x2≤2 2x1+x2≤3 0≤x1, 0≤x2 程序: H=[2 -2;-2 4]; f=[-4;-12]; A=[1 1;-1 2;2 1]; b=[2;2;3]; lb=zeros(2,1); [x,fval,exitflag]=quadprog(H,f,A,b,[],[],lb) 结果: x = 0.6667 1.3333 fval = -16.4444 exitflag = 1
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传
相似文档                                   自信AI助手自信AI助手

当前位置:首页 > 环境建筑 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服