• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Matlab有约束的非线性规划的求解

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

标准形式:

\[min\quad f(x)\\ s.t.\begin{cases} G_1(x)\leq 0,G_2(x)=0\quad (非线性约束)\\ AX\leq b,Aeq\cdot X=beq\quad (线性约束)\\ vlb\leq X\leq vub\quad (决策变量的范围约束)\\ \end{cases} \]

调用 fmincon() 函数:

[x,favl]=fmincon(@fun,x0,A,b,Aeq,beq,vlb,vub,@con)

求解流程:

例:

\[max\quad f(x)=x_1^2+x^2_2-x_1x_2-2x_1-5x_2\\ s.t.\begin{cases} -(x_1-1)^2+x_2\geq 0\\ 2x_1-3x_2+6\geq 0\\ 初始值:x_1=0,x_2=1 \end{cases} \]

转化为标准形式:

\[min\quad f(x)=-x_1^2-x^2_2+x_1x_2+2x_1+5x_2\\ s.t.\begin{cases} (x_1-1)^2-x_2\leq 0\\ -2x_1+3x_2-6\leq 0\\ 初始值:x_1=0,x_2=1 \end{cases} \]

①:

function f=fun(x)
f=-x(1)^2-x(2)^2+x(1)*x(2)+2*x(1)+5*x(2);
end

function [G,Geq]=cont(x)
G=(x(1)-1)^2-x(2);
Geq=[];
end

x0=[0 1];
A=[-2,3];
b=6;
Aeq=[];
beq=[];
lb=[];
ub=[];
[x,favl]=fmincon(@fun,x0,A,b,Aeq,beq,lb,ub,@cont)

运行结果可知,最大值为-1:

x =

    1.0000    0.0000


favl =

    1.0000

>> 

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
初学delphi发布时间:2022-07-18
下一篇:
Delphi中的XMLDocument类详解(5)-获取元素内容发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap