Я занимаюсь оптимизацией проекта и столкнулся с очень странной ошибкой в scipy. После нескольких раз выполнения целевой функции ее вектор параметров волшебным образом превращается в двумерный массив (но предполагается, что он все время является одномерным массивом) без какой-либо явной инструкции.
Кто-нибудь когда-либо сталкивался с тем же самым?
Возможно, это баговая ошибка или я должен еще раз проверить свой код?
Я имею в виду, что если в моем коде что-то не так, я не вижу причин, по которым это произошло после того, как несколько итераций были правильно выполнены
каждый раз, когда вызывается целевая функция, я печатаю x и ее форму. Это код внутри целевой функции
def objective(x, some, other, parameters..):
print("current x",x)
print("current x.shape",x.shape)
some code here...
score = calculate_objective_function(some_parameters_here...)
return -score
А вот что случилось
current x [-2322.83367669 13868.03814803 0. ]
current x.shape (3,)
0
current x [-2322.83367669 13868.03814803 0. ]
current x.shape (3,)
1
current x [-2321.83367669 13868.03814803 0. ]
current x.shape (3,)
2
current x [-2324.45171069 13868.03814803 0. ]
current x.shape (3,)
3
current x [-2322.83367669 13868.03814803 0. ]
current x.shape (3,)
4
current x [-2323.45171067 13868.03814803 0. ]
current x.shape (3,)
5
current x [-2322.45171069 13868.03814803 0. ]
current x.shape (3,)
6
current x [[-2322.8237272 13868.03814803 0. ]]
current x.shape (1, 3)
Traceback (most recent call last):
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/optimization_image.py", line 692, in <module>
solution = minimize(objective,x0,method='Powell',args= additional_and_point_cloud, callback= callback_fun)
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/lib/python3.5/site-packages/scipy/optimize/_minimize.py", line 590, in minimize
return _minimize_powell(fun, x0, args, callback, **options)
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/lib/python3.5/site-packages/scipy/optimize/optimize.py", line 2612, in _minimize_powell
tol=xtol * 100)
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/lib/python3.5/site-packages/scipy/optimize/optimize.py", line 2398, in _linesearch_powell
alpha_min, fret, iter, num = brent(myfunc, full_output=1, tol=tol)
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/lib/python3.5/site-packages/scipy/optimize/optimize.py", line 2109, in brent
res = _minimize_scalar_brent(func, brack, args, **options)
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/lib/python3.5/site-packages/scipy/optimize/optimize.py", line 2141, in _minimize_scalar_brent
brent.optimize()
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/lib/python3.5/site-packages/scipy/optimize/optimize.py", line 1992, in optimize
fu = func(*((u,) + self.args)) # calculate new output value
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/lib/python3.5/site-packages/scipy/optimize/optimize.py", line 2397, in myfunc
return func(p + alpha*xi)
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/lib/python3.5/site-packages/scipy/optimize/optimize.py", line 326, in function_wrapper
return function(*(wrapper_args + args))
File "/home/mingzhe/PycharmProjects/ZebraFinder/venv/optimization_image.py", line 550, in objective
centroid = image_coordinate_from_world_coordinate(np.array([x[0],x[1]]),scale_factor,min_point_world)
IndexError: index 1 is out of bounds for axis 0 with size 1
Process finished with exit code 1
скриншот с ошибкой
ОБНОВЛЕНИЕ: проблема решена ответом @HYRY. Моя функция подсчета очков возвращает матрицу 1 * 1, а не скалер. После заброса он работает как положено.