*本文主要记录和分享学习到的知识,算不上原创

*参考文献见链接

本文主要简述了求解MIP问题的两大类(精确求解和近似求解),或者更细致地,三大类方法(精确算法,ε-近似算法和启发式算法)。由于暂时不太熟悉ε-近似算法,所以在这个版块我大部分只会涉及到精确算法和启发式算法。

目录

  MIP问题

  MIP求解方法

MIP问题

MIP问题,即混合整数规划问题(Mixed integer programming)。

首先我们来简单回顾一下线性规划问题。

线性规划问题

线性规划问题指的是满足:

(1)目标函数是线性函数;

(2)约束条件是线性等式或不等式;

的优化问题。通常是求最小化目标函数或最大化目标函数。

我以下提到的线性规划问题,如果没有特殊说明,指的是最小化目标函数。注意:最小化目标函数与最大化目标函数可以相互转换,没有实质上的区别。

线性规划问题

  →整数规划问题

    →0-1 问题

  →混合整数规划问题

线性规划问题,根据对变量的限制,可以更细地区分出:
(1)整数规划问题:指的是变量是整数的线性规划问题。

它将连续的线性规划跳转到离散的整数规划。需要说明的是求解整数规划的难度比求解线性规划的难度要大很多,尤其是当问题的规模很大时。

(2)0-1规划问题:指的是变量只能取值0或1的线性规划问题。

它是整数规划中特殊的一种。

(3)混合整数规划问题:指的是所有变量中有些变量可以取值连续,有些变量只能取整数值的线性规划问题。

混合整数规划问题

根据混合整数规划问题(MIP)的定义,可以概括出其一般形式:

MIP求解方法

MIP的求解方法可以分为:精确求解和近似求解两大类,如下图:

我们简单谈一谈精确求解和近似求解的区别:

(1)精确求解的目标是求得最优解(global optimal solution),但作为代价求解的过程需要花很长时间(exponential time),所以更适合于规模比较小的MIP问题。

(2)近似求解并不要求求得最优解,而是希望能在短时间内求得较优解(suboptimal solution)

近似求解,实际上可以理解成用时间换质量的一种求解思想。

近似求解又可以分为两种大类:

(1)ε-approximation:ε-近似算法要求在短时间内(in polynomial time)求得次优解(suboptimal solution),并且可以保证解的优秀程度(bound on the degree of suboptimality)

对于最小化问题而言,一个ε-近似算法在多项式时间内得到的解ZH满足:

ZH≤(1+ε)Z*

其中,Z*表示该问题的最优解。

(2)metaheuristics:启发式算法往往能在短时间内(empirically fast)获得较优解(suboptimal solution),但不能保证解的优秀程度(without a gurantee of its quality)。由于启发式算法通常求解速度快,适用于规模中等或规模大的MIP问题,所以企业中常常使用启发式算法求解问题。

*精确算法和启发式算法并不是完全分割的,比如Cplex利用branch and cut思想求解整数规划时,可以调用HeuristicCallback,而variable neighborhood search、local braching等启发式算法在求解大规模问题时可以调用Cplex求解局部最优解。

