24小时热门版块排行榜    

查看: 2582  |  回复: 8

fxlily2008

木虫 (小有名气)

[求助] 关于matlab的LMI求助

各位学长学姐,我从来没有用过matlab的LMI工具箱编写过程序,现在我想用它的mincx实现一个极简单的功能:
target:  min(0.1*x1+0.2*x2+0.3*x3+0.4*x4)
   s.t. :  x1,x2,x3,x4>=0
            x1+x2+x3+x4>10

我试着编了一个小程序,但是结果好像不对,请高手帮助一下吧,不胜感激,小弟在线等。

最好回复一个完整的程序吧,谢谢!!
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)

【答案】应助回帖


感谢参与,应助指数 +1
xiegangmai: 金币+1, 谢谢参与! 2013-05-26 12:36:34
你这个条件就有问题,没有解!
2楼2013-05-15 20:07:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

fxlily2008

木虫 (小有名气)

引用回帖:
2楼: Originally posted by lijie169 at 2013-05-15 20:07:30
你这个条件就有问题,没有解!

不是啊,虽然x1,x2,x3,x4可以无限大,但min(……)本身就是约束啊,理论上正确的结果应该是x1=10.0000001,x2=x3=x4=0对吧。但是用matlab的LMI怎么写程序啊,求帮助
3楼2013-05-15 21:09:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

fxlily2008

木虫 (小有名气)

另外,其中的等于号可以不考虑,没关系的
4楼2013-05-15 21:10:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

idnk

金虫 (小有名气)

★ ★
感谢参与,应助指数 +1
1592203609: 金币+2, 应助指数-1, 非应助帖不要选择应助 2013-05-15 23:00:23
把你程序贴出来,大家一起看看什么问题
5楼2013-05-15 22:36:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

elvinsu

金虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
fxlily2008: 金币+5, ★★★很有帮助 2013-05-18 14:45:27
xiegangmai: 金币+1, 谢谢参与! 2013-05-19 08:43:35
LMI是可以处理, 但是用线性规划不是更直接吗? x = linprog(f,A,b,Aeq,beq,lb,ub,x0,options)
科学的历程就是在假设求证中不断进步--巴瑞•马歇尔教授
6楼2013-05-18 11:56:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

fxlily2008

木虫 (小有名气)

引用回帖:
6楼: Originally posted by elvinsu at 2013-05-18 11:56:08
LMI是可以处理, 但是用线性规划不是更直接吗? x = linprog(f,A,b,Aeq,beq,lb,ub,x0,options)

哦,这样啊,这个函数我不熟,我先试试,谢谢前辈指导,我先给你5分吧
7楼2013-05-18 14:44:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

elvinsu

金虫 (小有名气)

引用回帖:
7楼: Originally posted by fxlily2008 at 2013-05-18 14:44:53
哦,这样啊,这个函数我不熟,我先试试,谢谢前辈指导,我先给你5分吧...

不敢当,谢谢加分!
科学的历程就是在假设求证中不断进步--巴瑞•马歇尔教授
8楼2013-05-19 21:00:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

EVRYIBISC

新虫 (初入文坛)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★
fxlily2008: 金币+5, ★★★很有帮助 2013-06-07 09:04:54
xiegangmai: 金币+2, 谢谢参与! 2013-06-07 20:36:25
clear all;
close all;
clc

setlmis([]);

x1 = lmivar(1,[1,1]);
x2 = lmivar(1,[1,1]);
x3 = lmivar(1,[1,1]);
x4 = lmivar(1,[1,1]);

br1 = newlmi;

lmiterm([-br1 1 1 x1],1,1);

br2 = newlmi;

lmiterm([-br2 1 1 x2],1,1);

br3 = newlmi;

lmiterm([-br3 1 1 x3],1,1);

br4 = newlmi;

lmiterm([-br4 1 1 x4],1,1);

br5 = newlmi;

lmiterm([-br5 1 1 x1],1,1);
lmiterm([-br5 1 1 x2],1,1);
lmiterm([-br5 1 1 x3],1,1);
lmiterm([-br5 1 1 x4],1,1);
lmiterm([br5 1 1 0],10);

lmisys = getlmis;

n = decnbr(lmisys);
c = zeros(n,1);
c(n,1)=1;

for jj = 1:n
    [x1j,x2j,x3j,x4j] = defcx(lmisys,jj,x1,x2,x3,x4);
    c(jj) = 0.1*x1j+0.2*x2j+0.3*x3j+0.4*x4j
