В соавторстве с Юлией Филимоновой.
Введение
Представьте себе, что летите такой весь победитель на базу, бомб уже нет, и ничего не предвещает беды...
А тут, скажем, горочка из тумана/облаков выступает неожиданно, или, что несколько хуже, — вот это… И вам рады, но исключительно в качестве цели:
#поравалить — а вот как это делать с математическим уклоном сейчас и будем разбираться.
Да и вообще есть множество случаев, когда необходимо уклониться от неожиданно возникшей помехи/преграды, нашЛось, как говорят в Яндексе, например.
Оговорка для математиков. Изложение направлено скорее на объяснение принципов и понятность, а не на формальность и строгость. Почему так: если интересно - будет мотив разобраться с теорией дифференциальных игр, которая лежит в основе, и с первоисточниками, часть из которых перечислена в конце.
Часть первая — модель в «простых движениях»
Простые движения это не то о чём в попсе поют, а самая простая модель динамического объекта, выражаемая следующей дифференциальной моделью:
где , -управление ограничено (что логично, т.к. скорость не бесконечна), а — -мерное Евклидово пространство (для нашего примера, как видно, вполне достаточно двумерного). Множество — наша база, т.е. сюда мы хотим вернуться в целости и сохранности, — располагается в точке .
Что это нам даёт? Если проинтегрировать уравнение, то мы получим траекторию движения — прямую линию , то есть, куда направлено управление, туда и летим. Значит, при отсутствии помех вектор управления сонаправлен с вектором движения .
Плюс данной модели в её крайней простоте для анализа, минус — моделирует она только безынерционные движения, но это не очень страшно так как моделирование инерционных движений будет выглядеть (упрощённо) как:
и к моделям соответствующего типа мы перейдем чуть позже.
Описанная модель отражает наши динамические возможности. Добавим в нее противника , который всячески старается нам помешать:
Здесь аналогично ограниченное управление .
При этом мы заранее не знаем, где притаился противник, а он, при этом, знает всё и ждёт себе, пока мы подлетим поближе, для того чтобы при помощи своего управления достать нас множеством .
Поскольку наша цель — всё--таки попасть на , гарантированно уклонившись от , и мы должны знать от чего, собственно, мы уклоняемся, то рано или поздно помеху мы обнаружим. В случае безынерционного движения мы можем не знать о ней ничего до предпоследнего момента времени, так как в этом случае мы всегда можем направить вектор скорости (и, соответственно, траекторию) в сторону от помехи.
При этом, как можно заметить, помеха типа <<гора>> не самая страшная ситуация, так как она неподвижна, хотя и является большим препятствием, — хуже если противник подвижен, поэтому надо обсудить ещё пару моментов:
- чтобы иметь возможность уклоняться, мы должны обладать большими динамическими возможностями, чем противник, иначе рано или поздно нас поймают, то есть в некотором смысле должно быть меньше ;
- пусть множество помехи, которым управляет противник — выпуклое, иначе, если применять стратегию уклонения по нормали от множества помехи — можно и не уклониться.
Воспользовавшись приведенными выше эвристическими рассуждениями, посмотрим, как можно решить приведенную выше задачу при следующих условиях в пространстве :
Здесь — координаты объекта на плоскости,
Пусть объект начинает движение из точки
Ограничения на управления имеют вид
- — круг радиуса 1;
- — круг радиуса 0.9.
Первый игрок стремится перевести траекторию системы за конечное время на терминальное множество — круг радиуса 1 с центром в точке , избежав при этом попадания на множество помехи — круг радиуса 2 с центром в точке .
Время успешного завершения игры первым игроком .
Траектория движения системы и компоненты управления первого игрока показаны на следующих рисунках.
Траектория движения системы.
Зависимость первой компоненты управления от времени.
Зависимость второй компоненты управления от времени.
Данный подход, очевидно имеет несколько недостатков, а именно:
- большое количество переключений, что плохо с практической точки зрения, так как рывки между крайними значениями дают существенную нагрузку на органы управления;
- как следствие, вместо того, чтобы лететь к цели, мы тратим время на блуждания, связанные с уклонением от помехи и наведением на терминальное множество;
- непонятно, что делать, если мы подлетаем к помехе строго по нормали: уклонение будет проводиться в ту же точку, откуда наводились за шаг до этого — то есть алгоритм может зациклится;
- непонятно, что делать с инерционными объектами, так как эвристика, конечно, хороша, но реальность несколько сложнее.
Часть вторая — модель всё ещё в «простых движениях», но сокращается количество переключений
Ввиду того, что модель простая и позволяет нам двигаться по плоскости из любой точки в любую точку (это в дальнейшем будет являться существенным предположением, а пока просто берём на заметку), ничто не мешает нам рассуждать следующим образом.
Давайте думать на один шаг вперёд: если наша система сначала наводилась на цель, а на следующем шаге начала уклонятся, то можно найти точку, в которую система придёт через два шага, и наводиться сразу на неё как на промежуточную цель. Можем? По нашему предположению — ДА.
На том же примере посмотрим, что получается. Время успешного завершения игры первым игроком сократилось почти в три раза с до . Количество переключений тоже резко уменьшилось. Берём на заметку — думать хотя бы на шаг вперёд эффективно и вообще полезно для здоровья.
Траектория движения системы и компоненты управления первого игрока показаны на на следующих рисунках.
Траектория движения системы.
Зависимость первой компоненты управления от времени.
Зависимость второй компоненты управления от времени.
Часть третья — модель всё ещё в «простых движениях», но теперь решаем вопрос с приближением <<по нормали>>
Так как мы умеем уклоняться от одного множества в один момент времени, то ничто нам не мешает построить дополнительное множество таким образом, чтобы, уклоняясь от него, мы ( возможно с измельчением шага по времени) гарантированно через два шага попадали в точку, отличную от той, в которой находимся сейчас. И сделаем мы это следующим образом:
Построение дополнительного множества избегания для траектории.
То есть просто построим дополнительное множество, от которого будем уклоняться, содержащее в себе «проблемную» точку не как центр, а с некоторым смещением, как на рисунке.
Часть четвертая — математический базис
Для того, чтобы построить управления инерционными объектами необходимо всё таки погрузиться в теорию, так как простые эвристические рассуждения в этом случае работать перестают и, соответственно, необходимо подобрать теоретическую основу решения. Если у вас жёсткий приступ лени не хватает времени, то раздел можно, пропустить и воспользоваться сразу результатами, интересующиеся же — смотрим дальше.
В качестве основы будем использовать теорию дифференциальных игр, которые в нашей стране развивались Львом Семёновичем Понтрягиным [1] (если не знаете кто такой — обязательно почитайте, Личность с большой буквы, как говорится, таких уже не делают) и Красовским Николаем Николаевичем [2].
Для решения нам потребуются два множества:
- куда можно попасть первым игроком — множество достижимости первого игрока;
- откуда можно завершить преследование вторым игроком первого.
А также способ их построения, реализуемый на практике.
С первым множеством, при отсутствии помехи всё более или менее понятно, если можем построить его таким образом, чтобы включить конечное множество — значит игру завершим успешно, не сможем — значит игра точно не сможет быть завершена. Строится оно в теории следующим образом — для каждой точки начиная с начальной путём перебора всех доступных управлений строим множество в которое можем попасть через , после чего операцию повторяем. Выглядит довольно сложно, но для выпуклых множеств и линейных систем можно всё радикально упростить, используя аппарат выпуклого анализа, — опорные функции и введя соответствующие сетки [4]. Построение такого множества решает задачу наведения первого игрока, назовём её — задача А.
Наведение на множество $M$ в условиях отсутствия помехи.
Что касается второго множества — множества откуда второй игрок может поймать нас и от которого нам и нужно уклоняться, то здесь несколько сложнее — следите за пальцами:
- с одной стороны, если мы "приближаемся" к противнику, то ввиду превосходства наших возможностей, чем мы дальше от него тем вероятность нас поймать, — этому потом придётся дать строгое объяснение;
- с другой стороны — если мы "удаляемся" от противника, то ввиду того же самого нашего превосходства противник не сможет нас поймать в любом случае.
То есть что получается множество от которого мы уклоняемся должно быть с одной стороны большим (при приближении), а с дугой стороны (при удалении) может быть едва превышающим то, от которого необходимо уклониться?
Уклонение от множества .
Совпадение? Противоречие? Не думаю. Подобно Доку в "Назад в будущее" с его "пространственно-временным континуумом" вспомним, что у нас есть ещё одна переменная — время и будем трактовать термины "приближаемся" и "удаляемся" приведенные в кавычках как поведение системы вдоль траектории, что не всегда совпадает с прямолинейным движением и уж точно не характеризуется расстоянием в евклидовом пространстве. Зато временем движения до конкретной точки понятия "далеко-близко" и "приближаемся-удаляемся" характеризуются очень неплохо.
В этом случае давайте будем строить управление уклонения не от множества от которого нам надо уклоняться , а от множества в которое оно преобразуется (а оно уменьшится ввиду превосходства первого игрока) к моменту его приближение на соответствующее временной интервал в множеству — т.е. построим этакую воронку направленную к первому игроку своей узкой стороной и будем отталкиваться уже от неё. Построение такого множества в каждый момент игры и уклонение от него будет решает задачу уклонения первого игрока, назовём её — задача Б.
Соответственно общее управление управление первого игрока так, чтобы в каждый момент времени он решал только одну из этих подзадач.
Формализуем теперь движение нашего объекта , в --мерном евклидовом пространстве следующей системой дифференциальных уравнений:
где ; — выпуклые компакты из евклидовых пространств ; — постоянные матрицы, , что обеспечивает существование, единственность и продолжимость при всех решения задачи Коши.
Вектор находится в распоряжении первого игрока, вектор находится в распоряжении второго игрока.
Движение начинается при из начального состояния и протекает под воздействием измеримых по Лебегу функций .
В выделены некоторые непустые выпуклые замкнутые множества и . Множество является терминальным множеством первого игрока. Цель первого игрока — добиться выполнения включения при некотором . Множество является терминальным множеством второго игрока и множеством помехи первого игрока. Цель второго игрока — добиться выполнения включения при некотором . В момент первого попадания точки на игра считается успешно завершенной вторым игроком. Дополнительная задача первого игрока — избежать попадания точки на .
Игра считается успешно завершенной первым игроком в момент первого попадания точки на при условии, что для всех предыдущих моментов времени точка ни разу не попадала на . Таким образом, цели игроков не совпадают, и точка находится под воздействием противоборствующих управлений .
Будем отдельно рассматривать дифференциальную игру с точки зрения первого и второго игроков.
A: Предполагается, что первый игрок знает:
- динамические возможности конфликтно управляемого объекта , то есть матрицы , множества ;
- начальное состояние игры ;
Предполагается также, что первый игрок способен обнаружить множество не позднее чем за время , значению которого определим ниже.
Определим стратегию первого игрока как отображение, определенное на множестве произвольных измеримых функций , и обладающее следующим свойством: для произвольной измеримой , функция измерима по и .
Задача A: Найти начальные состояния , для которых первый игрок обладает такой стратегией, что она обеспечивает окончание игры для произвольной измеримой не позже некоторого конечного момента. Такие состояния будем называть решениями задачи A.
Б:Второй игрок обладает полной информацией о ходе игры.
Определим стратегию второго игрока как отображение, определенное на множестве произвольных измеримых функций , и обладающее следующим свойством: для произвольной измеримой , функция измерима по и .
Задача Б: Найти начальные состояния , для которых второй игрок обладает такой стратегией, что она обеспечивает окончание игры для произвольной измеримой не позже некоторого конечного момента. Такие состояния будем называть решениями задачи Б.
Будем считать, что , где — линейное подпространство пространства , — выпуклый компакт, . Аналогично , где — линейное подпространство пространства , — выпуклый компакт, . При этом — оператор ортогонального проектирования из в , . Данные построения нужны для того, чтобы учесть, что игра у нас в общем случае (а при наличии инерционных объектов это так и есть) ведётся в пространстве меньшей размерности чем размерность системы дифференциальных уравнений.
Подраздел 4.1. Достаточное условие разрешимости задачи уклонения первого игрока от множества
Рассмотрим задачу Б — задачу преследования вторым игроком первого и построим для неё множество точек, из которого данная задача будет иметь решение. Так вот, для подобного типа задач Понтрягин придумал способ построения нужного множества — альтернированная сумма — [3], [5]. Так вот альтернированная сумма мало того является выпуклым компактом, так ещё и -стабильно (т.е. позволяет строить нужные нам стратегии второго игрока), а также обеспечивает выполнение условия существования седловой точки маленькой игры [6, стр. 56] (что означает, что игра в принципе разрешима) — т.е. всё и сразу.
Из [6, стр. 69 — теорема 17.1] следует, что в этих условиях можно воспользоваться теоремой об альтернативе:
Для всякой начальной позиции и выбранного верно одно из двух утверждений:
1) Либо найдется стратегия , которая для всех движений обеспечит встречу за конечное время . То есть, в классе позиционных стратегий второго игрока разрешима задача преследования (задача Б).
2) Либо, в противном случае, найдется стратегия , которая для всех движений , обеспечит уклонение от множества -окрестности множества $N$ вплоть до момента времени . То есть, в классе позиционных стратегий первого игрока разрешима задача уклонения (задача А).
При этом, ввиду -стабильности множества на сновании [6, стр. 62 — теорема 15.1] получим, что условие:
является достаточным условием решения задачи уклонения первого игрока из начальной позиции от -окрестности множества в течение времени .
Если ресурсы первого игрока, определяемые множеством , превосходят ресурсы второго игрока, определяемые множествами и , то найдется такое время , что .
Существование момента , для которого выполнено включение , обеспечивает разрешимость задачи Б за время из диапазона .
То есть можно построить стратегию , удовлетворяющую условию:
Следовательно, для того, чтобы обеспечить уклонение от множества , необходимо проверять приведенное выше условие как для текущего момента времени , так и для всех последующих моментов времени на глубину .
Множество , построенное в виде:
характеризует минимальное расстояние между преследователем и убегающим в момент времени , на котором преследование может быть завершено успешно. Откуда в общем-то и следует, что обнаруживать помеху мы должны за такое время (не за расстояние), за которое сможем от неё уклониться, что логично.
И, если настоящие математики на некоторое время закроют глаза, так как следующее рассуждение является ооочень частным случаем, то на пальцах это выглядит следующим образом: пусть множество помехи у нас шарик радиуса 5, множество управления шарик радиуса 2, а помехи -- соответственно 1, тогда время за которое мы должны обнаруживать помеху никак не должно быть меньше 4.
Математики могут открывать глаза.
Аналогичным образом можно решить задачу наведения на множество в условиях отсутствия помехи. При этом достаточным условием наведения траектории системы на множество является условие:
Подраздел 4.2. Построение управления первого игрока для решения задачи А
Пусть первый игрок может заметить множество помехи не раньше, чем за время . Это означает, если ввести равномерное разбиения временного отрезка , что первый игрок может заметить помеху не раньше, чем за шагов по времени:
Тогда возможность перехвата вторым игроком первого (успешного завершения задачи Б) в момент определяется условием:
Здесь первый мы в момент времени проверяем, возможна ли поимка первого игрока на следующем шаге .
Будем строить управление первого игрока, считая, что выполнены следующие предположения.
На второго игрока наложены следующие ограничения:
второй игрок никогда не сможет достичь терминального множества :
в противном случае стратегия "закрыть собой" обеспечит победу второму игроку;
- начальная позиция игры не принадлежит множеству , откуда возможно успешное завершение задачи Б — преследования вторым игроком первого:
что гаратнирует нас от того, что мы при появлении откажемся внутри множества где нас поймают и игра потеряет всякий смысл.
Рассмотрим задачу уклонения первого игрока от множества отдельно от задачи наведения на целевое множество .
При этом, если для нашей игры выполнено приведенное выше предположение, то при любом начальном значении , можно показать, что существует такая стратегия уклонения, что расстояние между траекторией и множеством избегания может будет больше и зависеть только от хода игры, а не от её начального значения.
Что, переводя с математического на русский, означает, что в зависимости от параметров игры всегда существует ненулевое расстояние между нами и множеством из которого нас можно поймать.
При этом, в качестве стратегии уклонения можно выбрать управление экстремального сдвига, обеспечивающее, согласно теореме об альтернативе [6, стр. 69], уклонение от множества в виде:
где
Так как выполняются условия леммы 15.2 [6, стр. 65], то, повторяя её доказательство, получаем нужную оценку для минимального евклидового расстояния между траекторией и множеством , которая стремится к при измельчении шага разбиения по времени.
Рассмотрим теперь задачу наведения траектории системы на терминальное множество . При отсутствии каких-либо помех в виде множества и выполнении условия теоремы об альтернативе задача наведения разрешима, если начальная точка принадлежит множеству управляемости, а само управление наведения будет иметь вид:
Будем строить управление наведения--уклонения в следующем виде:
- определяем в ходе построения альтернированного интеграла, решающего для нашей системы задачу наведения;
- рассматриваем движение системы в момент , .
Проверяем для следующего шага пустоту пересечения:
- если множество достижимости системы из точки не пересекается с множеством , то первый игрок выбирает управление наведения;
- в противном случае первый игрок выбирает управление уклонения.
Отметим, что в общем случае условие окончания игры наведения может быть нарушено, т.е. , где , — это найденные ранее значения времени окончания игры и соответствующий ему альтернированный интеграл. В данном случае необходим пересчёт альтернированного интеграла Л.С. Понтрягина и поиск соответствующего ему нового времени окончания игры , -натуральное число.
Применяя описанную стратегию, первый игрок в каждый момент времени будет либо наводиться на терминальное множество , сокращая расстояние до него, либо уклоняться от множества помехи , не попадая внутрь него.
Поскольку множество — строго выпуклый компакт, то для его огибания по описанной стратегии потребуется конечное время, а теорема об альтернативе гарантирует уклонение от множества в течение конечного времени. Поскольку задача наведения в условиях отсутствия помехи имеет решение за конечное время, то общее время завершения игры тоже конечно. При этом
— время завершения игры не меньше времени наведения, а в общем случае оценить невозможно, хотя оно и существует.
Часть пятая — собираем всё вместе
Проверим теперь на практике, что даёт построенный способ управления сначала без учёта снижения колчества перекючений, а потом с учётом данной оптимизации. Для чего рассмотрим одну из типовых задач имеющих имя собственное — "Два крокодила", моделирующую движения двух инерционных объектов с разными динамическими параметрами. Соотвественно пусть теперь первый игрок стремится решить задачу А.
Соотвествующая система дифференциальных уравнений будет иметь вид:
Здесь — координаты объекта на плоскости, а — компоненты его скорости,
объект начинает движение из точки
Ограничения на управления имеют вид
Первый игрок стремится перевести траекторию системы за конечное время на терминальное множество
избежав при этом попадания на множество помехи
В случае если первый игрок не занимается снижением количества переключений, то время завершения игры будет
Траектория движения системы и компоненты управления первого игрока показаны на следующих рисунках.
Траектория движения системы.
Зависимость первой компоненты управления от времени.
Зависимость второй компоненты управления от времени.
В случае же использовани способа, обеспечивающего снижение количества переключений управления время успешного завершения игры первым игроком будет почти в трираза меньше:
а соответствующие траектории показаны на следующих рисунках.
Траектория движения системы.
Зависимость первой компоненты управления от времени.
Зависимость второй компоненты управления от времени.
На рисунках видно, что управление, полученное в ходе решения задачи описанным выше методом, обладает достаточно небольшим количеством переключений.
Выводы
Что в итоге получаем (если дочитали, конечно, до этого места), — "наивный" и "продвинутый" способы управления динамической моделью, позволяющие конструктивно строить управление зависящие исключительно от позиции (см. книги Н.Н. Красовcкого, А.И. Субботина и Л.С. Понтрягина), причем не обладая полными знаниями о помехе.
Исходники посмотреть можно здесь: репозитарий на GitHub
Предупреждаю сразу, что некоторым элементам кода уже порядка 19 лет, и они делались в то время, когда в C++ не было синтаксического сахара, да так и остались, т.к. работают. За конструктивую критику будем признательны.
Сейчас, т.к. жизнь не может быть полностью описана линейными дифференциальными уравнениями, занимаемся нелинейными моделями, но там нет серебряной пули, т.е. "на пальцах" простое объяснение дать не получится.
Отдельное спасибо Екатерине Кудешовой за критику.
UPD: спасибо пользователю technic93, за найденную ошибку (см. комменты).
Бибилиография
[1] Понтрягин Л.С. Жизнеописание Л. С. Понтрягина, математика, составленное им самим», М, 1983
[2] Красовский Н.Н. Теория управления движением: Линейные системы, М, Наука, 1968
[3] Григоренко Н.Л. Математические методы управления несколькими динамическими процессами, М, Издательство Московского Университета, 1990
[4] Ю.Н. Киселёв, С.Н. Аввакумов, М.В. Орлов ОПТИМАЛЬНОЕ УПРАВЛЕНИЕ. ЛИНЕЙНАЯ ТЕОРИЯ И ПРИЛОЖЕНИЯ, М, 2007
[5] Григоренко Н.Л., Камзолкин Д.В., Пивоварчук Д.Г. Линейные дифференциальные игры, М, 2007
[6] Красовский Н.Н., Субботин А.И. Позиционные дифференциальные игры, М, Наука, 1974
[7] Ли Э.Б., Маркус Л. Основы теории оптимального управления, М, Наука, 1972
[8] Понтрягин Л.С., Болтянский В.Г., Гамкрелидзе Р.В., Мищенко Е.Ф. Математическая теория оптимальных процессов, М, Наука, 1969
(В соавторстве с Юлией Филимоновой jul305a@gmail.com)
technic93
Математическая постановка задачи и сама задача с прикладной точки зрения очень интересная. Но я не понял какая цель данной статьи. Рассказать чем вы занимаетесь, тогда не нонятно зачем столько математики. Описать библиотеку на гитхабе, тогда нету никаких отсылок к коду. Как задача собственно решается тоже не рассказано.
Rumyantsev
Зачем.
Сталкивался с некоторым объёмом задач по управлению в играх, например в 2015, по-моему в AI-Cup на mail.ru была задача с гоночной трассой (и пост в habr был соответствующий) и у многих были проблемы с оптимальными прохождением поворотов, уклонения от выстрелов и неожиданно появившихся луж масла. Вот например для этого.
Что касается вопроса как решить, то в принципе в матчасти все принципы рассказал, если рассказывать теорию дифференциальных игр, то лучше либо в режиме вопрос-ответ, либо разобрать какую-нибудь не очень сложную задачу, тогда это будет обозримо по срокам.
UPD: пост нашёл + ещё ищутся 2 и далее места.
technic93
Сразу скажу, что я этой темой не занимаюсь, просто так сказать любопытно.
Вот хотя бы про это чуть больше чем одну фразу.
Не знаю как другим жителям хабра, но я думаю тема для статьи интересная.
И по поводу содержательной части
Я правильно понял что в итоге x это вектор между самолетом и ракетой (если говорить про ситуацию из введения)? Если да, тогда N я могу понимать как радиус разлета осколков. В этом случае если M это наш аэродром то область M в итоге должна двигаться, т.к. перешли в систему отсчета связанную с ракетой. Или все таки область N которая связана с ракетой должна двигаться.
Rumyantsev
Если быть честным, то Вы нашли ошибку т.к. использовал я это не корректно (хоть и в кавычках :)). Корректно написать стратегию уклонения по нормали к множеству N(что в принципе видно на графиках), так как траектория системы состоит из отрезков прямых, то наискорейшее убегание от помехи будет, очевидно, по нормали. Спасибо — перепишу соотв. предложение.
Тут есть две интерпретации
Rumyantsev
Да, ещё раз задумался над "зачем" — понял, что хотелось рассказать, чем можно заниматься в науке в almamater и это в может быть довольно интересно.