我有以下使用纸浆的优化模型
neighborhood_lst = [
'btm_bin',
'hsr_bin',
'jayanagar_bin',
'koramangala_5th_block_bin',
'jp_nagar_bin',
'marathahalli_bin',
'whitefield_bin',
'indiranagar_bin',
'bannerghatta_road_bin',
'bellandur_bin'
]
cuisines_lst = [
'north_indian_bin',
'chinese_bin',
'south_indian_bin',
'biryani_bin',
'fast_food_bin',
'street_food_bin',
'seafood_bin',
'continental_bin',
'andhra_bin',
'beverages_bin',
'italian_bin',
'other_bin'
]
# set up model
model = LpProblem(name='restaurant_cuisine_neigborhood', sense=LpMaximize)
# set variables
x = {i: LpVariable(name=f"x{i}", lowBound=0, cat='Binary') for i in cuisines_lst}
y = {i: LpVariable(name=f"y{i}", lowBound=0, cat='Binary') for i in neighborhood_lst}
# Set objective
model += 0.0267 * x['north_indian_bin'] + 0.0243 * x['chinese_bin'] + 0.0088 * x['south_indian_bin'] + \
0.0108 * x['biryani_bin'] + 0.0084 * x['fast_food_bin'] + 0.0022 * x['street_food_bin'] + \
0.0030 * x['seafood_bin'] + 0.0038 * x['continental_bin'] + 0.0036 * x['andhra_bin'] + \
0.0030 * x['beverages_bin'] + 0.0176 * x['other_bin'] + \
0.0011 * y['btm_bin'] + 0.0018 * y['hsr_bin'] + 0.0041 * y['jayanagar_bin'] + \
0.0039 * y['koramangala_5th_block_bin'] + 0.0005 * y['jp_nagar_bin'] + 0.0094 * y['marathahalli_bin'] + \
0.0012 * y['whitefield_bin'] + 0.0004 * y['indiranagar_bin'] + 0.0108 * y['bannerghatta_road_bin'] + \
0.0085 * y['bellandur_bin']
我对下面的约束条件有问题
# Add constraints
model += (lpSum(y.values()) == 1, 'neighborhood_selection')
model += (lpSum(x.values()) <= 4, 'cuisine_selection')
# If Indiranagar then must NOT be andhra food
model += (y['indiranagar_bin'] + x['andhra_bin'] <= 1, 'andhra_not_in_indirangar')
# If Koramangala 5th Block, then one must be Italian
model += (y['koramangala_5th_block_bin'] <= x['italian_bin'], '5th_block_italian')
# If Whitefield, then one must be Other
model += (y['whitefield_bin'] <= x['other_bin'], 'whitefield_other')
如果我只使用andhra_not_in_indirangar
约束,模型将运行并确定最佳解决方案。当我尝试添加5th_block_italian
和whitefield_other
约束时,模型将不会运行
status = model.solve()
这将返回一个PulpSolverError: PuLP: Error while executing glpsol.exe
我对最后两个约束的逻辑是y
变量将小于或等于x
变量。因此,如果y
是1,那么x
也是1,但是x
可以是1,而y
不必是1
我读过关于大M方法的文章,但不确定它是否适用于我的模型
似乎解算器(或者可能是来自纸浆的接口)不喜欢以数字开头的约束名称。将有问题的约束替换为:
model += (y['koramangala_5th_block_bin'] <= x['italian_bin'], 'fifth_block_italian')
或者任何其他避免前导数字的变化都应该解决这个问题
我不知道这个错误的实际来源,但在过去使用重复变量名的情况下也出现过类似的错误。我就这个问题提出了一个GitHub issue,现在似乎有一个修复它的承诺,因此可能值得您在github页面上提交一个关于这个约束命名问题的问题
相关问题 更多 >
编程相关推荐