QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1682|回复: 7
打印 上一主题 下一主题

求助!关于Matlab线性规划的问题。。。请大家帮帮忙,谢谢!

[复制链接]
字体大小: 正常 放大
JimOu        

1

主题

7

听众

118

积分

升级  9%

  • TA的每日心情
    开心
    2015-3-17 00:22
  • 签到天数: 30 天

    [LV.5]常住居民I

    自我介绍
    数模人
    跳转到指定楼层
    1#
    发表于 2013-1-22 23:09 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    5体力
                                    题目    max f=0.05x0+0.27x1+0.19x2+0.185x3+0.185x4
                                              st.  x0+1.01x1+1.02x2+1.045x3+1.065x4=1
                                                    0.025x1<=a
                                                    0.015x2<=a
                                                    0.055x3<=a
                                                    0.026x4<=a
                                                    x0,x1,x2,x3,x4>=0
                          a=0,从步长为0.001进行循环搜索,到a=0.05为止。
                         
    编程如下:
                         clc,clear a=0;
                         hold on
                         while a<0.05     
                             c=[-0.05,-0.27,-0.19,-0.185,-0.185];     
                             A=[zeros(4,1),diag([0.025,0.015,0.055,0.026])];     
                             b=a*ones(4,1);     
                             Aeq=[1,1.01,1.02,1.045,1.065];     
                             beq=1;     
                             LB=zeros(5,1);     
                             [x,Q]=linprog(c,A,b,Aeq,beq,LB);   
                             Q=-Q;     
                             plot(a,Q,'.r');   
                             a=a+0.001;
                         end
                             xlabel('a'),ylabel('Q')
    结果输出的图像为空白(就是图像是什么也没有),想问下大家这个编程代码哪里错了?
    图片:
                                 
                                     
                

    最佳答案

    新手ttt 查看完整内容

    你把clear后面加一个分号就可以了,你把a给clear了!!! clc,clear ;a=0; hold on while a
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    新手ttt        

    3

    主题

    7

    听众

    63

    积分

    升级  61.05%

  • TA的每日心情
    开心
    2013-2-1 20:05
  • 签到天数: 13 天

    [LV.3]偶尔看看II

    自我介绍
    擅长数学
    你把clear后面加一个分号就可以了,你把a给clear了!!!
    clc,clear ;a=0;
                         hold on
                         while a<0.05     
                             c=[-0.05,-0.27,-0.19,-0.185,-0.185];     
                             A=[zeros(4,1),diag([0.025,0.015,0.055,0.026])];     
                             b=a*ones(4,1);     
                             Aeq=[1,1.01,1.02,1.045,1.065];     
                             beq=1;     
                             LB=zeros(5,1);     
                             [x,Q]=linprog(c,A,b,Aeq,beq,LB);   
                             Q=-Q;     
                             plot(a,Q,'.r');   
                             a=a+0.001;
                         end
                             xlabel('a'),ylabel('Q')
    回复

    使用道具 举报

    JimOu        

    1

    主题

    7

    听众

    118

    积分

    升级  9%

  • TA的每日心情
    开心
    2015-3-17 00:22
  • 签到天数: 30 天

    [LV.5]常住居民I

    自我介绍
    数模人
    回复

    使用道具 举报

    JimOu        

    1

    主题

    7

    听众

    118

    积分

    升级  9%

  • TA的每日心情
    开心
    2015-3-17 00:22
  • 签到天数: 30 天

    [LV.5]常住居民I

    自我介绍
    数模人
    回复

    使用道具 举报

    新手ttt        

    3

    主题

    7

    听众

    63

    积分

    升级  61.05%

  • TA的每日心情
    开心
    2013-2-1 20:05
  • 签到天数: 13 天

    [LV.3]偶尔看看II

    自我介绍
    擅长数学
    你把clear后面加一个分号就可以了,你把a给clear了!!!
    clc,clear ;a=0;
                         hold on
                         while a<0.05     
                             c=[-0.05,-0.27,-0.19,-0.185,-0.185];     
                             A=[zeros(4,1),diag([0.025,0.015,0.055,0.026])];     
                             b=a*ones(4,1);     
                             Aeq=[1,1.01,1.02,1.045,1.065];     
                             beq=1;     
                             LB=zeros(5,1);     
                             [x,Q]=linprog(c,A,b,Aeq,beq,LB);   
                             Q=-Q;     
                             plot(a,Q,'.r');   
                             a=a+0.001;
                         end
                             xlabel('a'),ylabel('Q')

    点评

    JimOu  哎啊~太粗心了。。。  详情 回复 发表于 2013-1-25 09:52
    回复

    使用道具 举报

    新手ttt        

    3

    主题

    7

    听众

    63

    积分

    升级  61.05%

  • TA的每日心情
    开心
    2013-2-1 20:05
  • 签到天数: 13 天

    [LV.3]偶尔看看II

    自我介绍
    擅长数学
    回复

    使用道具 举报

    新手ttt        

    3

    主题

    7

    听众

    63

    积分

    升级  61.05%

  • TA的每日心情
    开心
    2013-2-1 20:05
  • 签到天数: 13 天

    [LV.3]偶尔看看II

    自我介绍
    擅长数学
    你把clear后面加一个分号就可以了,你把a给clear了!!! clc,clear ;a=0;                       hold on                       while a<0.05                               c=[-0.05,-0.27,-0.19,-0.185,-0.185];                               A=[zeros(4,1),diag([0.025,0.015,0.055,0.026])];                               b=a*ones(4,1);                               Aeq=[1,1.01,1.02,1.045,1.065];                               beq=1;                               LB=zeros(5,1);                               [x,Q]=linprog(c,A,b,Aeq,beq,LB);                              Q=-Q;                               plot(a,Q,'.r');                              a=a+0.001;                       end                          xlabel('a'),ylabel('Q')
    回复

    使用道具 举报

    JimOu        

    1

    主题

    7

    听众

    118

    积分

    升级  9%

  • TA的每日心情
    开心
    2015-3-17 00:22
  • 签到天数: 30 天

    [LV.5]常住居民I

    自我介绍
    数模人
    新手ttt 发表于 2013-1-24 11:21
    你把clear后面加一个分号就可以了,你把a给clear了!!!
    clc,clear ;a=0;
                         hold o ...

    哎啊~太粗心了。。。
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-5-25 18:48 , Processed in 0.754719 second(s), 91 queries .

    回顶部