如何将纸浆决策变量的输出打印成矩阵格式

2024-04-27 17:30:18 发布

您现在位置:Python中文网/ 问答频道 /正文

我想将模型的解导出为矩阵形式,从而将变量添加到Soln中,但关键错误。请帮忙解决这个问题

或者,请建议将解决方案导出为m*n表格格式的任何其他方法

KeyError                                  Traceback (most recent call last)
<ipython-input-52-c86dd2a00da5> in <module>()
     82 for i in range (1,Box+1):
     83   for j in range (1, Pallet+1):
---> 84     Soln[i][j]=x[i][j]
     85 
     86 
KeyError: 1


from pulp import *
import numpy as np
Box=6
Pallet=6
Variable_range=Box*Pallet
x = {}

from pulp import LpMaximize, LpProblem, LpStatus, lpSum, LpVariable
# Define the model
model = LpProblem(name="Container Loading", sense=LpMaximize)

# Define the decision variables

#Decision variables X
for i in range(1, Box+1):
    for j in range (1,Pallet+1):
      x[(i,j)] = pulp.LpVariable('x' + str(i) + '_' + str(j), 0, 1, LpBinary)

# Add constraints

#constraint for restricting unique number of boxes based on orientation
for i in range (1, (Box//2)+1):
     for j in range (1,Pallet+1):
       model += x[(i*2-1,j)] + x[(i*2,j)] <= 1 

#print (model)
#Set the objective
model += lpSum(x.values())

# Solve the optimization problem
status = model.solve()

Soln= [[0]*Pallet]*Box
for i in range (1,Box+1):
  for j in range (1, Pallet+1):
    Soln[i][j]=x[i][j]  # Error in this line


print(Soln)

Tags: theinfromimportboxformodelrange
1条回答
网友
1楼 · 发布于 2024-04-27 17:30:18
Soln= np.zeros((Box,Pallet))
print (Soln[5][5])
for i in range (1,Box+1):
  for j in range (1, Pallet+1):
    value=x[(i,j)].value()
    Soln[i-1][j-1]=value

这个修改给了我预期的输出

相关问题 更多 >