Main Content

混合整数线性规划 (MILP) 算法

混合整数线性规划定义

混合整数线性规划 (MILP) 问题具有以下要素:

  • 线性目标函数 fTx,其中 f 是由常数组成的列向量,x 是由未知数组成的列向量

  • 边界和线性约束,但没有非线性约束(有关定义,请参阅编写约束

  • x 的某些分量的限制,使其必须具有整数值

以数学语言表达,即根据向量 flbub,矩阵 AAeq,对应的向量 bbeq,以及索引集 intcon,求解向量 x 使下式成立

minxfTx subject to {x(intcon) are integersAxbAeqx=beqlbxub.

传统 intlinprog 算法

算法概述

'legacy' intlinprog 算法使用此基本策略来求解混合整数线性规划。intlinprog 可以在任一阶段完成问题的求解。如果它在某个阶段成功求解了问题,intlinprog 不会执行后面的阶段。

  1. 使用线性规划预处理缩减问题的规模。

  2. 使用线性规划求解初始松弛(非整数)问题。

  3. 执行混合整数规划预处理以收紧混合整数问题的 LP 松弛。

  4. 尝试切割生成以进一步收紧混合整数问题的 LP 松弛。

  5. 尝试使用启发式方法求得整数可行解。

  6. 使用分支定界算法系统地搜索最优解。此算法通过限制整数变量的可能值范围来求解 LP 松弛问题。它尝试在最优目标函数值上生成一系列更新边界。

线性规划预处理

根据混合整数线性规划定义,矩阵 AAeq 以及对应的向量 bbeq 以如下形式编写一组线性不等式和线性等式

A·xbAeq·x=beq.

这些线性约束对解 x 施加约束。

通常,我们可以减少问题中的变量数量(x 的分量数量),并减少线性约束的数量。虽然执行这些缩减可能会花费求解器的时间,但它们通常会缩短求解的总时间,并使更大型的问题可求解。这些算法可以使解在数值上更加稳定。此外,这些算法有时可以检测不可行问题。

预处理步骤旨在消除冗余变量和约束,改善模型的尺度和约束矩阵的稀疏性,加强变量的边界,检测模型的原始和对偶不可行性。

有关详细信息,请参阅 Andersen 和 Andersen 的论著 [3] 以及 Mészáros 和 Suhl 的论著 [10]

线性规划

初始松弛问题是线性规划问题,其目标和约束与混合整数线性规划定义相同,但没有整数约束。xLP 称为松弛问题的解,x 称为具有整数约束的原始问题的解。显然,

fTxLPfTx

因为 xLP 在较少的约束下最小化相同的函数。

此初始松弛 LP(根节点 LP)以及分支定界算法期间生成的所有 LP 松弛都使用线性规划方法来求解。

混合整数规划预处理

在混合整数规划预处理期间,intlinprog 分析线性不等式 A*x ≤ b 以及完整性约束,以确定是否有以下情形:

  • 此问题不可行。

  • 有些边界可以收紧,因此有些变量可以固定。

  • 有些不等式是冗余的,因此可以忽略或删除。

  • 一些不等式可以得到加强。

通过 IntegerPreprocess 选项,您可以选择 intlinprog 采取某些步骤、采取所有步骤还是几乎不采取任何步骤。如果包含 x0 参量,intlinprog 会在预处理中使用该值。

混合整数规划预处理的主要目标是简化后续的分支定界计算。预处理包括快速预检查和消除一些无用的子问题候选项,以免分支定界算法对其进行分析。

有关整数预处理的详细信息,请参阅 Achterberg 等人的论著 [1]

切割生成

切割是 intlinprog 为问题增加的额外线性不等式约束。这些不等式尝试限制 LP 松弛的可行域,使其解更接近整数。您可以通过 CutGeneration 选项控制 intlinprog 使用的切割类型。

'basic' 切割包括:

  • 混合整数舍入切割

  • 戈莫里切割

  • Clique 切割

  • 覆盖切割

  • 流覆盖切割

此外,如果问题为纯整数型(所有变量均为整数值),则 intlinprog 还使用以下切割:

  • 强查瓦塔尔-戈莫里切割

  • 零-半切割

'intermediate' 切割包括所有 'basic' 切割,还包括:

  • 简单的提升投影切割

  • 简单的主元缩减切割

  • 缩减拆分切割

'advanced' 切割包括缩减拆分切割以外的所有 'intermediate' 切割,还包括:

  • 强查瓦塔尔-戈莫里切割

  • 零-半切割

对于纯整数型问题,'intermediate' 使用的切割类型最多,因为它使用缩减拆分切割,而 'advanced' 不使用。

另一个选项 CutMaxIterations 指定 intlinprog 迭代切割生成的次数上界。

有关切割生成算法(也称为割平面方法)的详细信息,请参阅 Cornuéjols·的论著 [6];有关 clique 切割的详细信息,请参阅 Atamtürk、Nemhauser 和 Savelsbergh·的论著 [4]

使用启发式方法求出可行解

为了得到目标函数的上界,分支定界过程必须求得可行点。分支定界过程中,LP 松弛问题的解可能是整数可行的,可用于改进原始 MILP 的上界。某些方法能够在分支定界之前或期间更快地找到可行点。intlinprog 在根节点上以及一些分支定界迭代过程中使用这些方法。这些方法是启发式的,意味着它们是可能成功但也可能失败的算法。

启发式方法可以是初始点启发式方法,它们帮助求解器求得初始或新的整数可行解。启发式方法也可以是改进点启发式方法,它们从整数可行点开始,尝试找到更好的整数可行点,即目标函数值更低的点。intlinprog 改进点启发式方法有 'rins''rss'、1-opt、2-opt 和引导潜水。

使用 'Heuristics' 选项设置 intlinprog 使用的启发式方法。选项包括:

选项描述
'basic'(默认值)

求解器使用不同参数运行两次舍入启发式方法,再使用不同参数运行两次潜水启发式方法,然后运行 'rss'。如果前期的启发式方法能得到足够好的整数可行解,则求解器不再运行其后的启发式方法。

'intermediate'

求解器使用不同参数运行两次舍入启发式方法,然后使用不同参数运行两次潜水启发式方法。如果有整数可行解,则求解器运行 'rins',然后运行 'rss'。如果 'rss' 求得新解,求解器将再次运行 'rins'。如果前期的启发式方法能得到足够好的整数可行解,则求解器不再运行其后的启发式方法。

'advanced'

求解器使用不同参数运行两次舍入启发式方法,然后使用不同参数运行两次潜水启发式方法。如果有整数可行解,则求解器运行 'rins',然后运行 'rss'。如果 'rss' 求得新解,求解器将再次运行 'rins'。如果前期的启发式方法能得到足够好的整数可行解,则求解器不再运行其后的启发式方法。

'rins' 或等效的 'rins-diving'

intlinprog 搜索当前最佳整数可行解点(如有)的邻域,以求得更好的新解。请参阅 Danna、Rothberg 和 Le Pape·的论著 [8]。当您选择 'rins' 时,求解器使用不同参数运行两次舍入启发式方法,再使用不同参数运行两次潜水启发式方法,然后运行 'rins'

'rss' 或等效的 'rss-diving'

intlinprog'rins' 理念和局部分支理念整合,以混合方式搜索整数可行解。当您选择 'rss' 时,求解器使用不同参数运行两次舍入启发式方法,再使用不同参数运行两次潜水启发式方法,然后运行 'rss'。如果前期的启发式方法能得到足够好的整数可行解,则求解器不再运行其后的启发式方法。这些设置执行与 'basic' 相同的启发式方法。

'round'

intlinprog 取节点处松弛问题的 LP 解,并以尝试保持可行性的方式舍入整数分量。当您选择 'round' 时,求解器在根节点上使用不同参数运行两次舍入启发式方法,然后使用不同参数运行两次潜水启发式方法。此后,求解器仅在一些分支定界节点上运行舍入启发式方法。

'round-diving'

求解器的工作方式与 'round' 相似,但求解器还在一些分支定界节点上运行潜水启发式方法(在舍入启发式方法的基础上),而不仅限于根节点。

'diving'

intlinprog 使用类似于分支定界步骤的启发式方法,但只沿树的一个分支向下,而不创建其他分支。此单分支使得算法能够快速下“潜”到树的片段,因此命名为“潜水”。当前,intlinprog 按照以下顺序使用六种潜水启发式方法:

  • 向量长度潜水

  • 系数潜水

  • 小数潜水

  • 伪代价潜水

  • 线搜索潜水

  • 引导式潜水(当求解器已找到至少一个整数可行点时适用)

潜水启发式方法通常选择一个应该取整数值、但当前解为小数的变量。然后,启发式方法引入一个强制变量取整数值的边界,并再次求解相关联的松弛 LP。各种潜水启发式方法之间的主要区别在于如何选择要定界的变量。请参阅 Berthold 的论著·[5],第 3.1 节。

'none'

intlinprog 不搜索可行点。求解器只选取它在分支定界搜索中遇到的任何可行点。

'intermediate''advanced' 之间的主要区别在于 'advanced' 在分支定界迭代期间更频繁地运行启发式方法。

除了上表之外,当 Heuristics 选项为 'basic''intermediate''advanced' 时,还会运行以下启发式方法。

  • ZI 取整 - 每当算法解出一个松弛 LP 时,此启发式方法就会运行。该启发式方法遍历每个带小数的整数变量并尝试将其移至邻近的整数,不影响在其他约束下的可行性。有关详细信息,请参阅 Hendel [9]

  • 1-opt - 每当算法找到新的整数可行解时,此启发式方法就会运行。该启发式方法在降低目标函数值的同时遍历每个整数变量并尝试将其移至邻近的整数,不影响在其他约束下的可行性。

  • 2-opt - 每当算法找到新的整数可行解时,此启发式方法就会运行。2-opt 查找影响同一约束的所有整数变量对组,这意味着它们在 AAeq 约束矩阵的同一行中有非零项。对于每个对组,2-opt 选取一个整数可行解,并使用所有四个可能的移动(上-上、上-下、下-上和下-下)向上或向下移动变量对组的值,寻找具有更好的目标函数值的可行相邻解。该算法通过计算满足约束的对组中每个变量的最大移位大小(相同幅值)来测试每个整数变量对组,同时改进目标函数值。

在启发式方法阶段开始时,intlinprog 运行平凡启发式方法,除非 Heuristics'none' 或者您在 x0 参量中提供初始整数可行点。平凡启发式方法检查以下各点的可行性:

  • 全部为零

  • 上界

  • 下界(如果非零)

  • “锁定”点

“锁定”点仅针对所有变量的上界和下界有限的问题定义。每个变量的“锁定”点是其上界或下界,按如下方式进行选择。对于每个变量 j,计算线性约束矩阵 A(:,j) 中对应正条目的数量,并减去对应负条目的数量。如果结果为正值,则使用该变量的下界 lb(j)。否则,使用该变量的上界 ub(j)。“锁定”点尝试满足每个变量的最大数量的线性不等式约束,但不一定可行。

在每个启发式方法都获得一个可行解后,intlinprog 调用输出函数和绘图函数。请参阅intlinprog 输出函数和绘图函数语法

如果包含 x0 参量,intlinprog 将在 'rins' 中和引导潜水启发式方法中使用该值,直到找到更好的整数可行点。因此,当您提供 x0 时,您可以通过将 'Heuristics' 选项设置为 'rins-diving' 或使用 'rins' 的其他设置来获得满意的结果。

分支定界

分支定界方法构造一系列尝试收敛到 MILP 解的子问题。子问题给出关于解 fTx 的一系列上界和下界。第一个上界是任何可行解,第一个下界是松弛问题的解。关于上界的讨论,请参阅使用启发式方法求出可行解

线性规划中所述,线性规划松弛问题的任何解都比 MILP 解具有更低的目标函数值。此外,任何可行点 xfeas 都满足

fTxfeasfTx

因为 fTx 是所有可行点中最小的。

在这种情况下,节点是具有以下特征的 LP:它具有与原始问题相同的目标函数、边界和线性约束,但没有整数约束,并对线性约束或边界作出特定改变。根节点是没有整数约束且线性约束或边界也不发生变化的原始问题,这意味着根节点是初始松弛 LP。

从起始边界开始,分支定界方法通过从根节点产生分支来构造新子问题。分支步骤采用启发式方法,遵循以下规则之一。每个规则都基于这样的理念:约束一个变量,使之小于或等于整数 J,或者大于或等于 J+1,从而拆分问题。当 xLP 中对应于 intcon 所指定整数的项不是整数时,会出现这两个子问题。在此处,xLP 是松弛问题的解。以 J 为变量的下限(向下舍入),以 J+1 为上限(向上舍入)。由此产生的两个问题的解大于或等于 fTxLP,因为这两个问题具有更多约束。因此,此过程可能会提高下界。

分支定界方法的性能取决于基于何种规则选择要拆分的变量(分支规则)。您可以在 BranchRule 选项中设置算法所用的规则,这些规则如下:

  • 'maxpscost' - 选择具有最大伪代价的小数变量。

     伪代价

  • 'strongpscost' - 类似于 'maxpscost',但对于每个变量,求解器不会将伪代价初始化为 1,而是仅在伪代价具有更可靠的估计值后,才尝试对变量进行分支。为了获得更可靠的估计值,求解器执行以下操作(请参阅 Achterberg、Koch 和 Martin 的论著·[2])。

    • 对所有潜在分支变量(当前为小数但应为整数的变量)排序,依据是这些变量当前基于伪代价的得分。

    • 从得分最高的变量开始,基于当前分支变量运行两个松弛线性规划(前提是该变量尚未用于分支计算)。求解器使用这两个解来更新当前分支变量的伪代价。求解器可以提前停止此过程,以节省选择分支的时间。

    • 继续在列表中选择变量,直到当前基于伪代价的最高得分经连续 k 个变量保持不变,其中 k 是内部选择的值,通常在 5 到 10 之间。

    • 对基于伪代价得分最高的变量进行分支。求解器可能已在先前的伪代价估算过程中基于此变量计算了松弛线性规划。

    由于额外的线性规划解,'strongpscost' 分支的每次迭代都比默认的 'maxpscost' 花费更长时间。但是,分支定界迭代的数量通常会减少,因此 'strongpscost' 方法总体上可以节省时间。

  • 'reliability' - 类似于 'strongpscost',但 'reliability' 不是仅对未初始化的伪代价分支运行松弛线性规划,而是对每个变量运行多达 k2 次规划,其中 k2 是小整数,如 4 或 8。因此,与 'strongpscost' 相比,'reliability' 的分支速度更慢,但分支定界迭代可能更少。

  • 'mostfractional' - 选择小数部分最接近 1/2 的变量。

  • 'maxfun' - 选择目标向量 f 中最大的绝对值所对应的变量。

在算法分支后,有两个新节点需要探查。算法使用以下规则之一在所有可用节点中选择要探查的节点:

  • 'minobj' - 选择目标函数值最低的节点。

  • 'mininfeas' - 选择整数不可行性之和最小的节点。这意味着对于节点中的每个整数不可行分量 x(i),选择 pipi+ 中较小的一个进行累加,其中

    pi = x(i) – ⌊x(i)⌋
    pi+ = 1 – pi

  • 'simplebestproj' - 选择具有最佳投影的节点。

     最佳投影

intlinprog 将原始问题的信息(例如目标函数的最大公约数,即 GCD)纳入考虑,从而跳过一些子问题的分析。

分支定界过程继续按部就班地生成子问题以进行分析,并丢弃那些不会改进目标函数上界或下界的子问题,直到满足以下停止条件之一:

  • 算法超过 MaxTime 选项指定的运行时间。

  • 目标函数的上下界之差小于 AbsoluteGapToleranceRelativeGapTolerance 容差。

  • 探查的节点数量超过 MaxNodes 选项指定的数量。

  • 整数可行点数超过 MaxFeasiblePoints 选项指定的数量。

有关分支定界过程的详细信息,请参阅 Nemhauser 和 Wolsey 的 [11] 和 Wolsey 的 [13]

HiGHS MILP 算法

HiGHS 概述

intlinprog "highs" 算法基于 HiGHS 开源软件。intlinprog 将 MATLAB® 格式的输入和选项转换为等效的 HiGHS 参量,并将返回的解转换为标准 MATLAB 格式。

算法概要

"highs" 算法执行以下步骤。

  1. 预求解

  2. 计算根节点

  3. 获取分支定界节点(如果没有,则停止)

  4. 重复,直到达到停止条件:

    1. 搜索,直到达到停止条件:

    2. 传播域

    3. 剪除节点,更新边界,如果检测到不可行性或达到 ObjectiveCutOff 选项值则退出

    4. 如果满足重启条件,则返回步骤 2

    5. 安装下一个节点:

      1. 选择并计算节点

      2. 如果计算后剪除了此节点,则返回步骤 5

      3. 为节点生成切割

      4. 如果域不可行,则切掉该节点,并将开放节点放入节点队列

      5. 更新基变量

      6. 转至步骤 4

预求解

通常,我们可以减少问题中的变量数量(x 的分量数量),并减少线性约束的数量。虽然执行这些缩减可能会花费求解器的时间,但它们通常会缩短求解的总时间,并使更大型的问题可求解。这些算法可以使解在数值上更加稳定。此外,这些算法有时可以检测不可行问题。

预求解步骤旨在消除冗余变量和约束,改善模型的尺度和约束矩阵的稀疏性,加强变量的边界,检测模型的原始和对偶不可行性。有关背景,请参阅 Andersen 和 Andersen 的论著 [3] 以及 Mészáros 和 Suhl 的论著 [10]

在混合整数规划预处理期间,intlinprog 分析线性不等式 A*x ≤ b 以及完整性约束,以确定是否有以下情形:

  • 此问题不可行。

  • 有些边界可以收紧。

  • 有些不等式是冗余的,因此可以忽略或删除。

  • 一些不等式可以得到加强。

  • 一些整数变量可以固定。

有关整数预处理的背景,请参阅 Achterberg 等人的论著 [1]

计算根节点

为了计算根节点,算法执行以下步骤。

  1. 检测对称性并简化问题。

  2. 评估根 LP。

  3. 生成并添加 LP 切割(请参阅切割生成)。

  4. 应用随机舍入。

  5. 生成并添加更多 LP 切割。

  6. 循环执行切割生成和启发式方法。

  7. 检查重启条件,如果有必要,则从步骤 2 重启。

在根节点计算完成后,算法将继续执行分支定界

切割生成

切割是 intlinprog 为问题增加的额外线性不等式约束。这些不等式尝试限制 LP 松弛的可行域,使其解更接近整数。有关切割生成算法(亦称割平面方法)的背景信息,请参阅 Cornuéjols 的论著 [6] 以及 Atamtürk、Nemhauser 和 Savelsbergh 的论著 [4]

下潜/潜水

为了找到整数可行点,intlinprog 使用类似于分支定界步骤的启发式方法,但只沿树的一个分支向下,而不创建其他分支。此单分支使得算法能够快速下“潜”到树的片段,因此命名为“潜水”。

潜水启发式方法通常选择一个应该取整数值、但当前解为小数的变量。然后,启发式方法引入一个强制变量取整数值的边界,并再次求解相关联的松弛 LP。各种潜水启发式方法之间的主要区别在于如何选择要定界的变量。请参阅 Berthold 的论著·[5],第 3.1 节。

随机舍入、RINS 和 RENS

为了找到新的整数可行点,intlinprog 搜索当前最佳整数可行解点(如有)的邻域,以求得更好的新解。请参阅 Danna、Rothberg 和 Le Pape·的论著 [8]。同样,为了找到新的整数可行点,intlinprog 取节点处松弛问题的 LP 解,并以尝试保持可行性的方式舍入整数分量。通过采取随机舍入步骤,intlinprog 有时可以找到新的可行点。RENS 表示松弛强制邻域搜索,它是寻找整数可行点的另一种搜索方法。请参阅 Berthold 的论著 [5]

分支定界

分支定界方法构造一系列尝试收敛到 MILP 解的子问题。子问题给出关于解 fTx 的一系列上界和下界。这些边界称为原始边界和对偶边界。对于最小化问题,第一个上界(原始)是任何可行解,第一个下界(对偶)是松弛问题的解。对于最大化问题,原始边界是下界,对偶边界是上界。如线性规划中所述,对于最小化问题,线性规划松弛问题的任何解都比 MILP 解具有更低的目标函数值。此外,任何可行点 xfeas 都满足

fTxfeasfTx(1)

因为 fTx 是所有可行点中最小的。

在这种情况下,节点是具有以下特征的 LP:它具有与原始问题相同的目标函数、边界和线性约束,但没有整数约束,并对线性约束或边界作出特定改变。根节点是没有整数约束且线性约束或边界也不发生变化的原始问题,这意味着根节点是初始松弛 LP。

从起始边界开始,分支定界方法通过从根节点产生分支来构造新子问题。分支步骤采用启发式方法,遵循以下规则之一。每个规则都基于这样的理念:约束一个变量,使之小于或等于整数 J,或者大于或等于 J+1,从而拆分问题。当 xLP 中对应于 intcon 所指定整数的项不是整数时,会出现这两个子问题。在此处,xLP 是松弛问题的解。以 J 为变量的下限(向下舍入),以 J+1 为上限(向上舍入)。由此产生的两个问题的解大于或等于 fTxLP,因为这两个问题具有更多约束。因此,对于最小化问题来说,此过程可能会提高下界。

在算法分支后,有两个新节点需要探查。intlinprog 通过将其目标函数值与当前全局边界进行比较,跳过对某些子问题的分析。

分支定界过程继续按部就班地生成子问题以进行分析,并丢弃那些不会改进目标函数上界或下界的子问题,直到满足以下停止条件之一:

  • 问题被证明不可行。

  • 目标函数值达到 ObjectiveCutOff 限制。

  • 算法超过 MaxTime 选项指定的运行时间。

  • 目标函数的上下界之差小于 AbsoluteGapToleranceRelativeGapTolerance 容差。

  • 探查的节点数量超过 MaxNodes 选项指定的数量。

有关分支定界过程的背景,请参阅 Nemhauser 的论著 [11] 和 Wolsey 的论著 [13]

迭代输出

当您通过将 Display 选项设置为默认值 "iter" 来选择迭代输出时,求解器会显示它的一些步骤。HiGHS 迭代输出比其他求解器的迭代输出更加广泛和复杂。此外,HiGHS 算法可以重新开始其分支定界搜索,从而导致迭代输出也重新开始。

要选择迭代输出,请使用以下代码:

options = optimoptions("intlinprog",Display="iter");
[x,fval,exitflag,output] = intlinprog(f,intcon,A,b,Aeq,beq,...
    lb,ub,options)

预备步.  迭代输出从显示“预求解”的结果开始。预求解算法通过识别和删除线性约束矩阵中的冗余行和列并执行问题的相关简化来降低原始问题的复杂性。例如,

Presolving model
18018 rows, 26027 cols, 248579 nonzeros
15092 rows, 24343 cols, 217277 nonzeros
Objective function is integral with scale 1

根节点计算.  根节点是问题的线性规划解,不考虑任何整数约束。对于最小化问题,根节点的目标函数值是包含整数约束的问题解的目标函数值的下界。对于最小化问题,上界(如果有)来自符合所有约束的一个可行点。如果还未找到可行点,则上界为 Inf

迭代输出显示预求解后问题的大小。

Solving MIP model with:
   15092 rows
   24343 cols (24343 binary, 0 integer, 0 implied int., 0 continuous)
   217277 nonzeros
  • binary 是二元变量的个数。

  • integer 是整数变量的个数。

  • implied int 是暗示为整数的变量的个数。例如,如果 x(1) 为整数且 x(1) + x(2) = 5,则暗示 x(2) 为整数。

  • continuous 是连续变量的个数。

变量总数是模型中的列数。

动态约束创建.  软件首先创建“动态约束”,在迭代输出中有三个标题:

  • 切割 - 活动切割的数量

  • inLp - LP 矩阵中非模型行的数量

  • Confl. - 冲突的数量

软件可以通过重新启动动态约束创建来进一步扩展约束,这可以通过从新状态开始创建过程来创建更多约束。

在开始分支定界过程之前的最后一步中,软件会报告对称性检测的结果以及找到的生成器和轨道体 (orbitope) 的数量。例如,以下是出现在预备步和动态约束创建阶段中的部分迭代输出:

        Nodes      |    B&B Tree     |            Objective Bounds              |  Dynamic Constraints |       Work      
     Proc. InQueue |  Leaves   Expl. | BestBound       BestSol              Gap |   Cuts   InLp Confl. | LpIters     Time
 
         0       0         0   0.00%   0               inf                  inf        0      0      0         0     1.5s
         0       0         0   0.00%   0               inf                  inf        0      0      5      4934     3.6s
…
         0       0         0   0.00%   0               inf                  inf     4630    553    289    140296   159.6s
 
0.0% inactive integer columns, restarting
Model after restart has 15090 rows, 24338 cols (24338 bin., 0 int., 0 impl., 0 cont.), and 217075 nonzeros
 
         0       0         0   0.00%   0               inf                  inf      550      0      0    140296   160.5s
…
         0       0         0   0.00%   0               inf                  inf     5602    524    260    277323   318.0s
 
6.2% inactive integer columns, restarting
Model after restart has 14185 rows, 22816 cols (22816 bin., 0 int., 0 impl., 0 cont.), and 200423 nonzeros
 
         0       0         0   0.00%   0               inf                  inf      524      0      0    277323   318.6s
…
         0       0         0   0.00%   0               inf                  inf     4683    535    525    408393   505.8s
 
Symmetry detection completed in 3.1s
Found 215 generators and 12 full orbitope(s) acting on 730 columns

有关对称性检测和轨道体的信息,请参阅 Hojny、Pfetsch 和 Schmitt 的论著 [7] 以及 Pfetsch 和 Rehn 的论著 [12]。软件在进行下文描述的分支定界步骤时继续添加动态约束。

分支定界.  分支定界方法构造一系列尝试收敛到 MILP 解的子问题。子问题给出关于解 fTx 的一系列上界和下界。对于最小化问题,第一个上界是任何可行解,第一个下界是松弛问题的解。

在分支定界过程中,intlinprog 给出以下迭代输出。

        Nodes      |    B&B Tree     |            Objective Bounds              |  Dynamic Constraints |       Work      
     Proc. InQueue |  Leaves   Expl. | BestBound       BestSol              Gap |   Cuts   InLp Confl. | LpIters     Time
        72       0         2   1.56%   0               inf                  inf     4695    535    738    667009   686.9s
…
 T     271     107        51   1.56%   0               449              100.00%     6051    271   1767    792786   776.8s
 T     279     107        53   1.56%   0               439              100.00%     6053    271   1794    793241   777.5s
…
 L    1223     538       295   1.98%   0               434              100.00%     6984    243   7628     1689k  1580.6s
…
      1321     539       333   1.98%   0               434              100.00%     7029    243   8628     1898k  1650.6s
 
Restarting search from the root node
Model after restart has 13947 rows, 22426 cols (22426 bin., 0 int., 0 impl., 0 cont.), and 194633 nonzeros
 
      1323       0         0   0.00%   0               434              100.00%      243      0      0     1902k  1653.5s
      1323       0         0   0.00%   0               434              100.00%      243     76     10     1905k  1655.7s
…
      1694     173        52   0.00%   0               434              100.00%     9411    318   2220     3205k  2584.3s
 B    1710     167        55   0.00%   0               433              100.00%     9415    318   2263     3207k  2586.2s
      1726     224        56   0.00%   0               433              100.00%     9999    378   2307     3237k  2608.7s

最左边的一列显示代码,指示如何为输出中的该行找到新可行点:

    • L - 在原始启发式方法中求解子 MIP 问题时

    • T - 在树搜索期间,计算节点时

    • B - 在分支期间

    • H - 通过启发式方法

    • P - 在启动期间,求解 MIP 之前

    • C - 通过中心舍入

    • R - 通过随机舍入

    • S - 求解 LP 时

    • F - 通过可行性泵

    • U - 基于无界 LP

完成.  迭代输出结束时会显示算法停止的原因和结果摘要。

Solving report
  Status            Time limit reached
  Primal bound      14
  Dual bound        0
  Gap               100% (tolerance: 0.01%)
  Solution status   feasible
                    14 (objective)
                    0 (bound viol.)
                    1.7763568394e-15 (int. viol.)
                    0 (row viol.)
  Timing            7200.02 (total)
                    3.08 (presolve)
                    0.00 (postsolve)
  Nodes             5830
  LP iterations     9963775 (total)
                    2657448 (strong br.)
                    324908 (separation)
                    2140011 (heuristics)
 
Solver stopped prematurely. Integer feasible point found.
 
Intlinprog stopped because it exceeded the time limit, options.MaxTime = 7200 . The intcon variables are integer within tolerance,
options.ConstraintTolerance = 1e-06.
  • Status - 迭代停止的原因

  • Primal bound - 对于最小化问题,显示目标函数值的上界;对于最大化问题,显示目标函数值的下界

  • Dual bound - 对于最大化问题,显示目标函数值的下界;对于最大化问题,显示最小化问题的上界

  • Gap - 原始边界和对偶边界之间的相对间隙

  • Solution status

    • 解的状态

    • 目标函数值,标注为 (objective)

    • 解对变量边界的最大违反值,标注为 (bound viol.)

    • 整数类型变量与整数值的最大违反值,标注为 (int. viol.)

    • 解对线性约束的最大违反值,标注为 (row viol.)

  • Timing - 各个求解阶段的计时,以秒为单位

  • Nodes - 探查的节点数

  • LP iterations - 各阶段及总共的线性规划迭代次数

参考

[1] Achterberg, T.,Bixby, R., Gu, Z., Rothberg, E., and Weninger, D. Presolve Reductions in Mixed Integer Programming. INFORMS J. Computing 32(2), 2019, pp. 473–506. Available at https://doi.org/10.1287/ijoc.2018.0857.

[2] Achterberg, T., T. Koch and A. Martin. Branching rules revisited. Operations Research Letters 33, 2005, pp. 42–54. Available at https://opus4.kobv.de/opus4-zib/files/788/ZR-04-13.pdf.

[3] Andersen, E. D., and Andersen, K. D. Presolving in linear programming. Mathematical Programming 71, pp. 221–245, 1995.

[4] Atamtürk, A., G. L. Nemhauser, M. W. P. Savelsbergh. Conflict graphs in solving integer programming problems. European Journal of Operational Research 121, 2000, pp. 40–55.

[5] Berthold, T. Primal Heuristics for Mixed Integer Programs. Technischen Universität Berlin, September 2006. Available at https://opus4.kobv.de/opus4-zib/files/1029/Berthold_Primal_Heuristics_For_Mixed_Integer_Programs.pdf.

[6] Cornuéjols, G. Valid inequalities for mixed integer linear programs. Mathematical Programming B, Vol. 112, pp. 3–44, 2008.

[7] Hojny, C., Pfetsch, M. E., Schmitt, A. Extended formulations for column-constrained orbitopes. TU Darmstadt, Department of Mathematics, Research Group Optimization, Dolivostr. 15, 64293 Darmstadt, June 2017. Available at https://optimization-online.org/2017/06/6092/.

[8] Danna, E., Rothberg, E., Le Pape, C. Exploring relaxation induced neighborhoods to improve MIP solutions. Mathematical Programming, Vol. 102, issue 1, pp. 71–90, 2005.

[9] Hendel, G. New Rounding and Propagation Heuristics for Mixed Integer Programming. Bachelor's thesis at Technische Universität Berlin, 2011. PDF available at https://opus4.kobv.de/opus4-zib/files/1332/bachelor_thesis_main.pdf.

[10] Mészáros C., and Suhl, U. H. Advanced preprocessing techniques for linear and quadratic programming. OR Spectrum, 25(4), pp. 575–595, 2003.

[11] Nemhauser, G. L. and Wolsey, L. A. Integer and Combinatorial Optimization. Wiley-Interscience, New York, 1999.

[12] Pfetsch, M. E. and Rehn, T. A computational comparison of symmetry handling methods for mixed integer programs. Mathematical Programming Computation (2019) 11:37–93. Available at https://mpc.zib.de/archive/2019/1/Pfetsch-Rehn2019_Article_AComputationalComparisonOfSymm.pdf.

[13] Wolsey, L. A. Integer Programming. Wiley-Interscience, New York, 1998.