首页 > 图书中心 > 运筹优化常用模型、算法及案例实战——Python+Java实现

目录

目  录

第I部分  运筹优化常用模型及建模技巧

第1章  运筹优化算法相关概念  3

1.1  几类常见的数学规划模型  3

1.1.1  线性规划  3

1.1.2  混合整数规划  3

1.1.3  二次规划  4

1.1.4  二次约束规划  4

1.1.5  二次约束二次规划  4

1.1.6  二阶锥规划  5

1.2  凸集和极点  6

1.2.1  凸集  6

1.2.2  极点  7

1.3  多面体、超平面与半平面  7

1.3.1  多面体  7

1.3.2  超平面与半平面  7

1.4  凸组合和凸包  8

1.4.1  凸组合和凸包的概念  8

1.4.2  一些结论  8

第2章  运筹优化经典问题数学模型  9

2.1  指派问题  9

2.2  最短路问题  11

2.3  最大流问题  12

2.3.1  问题描述  12

2.3.2  问题建模及最优解  13

2.3.3  最大流问题的一般模型  14

2.3.4  Ford–Fulkerson 算法求解最大流问题  15

2.3.5  Java实现Ford–Fulkerson算法求解最大流问题  18

2.4  最优整数解特性和幺模矩阵  23

2.4.1  指派问题的最优解特性验证  24

2.4.2  最短路问题的整数最优解特性验证  27

2.4.3  最优整数解特性的理解  31

2.4.4  幺模矩阵和整数最优解特性  32

2.5  多商品网络流问题  34

2.6  多商品流运输问题  37

2.7  设施选址问题  38

2.8  旅行商问题  39

2.8.1  TSP建模方法1:子环路消除约束  41

2.8.2  TSP建模方法2:MTZ约束消除子环路  42

2.8.3  TSP建模方法3:1-tree建模方法  45

2.9  车辆路径规划问题  47

2.9.1  概述  47

2.9.2  VRPTW的一般模型  48

第3章  整数规划建模技巧  51

3.1  逻辑约束  51

3.1.1  两个命题  51

3.1.2  二选一约束条件  51

3.1.3  指示约束条件  53

3.2  线性化  54

3.2.1  分段线性函数线性化  54

3.2.2  含绝对值形式的线性化  58

3.2.3  含乘积形式的线性化  60

3.2.4  含分式形式的线性化  61

3.2.5  含max/min形式的线性化  62

第4章  大规模线性规划的对偶  64

4.1  对偶理论概述  64

4.2  原问题与对偶问题之间的关系  65

4.3  对偶理论相关重要定理  66

4.4  最短路问题的对偶  73

4.4.1  借助Excel和具体小算例写出大规模SPP的对偶  74

4.4.2  SPP中存在负环的特例  76

4.5  多商品网络流问题的对偶  81

4.5.1  借助Excel和具体小算例写出大规模MCNF的对偶  81

4.5.2  将Excel中的对偶问题表转化成公式形式  83

4.5.3  Python调用Gurobi求解MCNF  83

第II部分  常用优化求解器API详解及应用案例

第5章  CPLEX的Java API详解及简单案例  93

5.1  基于Eclipse的CPLEX Java API的安装与配置:适用于macOS  93

5.2  基于Eclipse的CPLEX Java API的安装与配置:适用于Windows  97

5.2.1  基本环境配置  97

5.2.2  环境设置中java.library.path的问题  98

5.2.3  Javadoc的设置  100

5.3  CPLEX建模  102

5.3.1  类与接口  102

5.3.2  变量   102

5.3.3  表达式   102

5.3.4  范围约束   104

5.3.5  目标函数   104

5.3.6  建模方式  105

5.3.7  模型求解  108

5.3.8  获取解的信息  108

5.3.9  模型导出与模型导入  109

5.3.10  参数  109

5.3.11  其他  114

5.4  传统回调  114

5.4.1  参考回调  115

5.4.2  查询或诊断回调  116

5.4.3  控制回调  117

5.4.4  回调的终止  118

5.4.5  传统回调示例  119

5.5  通用回调  121

5.5.1  简介  121

5.5.2  功能  121

5.5.3  通用回调的上下文  121

5.5.4  通用回调示例  123

5.6  Java调用CPLEX求解整数规划的小例子  124

5.6.1  书架生产问题  124

5.6.2  包装盒选择问题  128

第6章  Gurobi的Python API详解及简单案例  132

6.1  Python调用Gurobi环境配置  132

6.1.1  完整步骤  132

6.1.2  相关问题  132

6.2  Gurobi算法框架介绍  138

6.2.1  Gurobi MIP Algorithms  138

6.2.2  Presolving  140

6.2.3  Node Selection  141

6.2.4  Cutting Planes  142

6.2.5  Heuristics  143

