I'm trying to use scipy.optimize.minimize.
I've tried multiple "multivariate" methods that don't seem to actually take multivariate data and derivatives. Can someone tell me how I can make the multivariate part of the solver actually work?
Here's an example:
My main function the following (typical length for N is 3):
input guess is a x0=np.array([1,2,3])
the optimization function returns:
def calc_f3d(...):
f3d = np.ones((np.max([3,N]),1)
.... do some assignments to f3d[row,0] ....
return np.linalg.norm(f3d) # numpy.array that's 3x1
The jacobian returns a Nx3 matrix:
def jacob3d(...):
df = np.ones((np.max([3,N]),3))
... do some assignments to df[row,col]
return df # note numpy.array that's 3x3
The optimize call is:
OptimizeResult = optimize.minimize(
fun=tdcalc.calc_f3d,
x0=ract,
jac=tdcalc.jacob3d,
method='BFGS',
args=(operdata,),
tol=1.0e-8,
options={'maxiter': 40000, 'xtol':1e-8}) <--- ops change based on whether using Newton-CG or BFGS
When I use BFGS, I get:
Traceback (most recent call last):
File "./tdoa_calc.py", line 664, in <module>
options={'maxiter': 40000, 'gtol':1e-8})
File "/usr/lib64/python2.7/site-packages/scipy/optimize/_minimize.py", line 348, in minimize
return _minimize_bfgs(fun, x0, args, jac, callback, **options)
File "/usr/lib64/python2.7/site-packages/scipy/optimize/optimize.py", line 779, in _minimize_bfgs
old_fval, old_old_fval)
File "/usr/lib64/python2.7/site-packages/scipy/optimize/linesearch.py", line 95, in line_search_wolfe1
c1=c1, c2=c2, amax=amax, amin=amin, xtol=xtol)
File "/usr/lib64/python2.7/site-packages/scipy/optimize/linesearch.py", line 147, in scalar_search_wolfe1
alpha1 = min(1.0, 1.01*2*(phi0 - old_phi0)/derphi0)
ValueError: The truth value of an array with more than one element is ambiguous. Use a.any() or a.all()
When I use Newton-CG, I get:
Traceback (most recent call last):
File "./tdoa_calc.py", line 655, in <module>
options={'maxiter': 40000, 'xtol':1e-8})
File "/usr/lib64/python2.7/site-packages/scipy/optimize/_minimize.py", line 351, in minimize
**options)
File "/usr/lib64/python2.7/site-packages/scipy/optimize/optimize.py", line 1320, in _minimize_newtoncg
eta = numpy.min([0.5, numpy.sqrt(maggrad)])
File "/usr/lib64/python2.7/site-packages/numpy/core/fromnumeric.py", line 1982, in amin
out=out, keepdims=keepdims)
File "/usr/lib64/python2.7/site-packages/numpy/core/_methods.py", line 14, in _amin
out=out, keepdims=keepdims)
ValueError: setting an array element with a sequence.