如何在不使用exec的情况下生成PuLP变量和约束? [英] How do I generate PuLP variables and constrains without using exec?
问题描述
我已经使用PuLP库编写了以下Python代码,以使用Integer Programming公式解决背包问题.我正在使用字符串生成LpVariable命令并添加约束,然后使用eval执行它们.有没有办法不用eval来做到这一点?
I have written the following Python Code using the PuLP Library for solving the Knapsack Problem using the Integer Programming formulation. I am using strings to generate the LpVariable commands and add the constraints and then executing them with eval. Is there a way to do this without using eval?
from pulp import *
#Knapsack problem
items = input ('Enter the number of items :')
items = int(items)
#print('Enter %d items one by one')
print ('Enter {0} items profit one by one'.format(items))
obj = []
weight = []
knapweight = 0
for i in range(0,items):
print('Enter {0} item profit : '.format(i+1))
obj.append(input())
for i in range(0, items):
print('The profit at {0} is {1}'.format(i, obj[i]))
print ('\nEnter {0} items weights one by one'.format(items))
for i in range(0, items):
print('Enter {0} item weight'.format(i+1))
weight.append(input())
for i in range(0, items):
print('The profit at {0} is {1}'.format(i, weight[i]))
print ('\nEnter the weight of the knapsack :')
knapweight = input()
print ('The weight of the knapsack is : {0}'.format(knapweight))
#generating variables
for i in range(0, items):
str = 'x{0} = LpVariable("x{1}", cat=\'Binary\')'.format(i+1,i+1)
print (str)
exec(str)
prob = LpProblem('Knapsack', LpMaximize)
print ('\nDynamic Generaion\n')
#weight constraint generation
str = "prob += "
for i in range(0, items):
if i == (items-1):
str = str + weight[i] + '*x{0}'.format(i+1)
else:
str = str + weight[i] + '*x{0}'.format(i+1) + '+'
str = str + '<=' + knapweight
exec(str)
print(str)
#objective function generation
str = "prob += "
for i in range(0, items):
if i == (items-1):
str = str + obj[i] + '*x{0}'.format(i+1)
else:
str = str + obj[i] + '*x{0}'.format(i+1) + '+'
exec(str)
print(str)
status = prob.solve()
print(LpStatus[status])
print ('\nThe values of the variables : \n')
for i in range(0, items):
print('x{0} = {1}'.format(i+1, value(eval('x{0}'.format(i+1)))))
推荐答案
关键是要认识到可以拥有一个对象(可以在列表或字典中说一个),而不必明确绑定到对象名称.您可以创建一个对象,将其附加到列表中,并且只能将其引用为 some_list [2]
.一旦您拥有了这种自由,您的代码就会变得更加简单.
The key is recognizing that it's okay to have an object -- say one in a list or a dictionary -- which you don't have explicitly bound to a name. You can make an object, append it to a list, and only ever refer to it as some_list[2]
. Once you allow yourself that freedom, your code can become much simpler.
在这里,我对输入进行了硬编码,因为这无关紧要:
Here I've hardcoded the inputs, because that doesn't matter:
from pulp import *
objs = [2,3,2,5,3]
weights = [1,2,2,1,3]
knapweight = 5
prob = LpProblem('Knapsack', LpMaximize)
xs = [LpVariable("x{}".format(i+1), cat="Binary") for i in range(len(objs))]
# add objective
total_prof = sum(x * obj for x,obj in zip(xs, objs))
prob += total_prof
# add constraint
total_weight = sum(x * w for x,w in zip(xs, weights))
prob += total_weight <= knapweight
status = prob.solve()
print(LpStatus[status])
print("Objective value:", value(prob.objective))
print ('\nThe values of the variables : \n')
for v in prob.variables():
print(v.name, "=", v.varValue)
这给了我
Optimal
Objective value: 10.0
The values of the variables :
x1 = 1.0
x2 = 1.0
x3 = 0.0
x4 = 1.0
x5 = 0.0
在这里,我正在列表理解中构建LpVariables
Here I'm building the LpVariables in the list comprehension
xs = [LpVariable("x{}".format(i+1), cat="Binary") for i in range(len(objs))]
然后将对象放在列表 xs
中.
where the objects then just live in the list xs
.
>>> xs
[x1, x2, x3, x4, x5]
>>> xs[3]
x4
>>> type(xs[3])
<class 'pulp.pulp.LpVariable'>
这篇关于如何在不使用exec的情况下生成PuLP变量和约束?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!