Gurobi使用教程

1.Gurobi使用的一般框架

from gurobipy import *
try:
m=Model('modelname') except GurobiError:
print('Error reported')

2.Gurobi读取数据求解

假设给定三个文件,分别是categories.txt,foodcost.txt以及nutritionvalues.txt,分别存放每天营养摄取的上限和下限,每种食物的价格以及每种食物所含的营养成分,其中categories.txt中的数据如下(注意文件最后有换行):

calories 1800 2200
protein 91 1.00E+100
fat 0 65
sodium 0 1779

读取该文件的代码如下:

file = open("./categories.txt","r")   #设置文件对象
nutrition=[]
maxNut={}
minNut={}
for line in file.readlines(): #依次读取每行
line = line.strip('') #去掉每行头尾空白
line = line[:-1] #去掉换行符,也可以不去,这样最后一个数据要求也要换行
str1=line.split(" ")[0]
nutrition.append(str1)
str2=line.split(" ")[1]
minNut[str1]=float(str2)
str3=line.split(" ")[2]
maxNut[str1]=float(str3) print(nutrition)
print(minNut)
print(maxNut)
print(minNut['fat'])
[print(minNut[x]) for x in nutrition]
file.close()

foodcost.txt中的数据如下(文件最后有换行):

hamburger 2.49
chicken 2.89
hotdog 1.50
fries 1.89
macaroni 2.09
pizza 1.99
salad 2.49
milk 0.89
icecream 1.59

读取该文件的代码如下:

file = open("./foodcost.txt","r")   #设置文件对象
food=[]
cost={}
for line in file.readlines(): #依次读取每行
line = line.strip('') #去掉每行头尾空白
line = line[:-1] #去掉换行符,也可以不去,这样最后一个数据要求也要换行
print("读取的数据为: %s" % (line))
str1=line.split(" ")[0]
food.append(str1)
str2=line.split(" ")[1]
cost[str1]=float(str2)
print(cost)
file.close()

nutritionvalues.txt中的数据如下(文件最后有换行)

410
420
560
380
320
320
320
100
330
24
32
20
4
12
15
31
8
8
26
10
32
19
10
12
12
2.5
10
730
1190
1800
270
930
820
1230
125
180

读取该文件的代码如下:

file = open("./nutritionvalues.txt","r")   #设置文件对象
nutritionval=[]
food=['hamburger','chicken','hotdog','fries','macaroni','pizza','salad','milk','icecream']
for line in file.readlines(): #依次读取每行
line = line.strip('') #去掉每行头尾空白
line = line[:-1] #去掉换行符,也可以不去,这样最后一个数据要求也要换行
print("读取的数据为: %s" % (line))
str1=line.split(" ")[0]
nutritionval.append(str1)
print(nutritionval)
nutritionvalue={}
i=0
for x in nutrition:
for y in food:
nutritionvalue[y,x]=float(nutritionval[i])
i=i+1
print(nutritionvalue[y,x])
for x in food:
for y in nutrition:
print(nutritionvalue[x,y])
file.close()

因此最后程序为

from gurobipy import *
import numpy as np
file = open("./categories.txt","r") #设置文件对象
nutrition=[]
maxNut={}
minNut={}
for line in file.readlines(): #依次读取每行
line = line.strip('') #去掉每行头尾空白
line = line[:-1] #去掉换行符,也可以不去,这样最后一个数据要求也要换行
str1=line.split(" ")[0]
nutrition.append(str1)
str2=line.split(" ")[1]
minNut[str1]=float(str2)
str3=line.split(" ")[2]
maxNut[str1]=float(str3) file.close() file = open("./foodcost.txt","r") #设置文件对象
food=[]
cost={}
for line in file.readlines(): #依次读取每行
line = line.strip('') #去掉每行头尾空白
line = line[:-1] #去掉换行符,也可以不去,这样最后一个数据要求也要换行
str1=line.split(" ")[0]
food.append(str1)
str2=line.split(" ")[1]
cost[str1]=float(str2) file.close() file = open("./nutritionvalues.txt","r") #设置文件对象 nutritionval=[]
food=['hamburger','chicken','hotdog','fries','macaroni','pizza','salad','milk','icecream']
for line in file.readlines(): #依次读取每行
line = line.strip('') #去掉每行头尾空白
line = line[:-1] #去掉换行符,也可以不去,这样最后一个数据要求也要换行
str1=line.split(" ")[0]
nutritionval.append(str1) nutritionvalue={}
i=0
for x in nutrition:
for y in food:
nutritionvalue[y,x]=float(nutritionval[i])
i=i+1 file.close() def printSolution():
if m.status == GRB.Status.OPTIMAL:
print('\nCost: %g' % m.objVal)
print('\nBuy:')
buyx = m.getAttr('x', buy)
for f in food:
if buy[f].x > 0.0001:
print('%s%g' % (f, buyx[f]))
else:
print('No solution') try:
m=Model('modelname')
buy=m.addVars(food,name="buy")
m.setObjective(buy.prod(cost),GRB.MINIMIZE)
m.addConstrs(
(quicksum(nutritionvalue[f,c]*buy[f] for f in food)==
[minNut[c],maxNut[c]]
for c in nutrition),"_"
)
m.write("diet.lp")#写入lp文件
m.optimize()
printSolution()
except GurobiError:
print('Error reported')

