当前位置: 首页 > news >正文

分支定界、分支切割、分支定价的区别

目录

1.从原理的角度

(1)分支定界:

(2)分支切割:

(3)分支定价:

2.从分支树的角度

(1)分支定界

(2)分支切割

(3)分支定价


1.从原理的角度

(1)分支定界:

仅添加整数割(本质上是一种特殊的割平面)。

(2)分支切割:

添加(根据问题)定制的割平面(规则/指标)。比如VRP问题中的k-paths割,即若干顾客的需求量至少需要的车辆数。

(3)分支定价:

将原问题重写,如VRP问题中将x_{ijk}的3-index模型改写为路径y_{r}的1-index模型(RMP);然后松弛主问题得到RLMP,再根据子问题的检验数不断往RLMP中添加新的路径,再次求解RLMP直到求到RLMP的最优解。若该解是非整数解则分支。

该算法比前两者难的原因是,需要改写模型;而且需要求解子问题(设计出有效的算法,比如标签算法,支配规则等)。别的与前两者区别不大。

2.从分支树的角度

从分支树的角度,我觉得更好理解。

(1)分支定界

可以看到,通过定界和剪支操作,比全枚举(二叉树)要少了很多枝。

(2)分支切割

可以看到比着分支定界算法枝干又减少了,但是两个叶子节点之间多了一些点(蓝框),是通过红框中的cut而求解产生的新的点。

 (3)分支定价

可以看到它在叶子节点做了更多的工作,所以最终实际上的节点更少。

总结:难度系数,分支定界<分支切割<分支定价。难的点在于分支切割要找到有效的加强的割平面(cut);分支定价需要重写模型,写出主问题和子问题,还需要求解子问题 。

http://www.lryc.cn/news/181622.html

相关文章:

  • 数字IC前端学习笔记:数字乘法器的优化设计(阵列乘法器)
  • 批量删除wordpress文章修订版本/自动草稿残留数据(3种方法)及四种方法禁用WordPress文章历史修订/自动保存/自动草稿功能
  • HTTP初识,fiddler的使用,URL各部分介绍,QueryString
  • 计算机毕业设计 基于SpringBoot的图书馆管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解
  • 第三章:最新版零基础学习 PYTHON 教程(第十二节 - Python 运算符—Python 中的运算符函数 - 套装1)
  • AAD基础知识(identity/token/PRT)
  • 基于SSM的视频点播系统设计与实现
  • React 知识点总结
  • ALSA project the C library refrerenc (ALSA工程 C库参考说明)
  • 【Maven基础篇-黑马程序员】Maven项目管理从基础到高级,一次搞定!
  • MySQL进阶 —— 超详细操作演示!!!(下)
  • SVM(上):如何用一根棍子将蓝红两色球分开?
  • libevent源码学习笔记
  • C++ opencv设置视频的捕获方式为 MJPG设置失败
  • 计算机网络两位伟人
  • 机器学习 不均衡数据采样方法:imblearn 库的使用
  • MySQL系统与内建函数
  • STM32CubeMX学习笔记-USB接口使用(CDC虚拟串口)
  • 腾讯云 Cloud Studio 实战训练营结营活动获奖公示
  • 使用晶体管做布尔逻辑和逻辑门
  • Linux系统编程系列之线程的信号处理
  • 【C语言】青蛙跳台阶 —— 详解
  • Java - 基本数据类型和封装类型
  • day-63 代码随想录算法训练营(19) 图论 part 02
  • SpringBoot的全局异常拦截
  • 『力扣每日一题11』:转换成小写字母
  • 复习Day07:链表part03:21. 合并两个有序链表、2. 两数相加
  • Ubuntu中启动HDFS后没有NameNode解决办法
  • AWS-Lambda之导入自定义包-pip包
  • MAC 如何解决GitHub下载速度慢的问题