网站大量收购独家精品文档,联系QQ:2885784924

关于yalmip知识点.doc

  1. 1、本文档共2页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
1. 创建决策变量:    x = sdpvar(m, n [, option]):创建m*n的连续型决策变量矩阵,option是对矩阵的一些参数指定。   相应的,如果要创建整型或二值型决策变量,matlab语句分别为:      x = intvar(m, n, [option])    x = binvar(m, n, [option]) 2. 添加约束:    F = set(constraint [, tag]):创建一个以constraint指定的约束,可选参数tag可以给该约束指定一个字符串标记。重要的是constraint的表达也非常简单,例如如果有 x1 + x2 + x3 = 3 的约束,直接写:    x = sdpvar(3, 1);   ?F = set(x(1) + x(2) + x(3) = 3, cost bound1);   如果要继续添加约束也非常简单,支持用+直接相连(类似于.net 里面的事件处理程序):    F = F + set(constraint1 [, tag1]);    F = F + set(constraint2 [, tag2]);……   例如,如果继续限制 x 只能取[0, 1]之间的值,则:    F = F + set(0 = x = 1, ‘upper and lower bound’);   一句话就搞定了,是不是非常简单。! 3. 参数配置   这个比较简单,语句如下:   ?ops = sdpsettings(option1, value1, option2, value2, ……)   例如语句   ?ops = sdpsettings(solver, lpsolve, verbose, 2);   solver 参数指定程序用lpsolve求解器(如果已经安装,否则会报错),如果不指定 ‘solver’ 参数,他会根据决策变量类型自动挑选已安装的、最适合的求解器;verbose 指定显示冗余度(冗余度越大,你就可以看到越详细的求解过程信息)。 4. 求解   这个也只有一句话:   ?result = solvesdp(F, f, ops) 求解一个数学规划(最小化)问题,该问题的目标函数由 f 指定,约束由 F 指定,ops指定求解参数,最后的结果存储在result结构体中。 还是以前面那个问题作为例子,如果用yalmip的话,只需要如下简单几句:   ?x = sdpvar(3, 1);   ?f = [4 2 1] * x;   ?F = set(2*x(1) + x(2) = 1);   ?F = F + set(x(1) + 2 * x(3) = 2);   ?F = F + set(x(1) + x(2) + x(3) == 1);   ?F = F + set(0 = x(1) = 1) + set(0 = x(2) = 1) + set(0 = x(3) = 2);   ?ops = sdpsettings(solver, lpsolve, verbose, 2);   ?result = solvesdp(F, -f, ops);   如果你想用 cplex 求解器求解,只需要将以上的‘solver’参数的‘lpsolve’改成‘cplex’,其他任何地方都不需要做改动。

文档评论(0)

qiwqpu54 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档