我正在用 Gekko 循环解决非线性优化问题,并希望使用先前的解决方案来初始化下一个解决方案。我用下面的代码创建了一个简化的问题来显示问题。
from gekko import GEKKO
m = GEKKO() # Initialize gekko
# Initialize variables
x1 = m.Var(value=1,lb=1,ub=5)
x2 = m.Var(value=5,lb=1,ub=5)
# Equations
m.Equation(x1==x2*2)
m.Equation(x1**2+x2**2==10)
m.Obj(x1*x2) # Objective
m.options.solver=1
m.solve(disp=False) # Solve
print('Iterations: ' + str(m.options.iterations))
print(x1.value[0], x2.value[0])
print('Objective: ' + str(m.options.objfcnval))
m.solve(disp=False) # Solve again
print('Iterations: ' + str(m.options.iterations))
print(x1.value[0], x2.value[0])
print('Objective: ' + str(m.options.objfcnval))
控制台打印:
Iterations: 5
2.8284271334 1.4142135667
Objective: 4.0000000245
Iterations: 5
2.8284271334 1.4142135667
Objective: 4.0000000245
在“再次求解”尝试之前,x1
和x2
返回初始猜测值 1 和 5。我试过x1.value = x1.value
了,但这又回来了RecursionError: maximum recursion depth exceeded
。从 Gekko 的先前解决方案中初始化值的正确方法是什么?