6.2.6  设置启发式的参数  144

6.2.7  Branching  144

6.3  Gurobi能够求解的模型类别  145

6.3.1  线性规划  145

6.3.2  混合整数规划  147

6.3.3  二次规划  148

6.3.4  二次约束二次规划  150

6.3.5  二阶锥规划  152

6.4  Python 调用Gurobi总体流程  154

6.5  Gurobi求解MIP输出的日志信息解释  156

6.5.1  MIP日志示例  156

6.5.2  预求解部分  157

6.5.3  求解进程部分  158

6.5.4  汇总部分  160

6.6  Python接口概述  161

6.6.1  模型概述  161

6.6.2  求解模型  162

6.6.3  多个解、目标函数和场景  162

6.6.4  不可行的模型  162

6.6.5  查询和修改模型属性  163

6.6.6  其他修改模型信息的方法  163

6.6.7  惰性更新  164

6.6.8  参数管理  164

6.6.9  管理求解进程:日志和回调  165

6.6.10  修改求解器的行为:回调  165

6.7  Python调用Gurobi常用类和函数  165

6.7.1  全局函数  165

6.7.2  Model类  166

6.7.3  Var类和MVar类  169

6.7.4  Column类  170

6.7.5  目标函数  170

6.7.6  表达式  171

6.7.7  约束类  172

6.7.8  求解  175

6.7.9  解的输出  176

6.8  Python接口中的GRB类  176

6.8.1  GRB类中的常量  176

6.8.2  GRB类中的属性:GRB.Attr 180

6.8.3  GRB类中的参数:GRB.Param 185

6.9  Gurobi的回调函数  190

6.9.1  什么是Gurobi的回调函数  190

6.9.2  Gurobi回调函数的用法  192

6.10  Python 调用Gurobi的参数调优  193

6.11  Python调用Gurobi求解整数规划的简单例子  194

第7章  调用CPLEX和Gurobi求解MIP的复杂案例:VRPTW和TSP  197

7.1  调用CPLEX和Gurobi求解VRPTW  197

7.1.1  VRPTW的一般模型  197

7.1.2  Java调用CPLEX求解VRPTW  198

7.1.3  Java调用Gurobi求解VRPTW  213

7.1.4  Python调用Gurobi求解VRPTW  221

7.2  Python调用Gurobi求解TSP  232

7.2.1  TSP的MTZ建模及调用Gurobi求解  235

7.2.2  TSP:Python调用Gurobi实现callback添加消除子环路约束  237

第III部分  运筹优化常用算法及实战

第8章  单纯形法  249

8.1  线性规划问题的标准形式  249

8.2  单纯形法流程图及详细案例  251

8.3  大$M$法和两阶段法  257

8.4  单纯形法伪代码  259

8.5  Python实现单纯形法  260

第9章  Dijkstra算法  265

9.1  Dijkstra算法求解最短路问题详解  265

9.2  Dijkstra算法步骤及伪代码  269

9.3  Python实现Dijkstra算法  271

9.3.1  网络数据准备  271

9.3.2  Dijkstra算法实现  272

9.3.3  算例测试  273

9.4  拓展  274

第10章  分支定界算法  275

10.1  整数规划和混合整数规划  275

10.2  分支定界算法求解混合整数规划  276

10.3  分支定界算法的一般步骤和伪代码  286

10.4  分支定界算法执行过程的直观展示  290

10.5  分支定界算法的分支策略  291

10.6  分支定界算法的搜索策略  292

10.7  分支定界算法的剪枝策略  292

10.8  Python调用Gurobi实现分支定界算法的简单案例  293

10.9  Python调用Gurobi实现分支定界算法求解TSP  300

10.10  Python调用Gurobi实现分支定界算法求解VRPTW  301

第11章  分支切割算法  303

11.1  什么是分支切割算法  303

11.2  有效不等式  306

11.3  割平面算法  308

11.3.1  Gomory's分数割平面算法  309

11.3.2  其他割平面算法  313

11.4  分支切割算法: 分支定界+割平面  314

11.4.1  分支切割算法伪代码  314

11.4.2  分支切割算法: 一个详细的例子  317

11.5  Java调用CPLEX实现分支切割算法求解VRPTW  319

11.5.1  分支定界  319

11.5.2  割平面  320

11.6  Python调用Gurobi实现分支切割算法求解VRPTW完整代码  321

11.7  Java 调用 CPLEX 实现分支切割算法求解CVRP: 回调函数添加割平面  322

11.7.1  CVRP的基本模型  322

11.7.2  割平面  323

第12章  拉格朗日松弛  326

12.1  最优性和松弛  326

12.1.1  原始边界  327

12.1.2  对偶边界  328

12.2  对偶  328

12.3  拉格朗日松弛  329

