运筹学基础(六)列生成算法(Column generation)

2024-04-09 11:04

本文主要是介绍运筹学基础(六)列生成算法(Column generation),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 从Cutting stock problem说起
    • 常规建模
    • Column generation reformulation
  • 列生成法
    • 核心思想
    • 相关概念
      • Master Problem (MP)
      • Linear Master Problem (LMP)
      • Restricted Linear Master Problem (RLMP)
      • subproblem(核能预警,非常重要)
    • 算法流程图
    • CG求解cutting stock problem
    • 适用场景:large linear programming
  • 参考资料

前言

学习列生成之前,有一些前置基础需要理解,不然就没法继续往下学了。所以为了写这篇文章,我提前铺垫了3篇文章帮助自己把基础捡起来!

  1. 单纯形法:运筹学基础(一)求解线性规划的单纯形法详解
  2. 检验数:运筹学基础(四):单纯形法中检验数(reduced cost)的理解
  3. 对偶问题:运筹学基础(五):对偶问题及其性质

今天终于可以进入正题了!

从Cutting stock problem说起

有一堆固定长度的钢管,不同的顾客想要长度不一样的钢管若干,怎么切割钢管能够使得消耗的钢管数最少?
在这里插入图片描述

常规建模

【集合】

  • K K K:未切割的钢管集合;
  • I I I:所需钢管的种类集合;

【参数】

  • D i D_i Di:第 i i i种钢管的需求数量;
  • L k L_k Lk:第 k k k根未切钢管的长度;
  • L i L_i Li:第 i i i种钢管的长度;

【决策变量】

  • x k i x_{ki} xki:第 k k k根钢管切割第 i i i种长度的数量;
  • y k y_k yk:第 k k k根钢管是否使用;

【数学模型】

目标函数:最小化使用的钢管数量
约束条件:

  1. 每根钢管被切割的总长度,不多于该根钢管的总长度;
  2. 每种钢管被切割的数量不低于该种钢管的总需求量;

m i n ∑ k ∈ K y k s . t . ∑ i ∈ I x k i L i ≤ L k ∗ y k , ∀ k ∈ K ∑ k ∈ K x k i ≥ D i , ∀ i ∈ I x k i ∈ { 0 , 1 } , ∀ k ∈ K , i ∈ I y k ∈ { 0 , 1 } , ∀ k ∈ K min \quad \sum_{k\in K}y_k\\ s.t. \sum_{i\in I}x_{ki}L_i\leq L_k*y_k, \forall k \in K\\ \sum_{k\in K}x_{ki} \geq D_i, \forall i \in I\\ x_{ki} \in \{0, 1\}, \forall k\in K, i\in I\\ y_{k} \in \{0, 1\}, \forall k\in K minkKyks.t.iIxkiLiLkyk,kKkKxkiDi,iIxki{0,1},kK,iIyk{0,1},kK

问题:该建模方式求解不高效(怎么理解),因此有人想出了第二种建模思路。

Column generation reformulation

假设所有的切割方式已知,我们用:

  • P P P表示所有的切割方案集合;
  • C p i C_{pi} Cpi表示在第 p p p种切割方式下,能切割出的第 i i i种钢管的数量;

定义新的决策变量:

  • z p z_p zp:表示执行第 p p p种切割模式的钢管的数量。

数学模型表示如下:
m i n ∑ p ∈ P z p s . t . ∑ p ∈ P C p i z p ≥ D i , ∀ i ∈ I z p ≥ 0 , z p i s i n t e g e r , ∀ p ∈ P min \sum_{p\in P}z_p\\ s.t. \sum_{p\in P}C_{pi}z_p \geq D_i, \forall i \in I\\ z_p \geq 0, z_p \quad is \quad integer, \forall p\in P minpPzps.t.pPCpizpDi,iIzp0,zpisinteger,pP

核心问题:切割模式非常多,穷举出来几乎是不可能的,也没有必要(因为不是所有的切割模式都会被用到)!那么如何去寻找最优的切割模式呢?

铛铛铛铛,列生成法正式登场!

列生成法

核心思想

列生成法本质上也是单纯形法的一种形式。常规的单纯形法要求可以把所有变量显式的表达出来,但是诸如cutting stock problem之类的问题,可能无法做到这一点,因此常规的单纯形法就束手无策了。

回想一下单纯形法的迭代过程,基变量的个数等于约束的个数,每次找一个非基变量入基(这个非基变量的增加,要能优化目标函数),直到不能改善目标函数值为止。可以发现,在这个过程中,并不是所有的变量都会用到!

因此有人想到:

  1. 可以先把原问题( P 0 P_0 P0)限制( r e s t r i c t restrict restrict)到一个规模很小的问题( P 1 P_1 P1)上,然后用单纯形法求解 P 1 P_1 P1。但此时求的最优解是 P 1 P_1 P1的最优解,不是原问题的最优解。
  2. 因此还需要一个子问题(subproblem)去检查是否存在一个非基变量,其reduced cost小于0(即改变量的增大可以进一步优化目标函数),如果存在,就把这个非基变量相关的系数列加入到 P 1 P_1 P1的系数矩阵中,回到第一步。直到找不到reduced cost小于0的非基变量,即找到了原问题的最优解。

为了获取更优的目标值,往往会选择reduced cost最小的非基变量(切割模式)加入到 P 1 P_1 P1中,那么如何寻找reduced cost最小的非基变量呢?

