使用m.Array()
函数创建变量(或参数)array.np.prod()
和m.sum()
函数用于定义目标函数m.Maximize()
和等式m.Equation()
.
import numpy as np
from gekko import GEKKO
n = 5
m = GEKKO(remote=False)
x = m.Array(m.Var,n,value=1)
m.Maximize(np.prod([m.sqrt(xi) for xi in x]))
m.Equation(m.sum(x)==100)
m.solve(disp=False)
print(x)
解决方案:
[[20.0] [20.0] [20.0] [20.0] [20.0]]