Построение "Bang-bang" траекторий движения между двумя точками для футбола роботов
Bang-bang (англ. "двухпозиционная") траектория - траектория, во время движения по которой вектор ускорения имеет два возможных значения
1. Длинные траектории, случай "Призма"
Название обусловлено видом графика зависимости проекций скорости на координатные оси от времени
Как мы видим, обе проекции скорости на оси меняются одновременно
1.1 Постановка задачи
Робот сначала разгоняется c начальной скорости до максимальной скорости с ускорением за время , после едет с максимальной скоростью время и тормозит с ускорением за время до конечной скорости . За всё движение робот перемещается на .
- Дано: (модуль максимального ускорения), (модуль максимальной скорости),
- Найти: (восстановить, зная модули),
1.2 Реализация
Красные участки - разгон; синий участок - постоянная скорость; фиолетовые точки - начало и конец.
Поиск будем производить "вращая" вектор . Остальные неизвестные восстановим из формул (аналогично для ):
Для получения разделим длину прямого участка (всё перемещение без перемещения при разгоне/торможении) на скорость его прохождения
Направление вектора находим троичным поиском (он же тернарный). Для этого строим траекторию используя промежуточное значение , и считаем расстояние от конца получившейся траектории до необходимой конечной точки. Именно это расстояние мы будем стремиться минимизировать.
Переберём 10 значений и вокруг минимального из них будем искать 0. Это необходимо для того, чтобы троичный поиск не остался в локальном минимуме. Троичный поиск ведём до тех пор, пока промежуток возможного угла не окажется малым (нуля это расстояние никогда не достигнет)
1.3 Анализ ответа
Если конечное расстояние оказалось малым, то траектория найдена и мы можем смело возвращать её роботу или выводить на экран. Если же расстояние явно показывает, что траекторию построить не удалось, то на это есть две причины:
- траектория с достижением максимальной скорости существует, но мы не смогли её обнаружить
- такую траекторию построить невозможно, то есть общее перемещение робота мало и у нас нет возможности разогнаться до максимальной скорости
Первый случай скучный, нужно лишь перезапустить алгоритм, увеличив количество перебираемый значений перед троичным поиском. Пока не будем тратить на него время работы программы и перезапустим код в случае если не удастся найти путь другими методами тоже. Второй случай уже требует новый алгоритм для создания траекторий, который мы рассмотрим далее
2. Короткие траектории, случай "Треугольник"
На этот раз название вновь связано с видом графика зависимости проекций скорости на координатные оси от времени
На этот раз на графике нет прямого участка из-за того, что робот не успевает разогнаться до максимальной скорости.
2.1 Постановка задачи
Робот разгоняется c начальной скорости до некоторой скорости с ускорением за время и сразу тормозит с ускорением за время до конечной скорости . За всё движение робот также перемещается на .
- Дано: (модуль максимального ускорения),
- Найти: (восстановить, зная модули) и
Задача усложнилась с предыдущего случая тем, что теперь мы не знаем модуль промежуточной скорости.
2.2 Реализация
Перебор угла для заданного модуля скорости. Красные участки - разгон; фиолетовые точки - начало и конец.
Поиск будем производить не только "вращая" вектор , но и перебирая модуль его скорости. Ускорения и время восстановим из вышеописанных формул (см. п. 1.2)
Будем перебирать модуль и отдавать его тому же алгоритму, что считал расстояние до цели для "трапеции"
Для поиска модуля также перебираем 10 значений на промежутке и выполняем поиск вокруг наименьшего
2.3 Анализ ответа
В случае нахождения пути заканчиваем алгоритм, но если путь не нашёлся, то вновь возвращаемся к двум случаям * траектория без достижения максимальной скорости существует, но мы не смогли её обнаружить * такую траекторию построить невозможно, то есть алгоритм с достижением максимальной скорости должен был построить маршрут
В обоих случаях нам необходимо прогнать оба алгоритма ещё раз, но рассматривая больше значений в начале, чтобы точно найти значение около минимума, которое явно будет меньше остальных.
3. Увеличение дискретизации перед троичным поиском
Для увеличения числа значений, которые мы будем перебирать перед троичным поиском будем передавать их число в качестве параметра функции. Если после первого прогона оба алгоритма для длинных и коротких траекторий не смогли найти траекторию, запустим первый из них увеличив на 10. Так алгоритмы смогут сделать ещё один пробег и найти маршрут. Больше двух раз прогонять все эти ресурсозатратные алгоритмы не имеет смысла, поэтому возвращаем None
Важно отметить, что это является решением проблемы невозможности построить путь, поэтому об оптимальности речи не идет.