纸浆中的条件约束

2024-05-04 04:39:06 发布

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

我有以下使用纸浆的优化模型

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_italianwhitefield_other约束时,模型将不会运行

status = model.solve()

这将返回一个PulpSolverError: PuLP: Error while executing glpsol.exe

我对最后两个约束的逻辑是y变量将小于或等于x变量。因此,如果y是1,那么x也是1,但是x可以是1,而y不必是1

我读过关于大M方法的文章,但不确定它是否适用于我的模型


Tags: in模型modelbinfoodblockindianother
1条回答
网友
1楼 · 发布于 2024-05-04 04:39:06

似乎解算器(或者可能是来自纸浆的接口)不喜欢以数字开头的约束名称。将有问题的约束替换为:

model += (y['koramangala_5th_block_bin'] <= x['italian_bin'], 'fifth_block_italian')

或者任何其他避免前导数字的变化都应该解决这个问题

我不知道这个错误的实际来源,但在过去使用重复变量名的情况下也出现过类似的错误。我就这个问题提出了一个GitHub issue,现在似乎有一个修复它的承诺,因此可能值得您在github页面上提交一个关于这个约束命名问题的问题

相关问题 更多 >