Странная ошибка, с которой столкнулся Сципи, есть мысли? - PullRequest
0 голосов
/ 05 июля 2019

Я занимаюсь оптимизацией проекта и столкнулся с очень странной ошибкой в ​​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, а не скалер. После заброса он работает как положено.

1 Ответ

0 голосов
/ 05 июля 2019

Возможно, возвращаемое значение оценки не является скалярным значением, например:

import numpy as np
from scipy import optimize

cnt = 0
def f(x):
    global cnt
    print(x.shape)
    cnt += 1
    if cnt < 10:
        return np.sum(x**2)
    else:
        e = np.full((1, 1), fill_value=np.sum(x**2))
        return e

optimize.minimize(f, [0, 0, 1], method="powell")
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...