MATLAB求解带绝对值的规划问题

对于带有绝对值的非线性规划问题,尽量进行手工线性化再根据线性规划的方法去做。

例如:

对于 ∣ x i ∣ \vert x_i \vert ∣xi∣,我们无法运用正常的线性规划方式进行求解,因此我们可以进行变量变换,将模型转换为线性规划模型。

我们可以用两个线性规划变量来表示,令 u i = x i + ∣ x i ∣ 2 , v i = ∣ x i ∣ − x i 2 , i = 1 , 2 , 3 , 4 u_i= \dfrac {x_i+\vert x_i \vert} 2,v_i=\dfrac {\vert x_i \vert-x_i} 2,i=1,2,3,4 ui=2xi+∣xi∣,vi=2∣xi∣−xi,i=1,2,3,4

令 u u u= [ u 1 , u 2 , u 3 , u 4 ] T , v = [ v 1 , v 2 , v 3 , v 4 ] T [u_1,u_2,u_3,u_4]^T,v=[v_1,v_2,v_3,v_4]^T [u1,u2,u3,u4]T,v=[v1,v2,v3,v4]T

则转换成的线性规划模型为:
m i n min min c T ( u + v ) c^T(u+v) cT(u+v)
s t st st { A ( u − v ) ≤ b u , v ≥ 0 \left\{ \begin{matrix} A(u-v)\leq b \\ u,v\geq0 \end{matrix} \right. {A(u−v)≤bu,v≥0

所以我们在线性规划方程中添加一个变量就可以了。

matlab 复制代码
c=[1,2,3,4];b=[-2;-1;-1/2];
a=[1,-1,-1,1;1,-1,1,-3;1,-1,-2,3];
prob=optimproblem('ObjectiveSense','min');//目标函数最小化,也可以写成prob=optimproblem;
u=optimvar('u',4,'LowerBound',0)//决策变量
v=optimvar('v',4,'LowerBound',0)//决策变量
prob.Objective=sum(c*(u+v))//目标函数
prob.Constraints.con=a*(u-v)<=b//约束条件
[sol,fval,flag,out]=solve(prob)//fval返回了最优值
x=sol.u-sol.v//求出xi的值

结果为

则最优解为 x 1 = − 2 , x 2 = x 3 = x 4 = 0 x_1=-2,x_2=x_3=x_4=0 x1=−2,x2=x3=x4=0.

最优值 f v a l = 2 fval=2 fval=2.

相关推荐
神的孩子都在歌唱几秒前
Java 和 J2EE 有什么不同?
java·开发语言·java-ee
大梦百万秋7 分钟前
C++中的虚拟化:通过虚拟机管理模拟服务器虚拟化
服务器·开发语言·c++
shentuyu木木木(森)11 分钟前
入门STL(map/multiset)
开发语言·数据结构·c++·算法·map·multiset
超级大咸鱼18 分钟前
CW信号的正交解调
matlab·verilog·fpga·数字信号·解调·正交解调·cw
向宇it23 分钟前
【从零开始入门unity游戏开发之——C#篇23】C#面向对象继承——`as`类型转化和`is`类型检查、向上转型和向下转型、里氏替换原则(LSP)
java·开发语言·unity·c#·游戏引擎·里氏替换原则
火³可²25 分钟前
PHP接入美团联盟推广
开发语言·php
Linux运维技术栈36 分钟前
Python字符串及正则表达式(十一):正则表达式、使用re模块实现正则表达式操作
开发语言·python·正则表达式
jackiendsc36 分钟前
Java中正则表达式的介绍、使用场景及示例代码
java·开发语言·正则表达式
疯狂的沙粒41 分钟前
前端开发 详解 Node. js 都有哪些全局对象?
开发语言·javascript
m0_748256561 小时前
如何使用Python WebDriver爬取ChatGPT内容(完整教程)
开发语言·python·chatgpt