QQ登录

只需要一步,快速开始

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

选址问题代码求纠错

[复制链接]
字体大小: 正常 放大
盐田港        

1

主题

11

听众

22

积分

升级  17.89%

  • TA的每日心情
    慵懒
    2017-6-6 17:55
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    邮箱绑定达人 新人进步奖

    跳转到指定楼层
    1#
    发表于 2014-12-29 14:14 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    12体力
    Min Z=∑∑CijXij
    St
    6
    ∑Xjj=2................................(1)
    J=1

    6
    ∑Xij=1,1<i<6......................(2)
    J=1

    Xjj-Xij≥0,对于1<i,j<6且i≠j.............(3)

    X为0/1变量......................................(4)

    model:
    sets:
    ZD/1..6/;
    links(ZD,ZD):c,x;
    endsets
    data:
    c=
    0        6        6        78        3        6       
    1        0        4        5        4        6       
    2        1        0        6        2        9       
    3        2        1        0        3        9       
    4        3        2        7        0        9       
    5        4        3        5        6        0       
    ;
    enddata
    min=@sum(links(i,j):c(i,j)*x(i,j)); !Objective Function;
    st
    @for(@sum(ZD(j):x(j,j))=2);
    @for(ZD(i)sum(ZD(j):x(i,j))=1);
    @for(ZD(i,j):i#ne#j:x(j,j)-x(i,j)>=0);
    @for(linksbin(x)); !Restrict x to be 0-1;
    end

    最佳答案

    liwenhui 查看完整内容

    你的约束条件部分似乎有歧义,不能很好地理解你的意思。按照你贴出来的模型,猜想你想实现的: 约束条件1:表示矩阵X的对角线之和(即方阵的迹)为2; 约束条件2:表示矩阵X每行有且只有1个值为1. 约束条件3:表示矩阵x每行上面对角线元素减去非对角线元素的差必须大于等于0. 由此得到的程序是:这个LINGO运行下来没有可行解。这是很显然的。因为约束条件1,2,3之间似乎存在矛盾,无法同时满足,你可以自己推敲一下。
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    liwenhui        

    70

    主题

    65

    听众

    5192

    积分

    独孤求败

  • TA的每日心情
    擦汗
    2018-4-26 23:29
  • 签到天数: 1502 天

    [LV.Master]伴坛终老

    自我介绍
    紫薇软剑,三十岁前所用,误伤义士不祥,乃弃之深谷。 重剑无锋,大巧不工。四十岁前恃之横行天下。 四十岁后,不滞于物,草木竹石均可为剑。自此精修,渐进至无剑胜有剑之境。

    社区QQ达人 邮箱绑定达人 发帖功臣 元老勋章 新人进步奖 风雨历程奖 最具活力勋章

    群组计量经济学之性

    群组LINGO

    你的约束条件部分似乎有歧义,不能很好地理解你的意思。按照你贴出来的模型,猜想你想实现的:
    约束条件1:表示矩阵X的对角线之和(即方阵的迹)为2;
    约束条件2:表示矩阵X每行有且只有1个值为1.
    约束条件3:表示矩阵x每行上面对角线元素减去非对角线元素的差必须大于等于0.
    由此得到的程序是:
    1. model:
    2. sets:
    3.   ZD/1..6/;
    4.   links(ZD,ZD):c,x;
    5. endsets
    6. data:
    7.   c=
    8.   0 6 6 78 3 6        
    9.   1 0 4 5 4 6        
    10.   2 1 0 6 2 9        
    11.   3 2 1 0 3 9        
    12.   4 3 2 7 0 9        
    13.   5 4 3 5 6 0        
    14.   ;
    15. enddata
    16. min=@sum(links(i,j):c(i,j)*x(i,j)); !Objective Function;
    17. @sum(links(i,j)|i #eq# j:x(i,j))=2;
    18. @for(ZD(i):@sum(ZD(j):x(i,j))=1);
    19. @for(ZD(i):@for(ZD(j)|j #ne# i:x(i,i)-x(i,j)>0));
    20. @for(links(i,j):@bin(x(i,j))); !Restrict x to be 0-1;
    21. end
    这个LINGO运行下来没有可行解。这是很显然的。因为约束条件1,2,3之间似乎存在矛盾,无法同时满足,你可以自己推敲一下。


    四十岁后,不滞于物,草木竹石均可为剑。
    回复

    使用道具 举报

    盐田港        

    1

    主题

    11

    听众

    22

    积分

    升级  17.89%

  • TA的每日心情
    慵懒
    2017-6-6 17:55
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    邮箱绑定达人 新人进步奖

    liwenhui 发表于 2014-12-29 14:56
    你的约束条件部分似乎有歧义,不能很好地理解你的意思。按照你贴出来的模型,猜想你想实现的:
    约束条件1: ...

    非常感谢你十分到位的回复,我的问题也成功解决了。
    情况是这样,这个模型中xjj求和=2表示选取两个服务点,也就是只有两个对角线能取值为1;其他取值为1的点则表示服务点能在有限的最优距离内对其进行服务,所以从实际选址意义上来说不矛盾。可能从数理推断上来说存在矛盾。
    无论如何,谢谢。

    点评

    liwenhui  好的。不客气。  详情 回复 发表于 2015-1-16 11:16
    回复

    使用道具 举报

    liwenhui        

    70

    主题

    65

    听众

    5192

    积分

    独孤求败

  • TA的每日心情
    擦汗
    2018-4-26 23:29
  • 签到天数: 1502 天

    [LV.Master]伴坛终老

    自我介绍
    紫薇软剑,三十岁前所用,误伤义士不祥,乃弃之深谷。 重剑无锋,大巧不工。四十岁前恃之横行天下。 四十岁后,不滞于物,草木竹石均可为剑。自此精修,渐进至无剑胜有剑之境。

    社区QQ达人 邮箱绑定达人 发帖功臣 元老勋章 新人进步奖 风雨历程奖 最具活力勋章

    群组计量经济学之性

    群组LINGO

    盐田港 发表于 2015-1-13 15:43
    非常感谢你十分到位的回复,我的问题也成功解决了。
    情况是这样,这个模型中xjj求和=2表示选取两个服务点 ...

    好的。不客气。
    四十岁后,不滞于物,草木竹石均可为剑。
    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2025-8-19 18:59 , Processed in 0.766097 second(s), 69 queries .

    回顶部