MIP求解方法总结的更多相关文章

  1. Machine Learning系列--隐马尔可夫模型的三大问题及求解方法

    本文主要介绍隐马尔可夫模型以及该模型中的三大问题的解决方法. 隐马尔可夫模型的是处理序列问题的统计学模型,描述的过程为:由隐马尔科夫链随机生成不可观测的状态随机序列,然后各个状态分别生成一个观测,从而 ...

  2. 用CSS画小猪佩奇,你就是下一个社会人! js将“I am a coder”反转成 “coder a am I”,不许用split,join,subString,reverse;求解方法三

    用CSS画小猪佩奇,你就是下一个社会人!   欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:江志耿 | 腾讯TEG网络工程师 我是佩奇,哼,这是我的弟弟乔治,呱呱,这是我的妈妈,嚯 ...

  3. 02(e)多元无约束优化问题- 梯度的两种求解方法以及有约束转化为无约束问题

    2.1 求解梯度的两种方法 以$f(x,y)={{x}^{2}}+{{y}^{3}}$为例,很容易得到: $\nabla f=\left[ \begin{aligned}& \frac{\pa ...

  4. C语言实现定积分求解方法

    求定积分的方法有很多种,下面是我总结的几种比较常用的方法. #include <stdio.h> #include <stdlib.h> #include <math.h ...

  5. 最近公共祖先(LCA)的三种求解方法

    转载来自:https://blog.andrewei.info/2015/10/08/e6-9c-80-e8-bf-91-e5-85-ac-e5-85-b1-e7-a5-96-e5-85-88lca- ...

  6. 组合数C(n,m)的四种求解方法

    转自:文章 1.暴力求解 C(n,m)=n*(n-1)*...*(n-m+1)/m!,(n<=15): int CF(int n,int m) { ,i,j; ;i--) ans*=i; ;i- ...

  7. N!(N的阶乘)最末位非0的求解方法

    问题是求关于N!的最后一位非0位, 如3!=6,最后一位非0位为6, 5!=120, 最后一位非0位为2.怎么样快速的求出最后一位非0位呢? 最朴素的想法就是先求出N!的结果,再求出结果的最后一位非0 ...

  8. low-rank 的相关求解方法 (CODE) Low-Rank Matrix Recovery and Completion via Convex Optimization

    (CODE) Low-Rank Matrix Recovery and Completion via Convex Optimization 这个是来自http://blog.sina.com.cn/ ...

  9. [POJ1050] To the Max 及最大子段和与最大矩阵和的求解方法

    最大子段和 Ο(n) 的时间求出价值最大的子段 #include<cstdio> #include<iostream> using namespace std; int n,m ...

随机推荐

  1. 记录一下filter

    filter是什么,如它的字面意思,就是拦截器.它可以在request到达相关资源之前,比如servlet之前先处理requeset,也可以拦截或处理从某个资源比如servlet发出的response ...

  2. vs2013修改为双击打开文件

    vs2012和vs2013默认是单击打开文件,让人突然就不习惯了,各种不爽. 修改方法: 工具-选项-环境-选项卡和窗口-不勾选允许在预览选项卡中打开新文件.

  3. .Net 遍历目录下第一层的子文件夹和子文件夹里的文件

    今天再完成一道任务的时候需要遍历得到所有txt文件,搜索很久终于得到了一个很方便的方法. foreach (string o in Directory.GetDirectories(@"D: ...

  4. CSS3基础知识学习

    CSS3动画例子展示 http://www.17sucai.com/pins/demoshow/13948 HTML5和CSS3特效展示 http://www.html5tricks.com/30-m ...

  5. 谈谈我理解的Http缓存机制

    前几天看到老铁们分享的面经,谈到 http 缓存机制的问题,痛下决心,一口气研究个明白,分享给大家. 前端的发展越来越迅速,能做的事情越来越多,承担的责任越来越重,通过了解 http 缓存机制,可以帮 ...

  6. fiddler+willow问题总结

    本文纯属用来记录自己学习过程中遇到的坑,如有朋友也遇到,可移步到这里查看是否为该问题导致. fiddler 安装不用说了,到官网直接去下载,自行下载最新版本 willow下载地址:http://qzo ...

  7. Azure 项目构建 – 托管静态网站

    本课程主要介绍了如何在 Azure 平台上快速构建和部署基于 Azure Web 应用的静态托管网站, 实践讲解如何使用 Azure 门户创建 Web 应用, 部署静态网站源代码,设置自定义域名等. ...

  8. Slacklining 2017/2/6

    原文 Get ready for a different kind of challenge What happens when mountain climbers take a day off?Ap ...

  9. python实现微信打飞机游戏(by crossin)

    # -*- coding: utf-8 -*- import pygame from sys import exit import random pygame.init() screen = pyga ...

  10. 获取显示设备的名称及PNPDeviceID

    实现效果: 知识运用: ManagementObjectSearcher类和ManagementObject类 实现代码: private void button1_Click(object send ...