【发布时间】:2020-12-29 14:03:48
【问题描述】:
我正在尝试在我的 gekko 模型中使用 cspine 插值。在这个问题中,有一个发电厂、一个蒸汽轮机和一个电网。根据用于满足电网的容量,涡轮机将具有不同的效率。我试图实现一个gekko cspline,然后让模型调用它来根据功率产生为每个时间点提供效率。我无法让它工作。这在 Gekko 中可行吗?
from gekko import GEKKO
import numpy as np
import matplotlib.pyplot as plt
# Grid demand
t = np.linspace(0, 24, 24)
e_grid = 2.5*np.sin(t/24*(2*np.pi)) + 5
# Turbine Efficiency curve based on turbine capacity
pcap = np.linspace(.1, 1, 10) # %capacity
cap = 10*pcap
turb_eff = .75*np.sin(cap/11*np.pi)
# build model
m = GEKKO(remote=True)
m.time = t
Econs = m.Param(e_grid)
Egen = m.MV(value=5, lb=0, ub=10) # steam production
x = m.Param(value=cap)
y = m.Var()
Turb_spline = m.cspline(x, y, cap, turb_eff)
turb_out = m.Intermediate(Egen*Turb_spline)
m.Equation(Econs == turb_out)
m.Obj(Egen)
m.options.IMODE = 5
m.options.SOLVER = 3
m.solve()
plt.plot(t, Egen.value, label='gen')
plt.plot(t, Econs.value, label='cons')
plt.xlabel('time')
plt.ylabel('Energy')
plt.legend()
我可以使用np.polyfit 来实现它。然后,我能够将多项式添加到我的 gekko 模型中并运行它以正确调整效率。我使用以下代码而不是 cspline。
Ecap = m.Intermediate(Egen/cap)
m.Equation(turb_eff == p[0]*Ecap**5 + p[1]*Ecap**4 + p[2]*Ecap**3 + p[3]*Ecap**2 + p[4]*Ecap + p[5])
turb_out = m.Intermediate(Egen*turb_eff)
m.Equation(turb_out == Econs)
我仍然想知道如何使用 cspline,以便拟合多项式无法捕获的更复杂的模型。
【问题讨论】:
标签: python optimization gekko