我正在尝试构建一个基于 Bass 模型的优化程序(见下文):
- 决策变量:p、m、q
- 问题:最小 RMSE
- 约束:
- Ft = (p + q(C(t-1)/m)(m - C(t-1))
- Et = Ft - St
其中 C(t) 是累计销售额,St 是实际销售额,Ft 是 t 期的预测销售额,Et 是误差项。
我似乎无法弄清楚如何编写将这些值分配给新变量的约束(并且不一定使用比较运算符)......
目前,我创建了一个 Bass_F 函数来执行上面的等式 Ft,以及一个计算 rmse 的 rmse 函数。我还编写了以下代码(我的实际销售额是变量 y,其中有 4 条记录):
import docplex.mp.model as cpx
opt_model = cpx.Model(name="Bass")
opt_model.continuous_var(name = "p")
opt_model.continuous_var(name = "q")
opt_model.continuous_var(name = "m")
F = [None]*4
E = [None]*4
opt_model.add_constraint_(F[0] = p*m)
opt_model.add_constraint_(E[0] = F[0] - y[0])
for i in range(1,len(F)):
opt_model.add_constraints_(F[i] = Bass_F(F[i-1], p, q, m))
opt_model.add_constraints_(E[i] = F[i] - y[i])
显然这给了我一个错误,即:
opt_model.add_constraint_(F[0] = p*m) ^
SyntaxError: keyword can't be an expression
任何人都可以帮忙吗?提前致谢!