当我在python中运行以下简单的NLOPT示例时:
import numpy as np
import nlopt
n = 2
localopt_feval_max = 10
lb = np.array([-1, -1])
ub = np.array([1, 1])
def myfunc(x, grad):
return -1
opt = nlopt.opt(nlopt.LN_NELDERMEAD, n)
opt.set_lower_bounds(lb)
opt.set_upper_bounds(ub)
opt.set_maxeval(localopt_feval_max)
opt.set_min_objective(myfunc)
opt.set_xtol_rel(1e-8)
x0 = np.array([0,0])
x = opt.optimize(x0)
我收到错误:
"ValueError: nlopt invalid argument"
这里引用的唯一建议是:
http://ab-initio.mit.edu/wiki/index.php/NLopt_Python_Reference
是下限可能大于上限,或者存在未知算法(这里都不是这种情况)。我正在运行以下版本的Python,NLOPT和NumPy
>>> sys.version
'3.4.0 (default, Apr 11 2014, 13:05:11) \n[GCC 4.8.2]'
>>> nlopt.__version__
'2.4.2'
>>> np.__version__
'1.8.2'
答案 0 :(得分:3)
通过将函数声明更改为
def myfunc(x, grad):
return -1.0
一切正常。所以NLopt无法处理返回python integer
而不是float
的目标
我觉得NLopt应该能够将整数目标函数值转换为float
。如果不是这样,那么至少应该提出TypeError
而不是ValueError: nlopt invalid argument
。
答案 1 :(得分:0)
我收到此错误是因为我的目标函数返回类型为numpy.float128所以我通过将返回类型更改为 numpy.float64
来修复错误