【问题标题】:Minimize the objective function using PuLP使用 PuLP 最小化目标函数
【发布时间】:2019-02-12 04:07:41
【问题描述】:

我有这个等式

-0.19430381*clo + 0.02507341*vam + 0.13574366*sla + 0.01667444*so = 10

我需要找到 clo、vam、sla 的最小值,这样才能解出这个方程。我已经使用 PuLP 来查找值。

# declare your variables
clo = LpVariable("clo", 65, 80)
vam = LpVariable("vam", 63, 90)
sla = LpVariable("sla", 70, 80)
so = LpVariable("so", 75, 85)

# defines the problem
prob = LpProblem("problem", LpMinimize)

目标函数和约束写成

# defines the objective function to minimize
prob += -0.19430381*clo + 0.02507341*vam +  0.13574366*sla + 0.01667444*so-10 

#define Constraints
prob+= clo>=65
prob+= clo<=80
prob+= vam>=63
prob+= vam<=90
prob+= sla>=71
prob+= sla<=80
prob+= so>=75
prob+= so<=85

当我使用默认求解器求解时,它为 clo 取上限值 80,而为所有其他变量取下限值。目标函数值为负。

print (pulp.value(prob.objective))
-13.21204077

我希望这个目标函数的值为0。在这种情况下,我需要找到所有参数的值。参数的值也可以是浮点数。

【问题讨论】:

  • 根据您的需要添加对目标项的约束,使其为非负数或零。

标签: python optimization pulp


【解决方案1】:

所描述的问题是不可行的。

您希望实现以下等式约束:

-0.19430381*clo + 0.02507341*vam + 0.13574366*sla + 0.01667444*so == 10

以下列变量的上下界为准:

clo = LpVariable("clo", 65, 80)
vam = LpVariable("vam", 63, 90)
sla = LpVariable("sla", 70, 80)
so = LpVariable("so", 75, 85)

查看等式约束,如果我们想让右边尽可能大,我们会选择vam, sla, so尽可能大,clo尽可能小(因为它左侧有负系数)。

设置:clo=65; vam=90; sla=80; so=85 我们得到等式约束左侧的结果为:1.9036794499999987。任何其他值组合(在上限/下限内)都将导致更小的左侧 - 因此无法满足等式约束,它永远不会等于所需的右侧 10。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-12-04
    • 2021-09-08
    • 1970-01-01
    • 1970-01-01
    • 2016-09-13
    相关资源
    最近更新 更多