09-第九章 ILOG OPL 建模语言 优化软件与应用 教学课件.pptVIP

09-第九章 ILOG OPL 建模语言 优化软件与应用 教学课件.ppt

  1. 1、本文档共28页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
09-第九章 ILOG OPL 建模语言 优化软件与应用 教学课件

主讲人: 雒兴刚 东北大学系统工程研究所 Email:luoxinggang@ise.neu.edu.cn Tel:优化软件与应用 第九章 ILOG OPL 建模语言 OPL 数据类型 1、整型:范围 例: int i = 25; int n = 3; int size = n*n; //注意这种初始化很特别 2、浮点型:双精度,IEEE 754 standard float f = 3.2; 第九章 ILOG OPL 建模语言 OPL 数据类型 3、字符串型 例如{string} Tasks = {masonry,carpentry,plumbing,ceiling, roofing,painting,windows,facade, garden,moving}; 定义字符串一个集合 。 字符串中的特殊字符: 字符串换行: 第九章 ILOG OPL 建模语言 OPL 数据结构 1、Range:给定最小和最大值。 range Rows = 1..10; int n = 8; range Rows = n+1..2*n+1; 用途1:数组定义 range R = 1..100; int A[R]; // A is an array of 100 integers 用途2:循环 range R = 1..100; forall(i in R) { //element of a loop ... } 用途3:变量定义 dvar int i in R; 第九章 ILOG OPL 建模语言 OPL 数据结构 2、数组 一维数组: int a[1..4] = [10, 20, 30, 40]; float f[1..4] = [1.2, 2.3, 3.4, 4.5]; string d[1..2] = [Monday, Wednesday]; int a[Days] = [10, 20, 30, 40, 50, 60, 70]; 即元素下标可以是字符串,如a[Monday],...,a[Sunday]. tuple Edges { int orig; int dest; } {Edge} Edges = {1,2, 1,4, 1,5}; int a[Edges] = [10,20,30]; 即下标也可以是Tuple,a[1,2], a[1,4], and a[1,5] 第九章 ILOG OPL 建模语言 OPL 数据结构 2、数组 多维数组: int a[1..2][1..3] = ...; int a[Days][1..3] = ...; //混合下标 {string} Warehouses = ...; {string} Customers = ...; tuple Route { string w; string c; } {Route} routes = ...; int transp[routes] = ... //实际上transp是二维数组 {string} Warehouses ...; {string} Customers ...; tuple Route { Warehouses w; Customers c; } {Route} routes = ...; int transp[routes] = ... 可能是稀疏矩阵 两种哪个好些? 第九章 ILOG OPL 建模语言 OPL 数据结构 3、Tuple:结构体 tuple Point { int x; int y; }; Point point[i in 1..3] = i, i+1; Point p = 2,3; Point point[i in 1..3] = i, i+1; //Tuple数组 {Point} points = {1,2, 2,3}; //Tuple集合 tuple Rectangle { Point ll; Point ur; } //Tuple的Tuple Point p = 2,3; int x = p.x; //取Tuple的成员 但是,Tuple的定义里不能出现Tuple集合和Tuple数组! 第九章 ILOG OPL 建模语言 OPL 数据结构 4、集合:可以写成{T}, 或者 setof(T) {int} setInt = ...; setof(Precedence) precedences = ...; 集合初始化: tuple Precedence { int before; int after; } {Precedence} precedences

文档评论(0)

yurixiang1314 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档