我试图用python来解决一个关于GEKKO的优化问题,我试图用log和sqrt开发一些数学函数,我想我应该使用gekko运算符,而不是使用numpy或数学函数。我想知道如何使用gekko实现日志库2,而不是日志或log10。
gk = GEKKO()
gk.log(...) # work
gk.sqrt(...) # work
gk.log2(...) # does not work!错误:
AttributeError: 'GEKKO' object has no attribute 'log2'发布于 2020-10-29 15:22:34
相反,您可以使用以下规则更改日志库:
log2(x) = gk.log(x)/gk.log(2)您不能期望它实现所有的日志库。
发布于 2020-10-29 17:44:38
您可以在Gekko中创建一个log2函数,特别是当您需要在整个模型中多次使用它时。
def glog2(x):
return gk.log(x)/np.log(2) 下面是一个完整的脚本,它演示了新log2函数的使用,并显示了与Numpy log2函数的协议。

from gekko import GEKKO
import numpy as np
# compare with numpy
xnp = np.logspace(-1,4,100)
ynp = np.log2(xnp)
gk = GEKKO(remote=False)
x = gk.Param(xnp)
y,z = gk.Array(gk.Var,2)
# define a new log2 function
def glog2(x):
return gk.log(x)/np.log(2)
gk.Equation(y==glog2(x))
gk.options.IMODE=2; gk.solve(disp=False)
import matplotlib.pyplot as plt
plt.semilogx(xnp,ynp,'b-',lw=4,label=r'$y=\log_2(x)$ Numpy')
plt.semilogx(x.value,y.value,'r--',lw=2,label=r'$y=\log_2(x)$ Gekko')
plt.legend(); plt.xlabel('x'); plt.ylabel('y'); plt.grid(); plt.show()https://stackoverflow.com/questions/64592988
复制相似问题