Lingo解决优化问题

@

前言

前面,我们已经对Lingo有了一定的了解,但是要想真正的熟悉Lingo在解决优化问题中的强大之处,还需要不断加强相关训练,本文主要是使用Lingo来解决优化问题,该文的主要目的有以下三点:

  • 希望能够提升自己对Lingo的相关操作并加强对优化问题的思维模式
  • 方便日后对Lingo核心操作的回顾
  • 希望每一位到来的朋友能够有所收获

若您对Lingo的安装及基本操作不是很了解,可暂且移步:Lingo安装Lingo基本操作

一、优化模型介绍

优化模型主要有三个基本要素:决策变量、目标函数、约束条件。其一般形式如下:

$$

opt \ \ \ \ f(x) \

s.t \ \ \ \ h_i(x)=0,\ i=1,2,\cdots,m \

g_j(x)\leq0,\ j=1,2,\cdots,l

$$

$opt$ 是“optimize”的缩写,表示“最优化”,一般为 $min$ 或 $max$,$f(x)$ 表示目标函数,$s.t.$ 是“subject to”的缩写“受约束于”,$h_i(x), g_i(x)$ 则表示约束条件,其中 $x$ 表示优化模型的决策变量。

二、运输问题

2.1 问题描述

Question:有三个生产地和四个销售地,其生产量、销售量及单位运费如表所示,求总运费最少的运输方案以及总运费。

2.2 问题分析

由题意,我们不难看出优化模型的决策变量是每个生产地向各个销售地运输的货量,即 $s_{ij}$。运输的总费用由各个产地向各个销售地运输所需费用之和,一个产地可以向多个销售地运输货物,一个销售地亦可接受多个产地的货物,所以可知优化模型中的目标函数是运输的总费用,即 $W=\sum3_{i=1}\sum4_{j=1}s_{ij}x_{ij}$。除此之外,该目标函数受到两个限制,即优化模型的约束条件:

  • 生产地限制:每个生产地的运输量理应小于产生量,$\sum_{j=1}^4s_{ij}\leq a_i$
  • 销售地限制:每个销售地接受的货物理应等于销售量,$\sum_{i=1}^3x_{ij}=b_j$

2.2 优化模型构建

有以上问题分析,为求出总运费最小的方案,我们可以构建该问题的优化模型如下:

$$

min \ \ \ \ \sum3_{i=1}\sum4_{j=1}s_{ij}x_{ij} \

s.t. \ \ \ \ \sum_{j=1}^4s_{ij}\leq a_i ;;\ \sum_{i=1}^3x_{ij}=b_j \ ;\ s_{ij}\geq0 \ ;

$$

2.3 模型求解

求解的Lingo代码如下:

sets:
supply/1..3/: s; !定义运输集,集中的每个元素都有对应的属性,即运输量s;
demand/1..4/: d; !定义需求集,集中的每个元素都有对应的属性,即需求量d;
link(supply, demand): p, x; !定义link衍生集,每个元素中都有两个属性,运费p,运输量x;
endsets data:
s = 30 25 21; !定义数据集s,表示生产量;
d = 15 17 22 12; !定义数据集d,表示销售量;
p = 6 2 6 7 !定义数据集p,表示生产地向销售地所对应的运费;
4 9 5 3
8 8 1 5;
enddata min = @sum(link(i,j): p(i,j)*x(i,j)); !目标函数;
@for(supply(i): @sum(demand(j): x(i,j)) <= s(i)); !生产地限制约束条件;
@for(demand(j): @sum(supply(i): x(i,j)) = d(j)); !销售地限制约束条件;

2.4 求解结果

运行如上所示Lingo程序,我们可以得到如下结果:

通过上图展示,我们可以得到运输的最佳方案以及最小运费161个单位。运输方案图示如下:

三、待更新

