使用pyomo和glpk解算器,我定义了以下目标规则:
def cost_rule(m):
return (sum(m.rd[i]*m.pRdImp*m.dt - m.vr[i]*m.pRdExp*m.dt for i in m.t) + m.cb + m.cPV + (150+10*m.kWp) )
m.cost = Objective(rule=cost_rule)
如果我知道在找到最小值后比较输出,我会得到不同的结果:
sum(m.rd[i]()*m.pRdImp()*m.dt() - m.vr[i]()*m.pRdExp()*m.dt() for i in t_t) + m.cPV() + m.cb() + (150+5*m.kWp())
Out[46]: 1136.468
m.cost()
Out[43]: 1173.178
(m.t和t_t是表示一年中小时数的范围集) 这是一个大约3%的误差,有什么想法可以从哪里来?如果我需要选择一个值,那么哪个值才是正确的
提前谢谢
表达方式不同。第一项中的最后一项是
(150+10*m.kWp)
,第二项中的最后一项是(150+5*m.kWp())
相关问题 更多 >
编程相关推荐