12.3.1  拉格朗日松弛介绍  329

12.3.2  拉格朗日对偶问题  330

12.3.3  拉格朗日松弛应用案例:无容量限制的设施选址问题  331

12.4  拉格朗日对偶的加强  333

12.5  求解拉格朗日对偶  335

12.5.1  次梯度算法求解拉格朗日对偶  335

12.5.2  应用案例:拉格朗日松弛求解TSP  338

12.6  如何选择拉格朗日松弛  340

12.7  Python调用Gurobi实现拉格朗日松弛求解选址--运输问题  342

12.7.1  拉格朗日松弛应用案例:选址--运输问题  342

12.7.2  Python代码实现  345

第13章  列生成算法  347

13.1  为什么用列生成算法  347

13.2  下料问题  349

13.2.1  引例  349

13.2.2  列生成求解下料问题的一般模型及其伪代码  352

13.2.3  列生成最优性的几个小问题  355

13.3  列生成求解下料问题的实现  356

13.3.1  Python调用Gurobi实现列生成求解下料问题示例算例:版本1  357

13.3.2  Python调用Gurobi实现列生成求解下料问题示例算例:版本2

(以人工变量为初始列的方式)  360

13.3.3  Python调用Gurobi实现列生成求解下料问题 : 版本3  362

13.4  列生成求解TSP  365

13.4.1  TSP的1-tree建模及列生成求解  365

13.4.2  主问题  366

13.4.3  子问题  367

13.5  列生成求解VRPTW  369

13.5.1  主问题  370

13.5.2  子问题  372

13.5.3  详细案例演示  373

第14章  动态规划  393

14.1  动态规划  393

14.1.1  动态规划求解最短路问题  394

14.1.2  问题建模和求解  394

14.1.3  一个较大规模的例子  396

14.2  动态规划的实现  397

14.2.1  伪代码  397

14.2.2  Java代码  398

14.3  动态规划求解TSP  403

14.3.1  一个简单的TSP算例  403

14.3.2  伪代码  408

14.3.3  Python实现:示例算例  409

14.3.4  Python实现:中大规模算例  412

14.4  标签算法求解带资源约束的最短路问题  419

14.4.1  带资源约束的最短路问题  419

14.4.2  标签算法  424

14.4.3  标签算法的伪代码   425

14.4.4  标签设定算法和标签校正算法  426

14.4.5  优超准则和优超算法  426

14.4.6  Python实现标签算法求解SPPRC  427

14.5  Python实现标签算法结合列生成求解VRPTW  435

14.5.1  初始化RMP  435

14.5.2  标签算法求解子问题  437

第15章  分支定价算法  438

15.1  分支定价算法基本原理概述  438

15.2  分支定价算法求解VRPTW  440

15.2.1  VRPTW的通用列生成建模方法  440

15.2.2  分支定价算法完整流程及伪代码  442

15.2.3  分支策略  445

15.2.4  界限更新  449

第16章  Dantzig-Wolfe分解算法  450

16.1  引例  450

16.2  块角模型与Dantzig-Wolfe分解  454

16.2.1  块角模型  454

16.2.2  Minkowski表示定理  455

16.2.3  模型分解  455

16.2.4  两阶段法  458

16.3  详细案例  459

16.4  Dantzig-Wolfe分解求解大规模混合整数规划  464

16.4.1  两阶段法实现Dantzig-Wolfe分解算法介绍  465

16.4.2  第1阶段  465

16.4.3  第2阶段  471

16.5  Python调用Gurobi实现Dantzig-Wolfe分解求解多商品流运输问题  482

16.5.1  多商品网络流模型的区块结构  482

16.5.2  多商品流运输问题 : Dantzig-Wolfe分解求解  483

16.5.3  Python调用Gurobi实现Dantzig-Wolfe分解求解多商品流运输问题  487

16.5.4  完整代码  487

16.5.5  算例格式说明  497

16.5.6  算例运行结果  498

16.6  Dantzig-Wolfe分解求解VRPTW  500

第17章  Benders分解算法  504

17.1  分解方法  504

17.1.1  Benders分解的原理  504

17.1.2  Benders分解的全过程  509

17.1.3  算法框架图  510

17.1.4  算法伪代码  511

17.2  详细案例  512

17.2.1  问题描述和模型转换  512

17.2.2  第1次迭代  513

17.2.3  第2次迭代  515

17.2.4  第3次迭代  516

17.2.5  第4次迭代  517

17.3  Benders分解应用案例  518

17.3.1  固定费用运输问题  518

17.3.2  设施选址问题  520

参考文献  523

版权所有(C)2023 清华大学出版社有限公司 京ICP备10035462号 京公网安备11010802042911号

联系我们 | 网站地图 | 法律声明 | 友情链接 | 盗版举报 | 人才招聘