end
%c = mat2dec(lmisys,zeros(2,2),zeros(1,2),1);

options = [1e-5,0,0,0,0];

[copt,xopt] = mincx(lmisys,c,options);

x1opt = dec2mat(lmisys,xopt,x1)
x2opt = dec2mat(lmisys,xopt,x2)
x3opt = dec2mat(lmisys,xopt,x3)
x4opt = dec2mat(lmisys,xopt,x4)

运行结果:
c =

    0.1000
         0
         0
    1.0000


c =

    0.1000
    0.2000
         0
    1.0000


c =

    0.1000
    0.2000
    0.3000
    1.0000


c =

    0.1000
    0.2000
    0.3000
    0.4000


Solver for linear objective minimization under LMI constraints

Iterations   :    Best objective value so far

     1                   1.734323
     2                   1.133169
***                 new lower bound:     0.563924
     3                   1.022152
***                 new lower bound:     0.834201
     4                   1.013815
***                 new lower bound:     0.977789
     5                   1.000993
***                 new lower bound:     0.997951
     6                   1.000010
***                 new lower bound:     0.998732
     7                   1.000010
***                 new lower bound:     0.999878
     8                   1.000001
***                 new lower bound:     0.999973
     9                   1.000001
***                 new lower bound:     0.999994

Result:  feasible solution of required accuracy
          best objective value:     1.000001
          guaranteed relative accuracy:  6.36e-06
          f-radius saturation:  0.000% of R =  1.00e+09


x1opt =

   10.0000


x2opt =

   1.2620e-06


x3opt =

   6.3082e-07


x4opt =

   4.2051e-07

>>
9楼2013-06-06 21:35:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 fxlily2008 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 070300化学319求调剂 +7 锦鲤0909 2026-03-17 7/350 2026-03-21 03:46 by JourneyLucky
[考研] 280求调剂 +7 咕噜晓晓 2026-03-18 8/400 2026-03-21 01:27 by JourneyLucky
[考研] 317求调剂 +8 申子申申 2026-03-19 13/650 2026-03-21 00:09 by 刘国森
[考研] 一志愿中海洋材料工程专硕330分求调剂 +8 小材化本科 2026-03-18 8/400 2026-03-20 23:16 by JourneyLucky
[考研] 324求调剂 +5 lucky呀呀呀鸭 2026-03-20 5/250 2026-03-20 22:30 by 促天成
[考研] 求调剂,一志愿:南京航空航天大学大学 ,080500材料科学与工程学硕,总分289分 +4 @taotao 2026-03-19 4/200 2026-03-20 22:14 by JourneyLucky
[考研] 329求调剂 +9 想上学吖吖 2026-03-19 9/450 2026-03-20 22:01 by luoyongfeng
[考研] 265求调剂 +12 梁梁校校 2026-03-19 13/650 2026-03-20 21:01 by 无际的草原
[考研] 一志愿 南京航空航天大学大学 ,080500材料科学与工程学硕 +5 @taotao 2026-03-20 5/250 2026-03-20 20:16 by JourneyLucky
[考研] 环境工程调剂 +9 大可digkids 2026-03-16 9/450 2026-03-20 17:38 by 醉在风里
[考研] 085410人工智能专硕317求调剂(0854都可以) +4 xbxudjdn 2026-03-18 4/200 2026-03-20 09:07 by 不168
[考研] 材料考研调剂 +3 xwt。 2026-03-19 3/150 2026-03-19 11:22 by w沐阳w
[考研] 344求调剂 +6 knight344 2026-03-16 7/350 2026-03-18 20:13 by walc
[考研] 311求调剂 +11 冬十三 2026-03-15 12/600 2026-03-18 14:36 by 星空星月
[考研] 收复试调剂生 +4 雨后秋荷 2026-03-18 4/200 2026-03-18 14:16 by elevennnne
[考博] 26博士申请 +3 1042136743 2026-03-17 3/150 2026-03-17 23:30 by 轻松不少随
[考研] 考研求调剂 +3 橘颂. 2026-03-17 4/200 2026-03-17 21:43 by 有只狸奴
[考研] 301求调剂 +4 A_JiXing 2026-03-16 4/200 2026-03-17 17:32 by ruiyingmiao
[考研] 080500,材料学硕302分求调剂学校 +4 初识可乐 2026-03-14 5/250 2026-03-14 21:08 by peike
[考研] 本科南京大学一志愿川大药学327 +3 麦田耕者 2026-03-14 3/150 2026-03-14 20:04 by 外星文明
信息提示
请填处理意见