Python3+Gurobi使用教程(一)的更多相关文章

  1. Python3.x爬虫教程:爬网页、爬图片、自己主动登录

    林炳文Evankaka原创作品. 转载请注明出处http://blog.csdn.net/evankaka 摘要:本文将使用Python3.4爬网页.爬图片.自己主动登录.并对HTTP协议做了一个简单 ...

  2. [教程]Tensorflow + win10 + CPU + Python3.6+ 安装教程

    由于各种原因,清华镜像源已经彻底挂掉了,但是目前网上的各种教程基本上都是采取设置清华镜像源来加快下载速度,所以这给小白带来了很大的困扰!这里我将通过合理上网工具来直接下载源镜像. 注意:本次教程适用于 ...

  3. python3 字符串str 教程

    字符串可以用单引号或双引号来创建. Python 不支持单字符类型,单字符也在Python也是作为一个字符串使用. 例: var1 = 'Hello World!' var2 = "Pyth ...

  4. python3操作mysql教程

    一.下载\安装\配置 1. python3 Python3下载网址:http://www.python.org/getit/ 当前最新版本是python3.2,下载地址是 http://www.pyt ...

  5. 18年selenium3+python3+unittest自动化测试教程(下)

    第六章 自动化测试进阶实战篇幅 1.自动化测试实战进阶之网页单选性别资料实战 简介:讲解使用selenium修改input输入框和单选框 2.自动化测试之页面常见弹窗处理 简介:讲解使用seleniu ...

  6. 18年selenium3+python3+unittest自动化测试教程(上)

    第一章 自动化测试课程介绍和课程大纲 1.自动化测试课程介绍 简介:讲解什么是自动化测试和课程大纲讲解,课程需要的基础和学后的水平 python3.7+selenium3 pycharm 第二章自动化 ...

  7. Python3.x安装教程及环境变量配置

    python3.x安装 1.直接到官网https://www.python.org/下载,安装就可以了. 2.安装比较简单,点exe文件一直下一步就可以了(注意:安装的时候有个选择是否添加环境变量,这 ...

  8. python3快速入门教程错误和异常

    Python 中(至少)有两种错误:语法错误(syntax errors)和异常(exceptions). 语法错误 语法错误又称作解析错误: >>> while True prin ...

  9. 安装python3的详细教程

    环境:CentOS 7 1. 安装依赖环境 # yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-dev ...

随机推荐

  1. zabbix-server端监控MySQL服务

    Zabbix 监控MySQL数据库 为server.zabbix,com 添加服务模块 创建MySQL服务图形 Server.zabbix.com 服务器操作 [root@server ~]# cd ...

  2. jenkins 展示报告

    1.下载插件 HTML Publisher plugin 2.设置说明 3.展示css 下载插件 (1).Startup Trigger: 可实现在Jenkins节点(master/slave)启动时 ...

  3. Day 07 -02 拷贝 浅拷贝 深拷贝

    必考 存一个值还是多个值 一个值:整型/浮点型/字符串 多个值:列表/元祖/字典/集合 有序or 无序 有序:字符串/列表/元祖 无序:字典/集合 可变or 不可变 可变:列表/字典/集合 不可变:整 ...

  4. Could not find result map java.util.HashMap

    Could not find result map java.util.HashMap 找不到结果图java.util.HashMap MyBatis 找不到返回的 'resultMap'!把resu ...

  5. Ubuntu下安装curl和corn

    Ubuntu下安装curl sudo apt install curl Ubuntu下安装cron apt-get install cron

  6. [POJ3233]Matrix Power Series 分治+矩阵

    本文为博主原创文章,欢迎转载,请注明出处 www.cnblogs.com/yangyaojia [POJ3233]Matrix Power Series 分治+矩阵 题目大意 A为n×n(n<= ...

  7. nginx 查看每秒有多少访问量

    nginx访问量统计 1.根据访问IP统计UV awk '{print $1}' access.log|sort | uniq -c |wc -l 2.统计访问URL统计PV awk '{print ...

  8. iOS给label加入下划线

    UILabel *myLabel = [[UILabelalloc] ,, , )]; NSMutableAttributedString *content = [[NSMutableAttribut ...

  9. 一个人的旅行 HDU杭电2066【dijkstra算法 || SPFA】

    pid=2066">http://acm.hdu.edu.cn/showproblem.php? pid=2066 Problem Description 尽管草儿是个路痴(就是在杭电 ...

  10. poj_1185状压dp

    用二维数组写了好久,失败啊.. #include<iostream> #include<string.h> #include<cstdio> #include< ...