回答这个问题之前,有一些相关概念先快速弄清楚。

相关概念

Master Problem (MP)

对于一般问题而言,如果要用CG(column generation)求解,一般要转化成set covering model,类似于上面的cutting stock model。不是很理解为什么

转为称为set covering model的问题就称为MP,例如:
在这里插入图片描述

Linear Master Problem (LMP)

如果MP里存在整数变量,要先进行线性松弛,MP线性松弛以后的问题就是LMP。
在这里插入图片描述

Restricted Linear Master Problem (RLMP)

将LMP限制(restrict)到一个规模更小(即变量数量更少)的问题,就称为RLMP了。

可以看到,下式相比原来的linear master problem,restricted linear master problem相当于把 y k + 1 . . . y n y_{k+1}...y_{n} yk+1...yn强制限制为非基变量了。
在这里插入图片描述

subproblem(核能预警,非常重要)

subproblem就是帮助我们找到,当前是否还有非基变量加入 P 1 P_1 P1能够使得目标函数值进一步改善的。理解subproblem的前提是,弄清楚检验数和对偶变量之间的关系。

我们做一下推导:
在这里插入图片描述

假设我们找到了原问题的最优解 [ x B , 0 ] [x_B, 0] [xB,0],那么此时原问题的检验数一定都是大于等于0的,即:
C N T − C B T B − 1 N ≥ 0 C_N^T-C_B^TB^{-1}N \geq 0 CNTCBTB1N0
可以得到:
C N T ≥ C B T B − 1 N C_N^T \geq C_B^TB^{-1}N CNTCBTB1N
我们计算一下:
C B T B − 1 A = C B T B − 1 [ B , N ] = [ C B T , C B T B − 1 N ] ≤ [ C B T , C N T ] = C T C_B^TB^{-1}A=\\ \quad\\ C_B^TB^{-1}[B, N]=\\ \quad\\ [C_B^T, C_B^TB^{-1}N]\leq\\ \quad\\ [C_B^T,C_N^T]=\\ \quad\\ C^T CBTB1A=CBTB1[B,N]=[CBT,CBTB1N][CBT,CNT]=CT
提炼一下上式推导过程中的首尾:
C B T B − 1 A ≤ C T C_B^TB^{-1}A \leq C^T CBTB1ACT

观察一下对偶问题的约束条件:
y T A ≤ C T y^TA\leq C^T yTACT

发现:
C B T B − 1 C_B^TB^{-1} CBTB1
是对偶问题的一个可行解!

我们继续证明它不仅是一个可行解,而且是最优解:
令:
y T = C B T B − 1 y^T=C_B^TB^{-1} yT=CBTB1
此时对偶问题的目标函数值为:
y T A = C B T B − 1 b = y^TA=C_B^TB^{-1}b= yTA=CBTB1b=
这里有个转换是:
x B = B − 1 b x_B=B^{-1}b xB=B1b
在我的文章运筹学基础(四):单纯形法中检验数(reduced cost)的理解里有相关推导。

因此:
y T A = C B T B − 1 b = C B T x B = C T x y^TA=C_B^TB^{-1}b=C_B^Tx_B=C^Tx yTA=CBTB1b=CBTxB=CTx
根据对偶问题的最优性性质,可知 y T y^T yT为对偶问题的最优解。

于是检验数的表达式可以写成:
C N T − C B T B − 1 N = y T N C_N^T-C_B^TB^{-1}N = y^TN CNTCBTB1N=yTN

所谓的subproblem就是根据该公式,在 y k + 1 . . . y n y_{k+1}...y_{n} yk+1...yn中找到检验数为负,并且最小的非基变量,将变量对应的那一列添加到RLMP中。

算法流程图

在这里插入图片描述

CG求解cutting stock problem

题目如下:

在这里插入图片描述

第一步:求解RLMP的最优解
在这里插入图片描述
第二步:求解subproblem
c i c_i ci表示在新的这种切割模式下,切割第 i i i种钢管的数量。
23+27=20米,正好为钢管的总长度,符合条件。

在这里插入图片描述
第三步:加入新的切割模式到原来的模型中,继续求解

在这里插入图片描述
第四步:继续求解subproblem,无更好的切割模式,终止
在这里插入图片描述

适用场景:large linear programming

约束的数量有限,但是变量的数量非常多的大规模线性规划问题。例如:机组人员调度问题(Crew Assignment Problem)、切割问题(Cutting Stock Problem)、车辆路径问题(Vehicle Routing Problem)、单资源工厂选址问题(The single facility location problem )等。

参考资料

  1. 带你彻底了解Column Generation(列生成)算法的原理
  2. 大规模优化求解器-Gurobi-教程

这篇关于运筹学基础(六)列生成算法(Column generation)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/887975

相关文章

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南

《Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南》在日常数据处理工作中,我们经常需要将不同Excel文档中的数据整合到一个新的DataFrame中,以便进行进一步... 目录一、准备工作二、读取Excel文件三、数据叠加四、处理重复数据(可选)五、保存新DataFram

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

详解Java中如何使用JFreeChart生成甘特图

《详解Java中如何使用JFreeChart生成甘特图》甘特图是一种流行的项目管理工具,用于显示项目的进度和任务分配,在Java开发中,JFreeChart是一个强大的开源图表库,能够生成各种类型的图... 目录引言一、JFreeChart简介二、准备工作三、创建甘特图1. 定义数据集2. 创建甘特图3.

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文