码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 九、分枝切割算法


    文章目录

    • 1、Gomory切割的算法原理
    • 2、分枝切割算法
    • THE END

    1、Gomory切割的算法原理

    \qquad 考虑有一个等式的形式如下所示:
    I L + F = f IL+F=f IL+F=f
    \qquad 其中各项满足以下性质:

    • I L IL IL是一个整数值的表达式
    • F F F是一个严格正分数的和
    • f < 1 f<1 f<1是一个严格正的分数
      \qquad 从而可以得出一个结论: F ≥ F \geq F≥ f。从而在拿到任意一个等式之后,可以将等式中的项分别凑到 I L IL IL, F F F和 f f f三项中,之后根据 F ≥ F \geq F≥ f 便可以得到有效的Gomory不等式。将Gomory不等式加到混合整数线性规划问题的线性松弛问题中之后,可以保证:
    • 切割掉一部分原本线性松弛问题的最优解
    • 同时保证所有原本混合整数线性规划的可行解都被保留
      \qquad 对于一个单纯型表形式的非整数解里面,必然有一个横行,
      x i = b + f − ∑ j a j x j ( 1 ) x_i = b+f-\sum_j a_jx_j \qquad (1) xi​=b+f−j∑​aj​xj​(1)
      \qquad 其中 b b b是整数且分数 f f f满足 0 ≤ f < 1 0 \leq f < 1 0≤f<1,将上等式(1)改写为:
      x i + ∑ j a j x j = b + f x i + ∑ j f l o o r ( a j ) x j − b + ∑ j ( a j − f l o o r ( a j ) ) x j = f x_i+\sum_j a_jx_j=b+f \\ x_i+\sum_j floor(a_j)x_j-b+\sum_j (a_j-floor(a_j))x_j=f xi​+j∑​aj​xj​=b+fxi​+j∑​floor(aj​)xj​−b+j∑​(aj​−floor(aj​))xj​=f
      \qquad 则在任意整数解里,有下式(2)满足
      ∑ j ( a j − f l o o r ( a j ) ) x j ≥ f ( 2 ) \sum_j(a_j-floor(a_j))x_j \geq f \qquad (2) j∑​(aj​−floor(aj​))xj​≥f(2)
      \qquad 不等式(2)即为Gomory不等式的一般形式。
      \qquad 除了Gomory不等式之外,还有其他一般性的不等式,如mixed integer roundin不等式和lift and project不等式;其他结构性的割约束,如knapsack cover不等式和Clique不等式。在分枝切割算法中,将不等式的添加和分枝策略进行结合,从而避免单纯割平面算法中系数爆炸的问题。

    2、分枝切割算法

    \qquad 分枝切割算法的流程如下所示:
    在这里插入图片描述
    \qquad 从上述流程可以看出,分枝切割算法和分枝定界算法的流程基本相似,知识在分枝之前,首先需要检查当前分数结点中有没有可以添加的有效不等式,讲这些不等式进行添加到线性规划模型中提升模型的下界。

    THE END

  • 相关阅读:
    java计算机毕业设计商场后台管理系统源码+系统+数据库+lw文档+mybatis+运行部署
    数据库系统原理与应用教程(004)—— MySQL 安装与配置:重置 MySQL 登录密码(windows 环境)
    为了讲明白继承和super、this关键字,群主发了20块钱群红包
    tomcat的初期了解
    royi-vue
    RestEasy入门小程序
    Pluck 代码问题漏洞( CVE-2022-26965)
    JAVA集合07_关于sorted如何排序、实战三级分类树状展示
    VSCode使用SSH免密登录远程主机
    银河麒麟高级服务器操作系统V10下载安装及安装docker
  • 原文地址:https://blog.csdn.net/weixin_43160744/article/details/133611544
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号