Создание примеров:
Код: Выделить всё
import numpy as np
points = np.random.RandomState(42).rand(100,2)
Код: Выделить всё
z = np.array([[complex(*c) for c in points]]) # notice the [[ ... ]]
distance_matrix = abs(z.T-z)
Некоторые связанные вопросы:
Эта тема: Коммивояжер в scipy предоставляет код для поиска решения TSP. Однако он работает итеративно, поэтому, если количество точек для посещения велико, сценарий не выдаст решение за разумное время.
Эта тема: Как решить задачу кумулятивного путешествия Продавец. Проблема с использованием инструментов or в Python? не имеет кода ответа и не ориентирован на классический TSP.
Эта тема: Оптимизация алгоритма коммивояжера (алгоритм путешественника во времени) предоставляет итеративные решения проблемы (что означает плохое масштабирование )
Подробнее здесь: https://stackoverflow.com/questions/711 ... -in-python