Lingo解决最优化问题的更多相关文章

  1. 使用Lingo增强JMS

    虽然activemq+jencks的jms轻量级解决方案已经很好地在psa中work了,尤其spring的JmsTemplate使得代码更简单,但是还是存在问题. 问题来自暑期做psa的时候,link ...

  2. DeepLearning之路(三)MLP

    DeepLearning tutorial(3)MLP多层感知机原理简介+代码详解 @author:wepon @blog:http://blog.csdn.net/u012162613/articl ...

  3. sicp第1章

    牛顿迭代法求平方: (define (sqrt-iter guess x) (if (good-enough? guess x) guess (sqrt-iter (improve guess x) ...

  4. convex optimization

    ##凸优化总结所有这些想法基本是来自于书籍[convex optimization](http://book.douban.com/subject/1888111/),主要包括凸优化的基本理论,主要的 ...

  5. 【机器学习实战】第6章 支持向量机(Support Vector Machine / SVM)

    第6章 支持向量机 <script type="text/javascript" src="http://cdn.mathjax.org/mathjax/lates ...

  6. 机器学习之支持向量机(三):核函数和KKT条件的理解

    注:关于支持向量机系列文章是借鉴大神的神作,加以自己的理解写成的:若对原作者有损请告知,我会及时处理.转载请标明来源. 序: 我在支持向量机系列中主要讲支持向量机的公式推导,第一部分讲到推出拉格朗日对 ...

  7. 从线性模型(linear model)衍生出的机器学习分类器(classifier)

    1. 线性模型简介 0x1:线性模型的现实意义 在一个理想的连续世界中,任何非线性的东西都可以被线性的东西来拟合(参考Taylor Expansion公式),所以理论上线性模型可以模拟物理世界中的绝大 ...

  8. AI从业者需要应用的10种深度学习方法

    https://zhuanlan.zhihu.com/p/43636528 https://zhuanlan.zhihu.com/p/43734896 摘要:想要了解人工智能,不知道这十种深度学习方法 ...

  9. 支持向量机-完整Platt-SMO算法加速优化

    完整版SMO算法与简单的SMO算法: 实现alpha的更改和代数运算的优化环节一模一样,唯一的不同就是选择alpha的方式.完整版应用了一些能够提速的方法. 同样使用Jupyter实现,后面不在赘述 ...

随机推荐

  1. 对于char *s1 和 char s2[] 的认识

    对于char *s1 和 char s2[] 认识有误区(认为无区别),导致有时出现“难以理解”的错误. char *s1 = "hello"; char s2[] = " ...

  2. ubuntu 摄像头软件

    sudo apt-get install cheese

  3. February 22 2017 Week 8 Wednesday

    There is only one happiness in life, to love and be loved. 生命中只有一种幸福,爱与被爱. If you think you are not ...

  4. ABAP类的文档生成工具

    本文介绍的工具原理和JavaDoc类似,位于software component BBPCRM 1. 在ABAP类里新建一个名为CLASS_DOCU的私有方法. 然后把所有的注释写在这个方法源代码的前 ...

  5. codeforces 797 E. Array Queries【dp,暴力】

    题目链接:codeforces 797 E. Array Queries   题意:给你一个长度为n的数组a,和q个询问,每次询问为(p,k),相应的把p转换为p+a[p]+k,直到p > n为 ...

  6. 静态路由解决双外卡,PC做路由器的实现

    1,曾经医院,有两个网卡,一个内,一个外,但都有网关(192.168.1.246. 192. 168.6.1) 这样同一时候开启就会出现网络不通. 当时并没有细究原因. 这次医院信息化项目上马,我学到 ...

  7. Mac 导入maven项目详解

    1.打开Eclipse,选择Help->Install New SoftWare2.点击add 地址输入:http://m2eclipse.sonatype.org/sites/m2e,name ...

  8. 【[NOI2016]区间】

    发现自己的离散化姿势一直有问题 今天终于掌握了正确的姿势 虽然这并不能阻挡我noip退役爆零的历史进程 还是先来看看离散化怎么写吧,我以前都是这么写的 for(std::set<int>: ...

  9. 2springboot:快速创建springboot项目

    使用IDEA快速创建springboot项目流程: 创建新的项目选择 项目的命名以及包名 需要什么包就导入什么包 进行测试的单元 <dependency> <groupId>o ...

  10. 文件上传之FileItem使用

    一.介绍 FileItem类的常用方法: 1.boolean isFormField().isFormField方法用来判断FileItem对象里面封装的数据是一个普通文本表单字段(true),还是一 ...