GamedevForge

GamedevForge

Привет, меня зовут Миша. Я веду канал в телеграме - GamedevForge. За 7 лет работы с Unity я делал кучу крутых проектов. Шутеры, пошаговые тактики, платформеры, сити билдеры, три-в-ряд, казуалки, гиперказуалки и так далее. Дал жизнь тонне проектов на фрилансе, в том числе и VR, AR проекты. Работал и в крупных студиях, и в мелких, и в инди-командах, и в качестве фрилансера. Активно занимаюсь менторством и помогаю начинающим или состоявшимся специалистам на их карьерном пути.
На Пикабу
100 рейтинг 4 подписчика 0 подписок 5 постов 0 в горячем

Unity .NET и Mono — галопом по компонентам

Полистал курсы от коробок навыков, мозгов гика и даже великого Романа Сакутина и не нашел ответа на дефолтный вопрос с джуновых собеседований: "Что же такое .NET, Mono, компилятор, рантайм и прочие ругательства"

Справедливости ради, там эти ответы и не обязаны быть. Курсы дают всего лишь более или менее общий набор знаний, который каждый применяет как хочет. Также большинство из них и не дают навыков и знаний для поиска работы, в чем и кроется моя главная претензия к курсам. "Возьми кредит на 200к и получи дефолтные знания".

Также этот вопрос в большинстве случаев не несет никакой пользы во время работы. До тех пор пока ты не начинаешь залезать в низкоуровневые оптимизации или писать сотни тэгов над компонентами в морпехе.

Unity .NET и Mono — галопом по компонентам Unity, Gamedev, Игры, Мат, Длиннопост

P.S. ничего не имею против морпеха, наоборот считаю самым удобным ECS фреймворком, но когда создаешь новые компоненты не через их менюшку, то приходится лезть в другие компоненты и копипастить тэги. Пока не догадаешься сделать темплейты в райдере для этого))

Но если вернуться к теме поиска работы, то вопрос про платформу и ее компоненты часто ставит начинающих разработчиков в тупик. Где-то на подкорке существует отдаленное понимание что такое компилятор и рантайм. Но формализовать это знание в четкий ответ рекрутеру, да если еще и волнуешься на первых собеседованиях... Целое дело

Поэтому давайте кратко пробежимся по компонентам .NET и Mono платформ, что у них общего и различного и для чего каждый компонент нужен.

Также в конце приложу ссылки для тех кому интересней копнуть в одну из тем более подробно.

Перед тем как начать, можешь подписаться на мой канал чтобы узнавать побольше интересного об играх и их разработке. Или записаться на менторство если и сам хочешь начать их делать за хорошие деньги

.NET

Согласно dotnet.microsoft.com ".NET — это бесплатная платформа приложений с открытым кодом, поддерживаемая корпорацией Майкрософт."

Если чуть раскрыть формулировку, то это набор компонентов, которые позволяют нам писать приложения и собирать их под разные устройства. В нее входит абсолютно все: язык, его библиотеки, компиляторы (да, там больше одного), рантайм и сборщик мусора.

Первая версия .NET Framework была создана в 2002, а первая версия Unity - в 2005. Отсюда резонный вопрос, почему Unity не работает целиком на .NET

В то время, .NET был ориентирован только создание приложений под Windows. И для движка ориентированного на любые платформы это было критичным. Соответственно юнитеки (Unity Technologies) подобрали реализацию такой же платформы от компании Xamarin, которая в то же время развивала собственное решение для разработки приложения - платформу Mono

Mono забрала из .NET язык и его базовые библиотеки (знакомые нам по неймспейсу System), а остальные компоненты такие как компилятор, рантайм, сборщик мусора переписала под свои нужны

Важной частью реализации была поддержка AOT (ahead of time) компиляции, которая в то время отсутствовала в .NET. А это было немаловажно для того же самого IOS, в котором жит компиляция запрещена (из соображений безопасности).

Также были преимущества в виде наличия библиотек для работы с мобильными устройствами, их сенсорами, камерами геолокацией, разными графическими библиотеками и возможностью работы на процессорах с разными архитектурами. Ведь .NET в то время ориентировалась на классические х86/х64

Компоненты

Рассмотрим основные компоненты платформ и для чего они нужны

Компилятор — это программа, которая переводит исходный код, написанный на языке программирования высокого уровня (в нашем случае, C#), в машинный код, который может быть выполнен компьютером. Этот процесс называется компиляцией.

Язык, в который компилируется наш C# называется Intermediate Language или просто IL. В контексте реализаций платформ, и .NET и Mono самостоятельно реализовали этот язык. Но обе версии полностью соответствуют определенному стандарту настолько, что любая версия может выполнятся на любой платформе.

Дальше в бой вступает такая штука как рантайм. В .NET он называется CLR (или Common Language Runtime), в Mono - просто Mono runtime.

И он выполняет кучу всего с нашим il кодом:

  • компиляция в машинный код для целевого устройства. В зависимости от целевого устройства он может делать это прямо во время выполнения кода (т.н. JIT или Just in time компиляция) или заранее скомпилирует весь код для устройств где такая компиляция запрещена (AOT). То есть в первую очередь рантайм включает в себя набор компиляторов под все целевые платформы, а также дополнительные инструменты для такой компиляции (например, IL2CPP, про него позднее)

  • управление памятью, которым занимается всеми известный сборщик мусора

  • и куча других вещей типа обработки исключений, управление потоками, взаимодействие с неуправляемым кодом, проверка кода на безопасность и тд

Рассмотрим пару его компонентов:

IL2CPP

Средство для компиляции кода для устройств, поддерживающих только AOT компиляцию.

Как и следует из названия, этот инструмент переводит код из IL в C++, чтобы в последствии при помощи компилятора конкретной платформы.

Зачем он нужен? Да банально для того чтобы юнитекам не приходилось писать собственные компиляторы и можно было использовать стандартные компиляторы для целевых платформ которые давным-давно написаны.

Сборщик мусора

Его основная задача - освобождать память, занятую объектами, которые больше не используются, чтобы предотвратить утечки памяти и освободить ресурсы устройства для создания новых объектов.

Какие есть основные особенности у сборщика мусора в .NET:

  • поколения, которые позволяют выполнять сборку мусора быстрее. Если кратко, то существует 3 поколения в которые попадают объекты от наиболее быстроживущих до долгоживущих, которые проверяются на необходимость удаления реже.

  • компактирование памяти - после сборки мусора у вас может остаться множество разбросанных по всей памяти объектов. И такое их хаотичное расположение может послужить проблемам. Например, что большие объекты могут не найти себе места в памяти, ведь раз текущие объекты разбросаны, то между ними не окажется достаточно много места для нового.

Хотя Mono поставляется сразу с двумя сборщиками мусора, Unity использует только один из них - boehm или bdw gc, более старый но при этом более легковесный что важно для тех же мобильных платформ.

В нем отсутствуют вышеперечисленные фишки, но зато существует так называемся инкрементальная сборка, которая позволяет размазывать процесс сборки на несколько кадров.

Также оба сборщика немного отличаются по своему принципу работы.

Верхнеуровнево они оба анализируют стек и глобальные объекты на предмет ссылок на объекты в куче, а потом и остальные объекты на наличие прочих ссылок. Те, на которые по итоге не ведут никакие ссылки, помечаются для удаления.

Но .NET сборщик мусора всегда точно знает какие объекты памяти являются ссылками на другие объекты, тогда как boehm анализирует все объекты в памяти которые потенциально могут быть ссылками на объект. Поэтому такой сборщик потенциально может оставлять в памяти объекты, на которые по итогу и не существует ни одной ссылки. То есть если в вашем объекте есть int поле которое по значению совпадает ссылкой на какой-то объект, то этот объект не удалится.

P.S. Дополнительная инфа про GC для заинтересованных прилинкована внизу статьи.

Штош, таким образом мы примерно представляем как устроена Mono и .NET и сможем ответить на этот вопрос на собесе (в остальном это все и нахуй не надо)

Подписывайтесь на канал чтобы узнавать еще больше и делать хорошие игры за хорошие деньги

Спасибо!

Дополнительная информация о GC:

Серия постов как работает GC в Unity под капотом

Всего лишь статья из Википедии, но тоже довольно подробная

Статья от My.Games про GC

Показать полностью

Вашим играм не нужна State Machine

Вступление

Сегодня я, наконец, расскажу, почему игровой ИИ, основанный на машине состояний (State Machine или просто SM), это ленивое подобие ИИ и не должно видеть свет в любом не пет-проекте.

Меня все также зовут Миша, я программирую больше 7 лет, последний год плотно занимаюсь игровым искусственным интеллектом, реализовывал его во всех возможных вариациях. А также успел увидеть немало говнокода со стейт машинами, где его довольно просто можно было бы избежать. Также, конечно же, веду телеграм канал, где рассказываю еще больше о разработке, карьере в геймдеве и прогреваю на менторство.

Почему нельзя?

Конечно, всегда можно сказать “да вот у меня элементарнейшее поведение, там нечего выделываться с ИИшными фреймворками” или “у меня жанр Idle, там мобы просто выполняют последовательность действий”. Но давайте вспомним цикл жизни практически любой игры. Да, мы делаем сначала core-фичи, только основной набор действий для мобов. Но как долго это длится? Как долго наши мобы из айдлеров не начинают менять поведение на ходу. Например, когда не могут что-то выполнить или когда просто хотят порадоваться просмотренной рекламке?

В такие моменты мы и понимаем, насколько были ленивы, выбрав машину состояний. Ведь у нее квадратичная сложность увеличения количества поведений. И еще все вместе вспоминем, что граф для состояний в наших стейт машинах ориентированный и умножаем количество на 2. То есть, 2 состояния - 2 стрелочки между ними, 5 состояний - 20 стрелочек, 12 → 132 и так далее.

Остаемся в зоне комфорта

Конечно, все мы следуем великой мантре “работает - не трожь!”. Поэтому как бы сильно ни стреляла нам по ногам эта стейт машина, мы остаемся с ней до победного (иногда) конца.

Второй стадией обычно идет “принятие” или как мы это называем “написание костылей”. То есть, чтобы бороться с квадратичной сложностью добавления нового поведения, программисты используют один из трех костылей или все вместе.

Рассмотрим их на примере NPC или условной RPG игры. Наш моб умеет некоторые действия типа: общаться с главным героем, ходить на работу, есть, спать, сражаться.

  • Any State. Этот синий квадратик в аниматоре знаком любому юнитисту. Проводя стрелку от него, мы показываем, что в это состояние можно перейти из любого другого. Чтобы не рисовать 20 стрелочек к 10-му состоянию, мы нарисуем 10, а одиннадцатую проведем от Any state. И все хорошо, пока мы не решим, что из какого-то состояния мы все таки не хотим переходить в это новое…
    Говоря о нашем NPC. Хотим мы ему добавить для смерти отдельное состояние (может наконец-то раскошелились на анимацию не из mixamo и хотим ею похвастаться). Мы решаем “ну умереть он может когда угодно, значит можно сделать переход из any state. Все классно, только вот NPC давал герою квест во время диалога и теперь во время болтовни он может умереть и закончить сюжетную арку на 10 часов раньше. Поэтому придется все таки провести еще 10 стрелочек.

  • Hierarchical state machine (HSM). Кому-то тоже знаком из аниматора как “вложенная стейт машина”. Если часть состояний одинаково связана с остальной частью стейт машины, то вполне резонно можно выделить ее в свою внутреннюю SM. Таким образом из 90 стрелок мы можем убрать условно половину. Но все снова идет по одному месту, когда часть таких состояний все таки должна иначе работать с внешней стейт машиной…
    Вернемся к NPC. Мы решаем, что все его мирные действия (поесть, поспать, поболтать) достойны того чтобы лежать отдельно от его боевых навыков. Убираем их отдельно и смотрим на похорошевший граф состояний… Ах да, он все еще сюжетный квест дает, но вместо диалога убежал сражаться… Тогда распаковываем обратно и рисуем обратно 40 стрелочек…

  • Слои.
    - Понимаешь, стейт машины, они как лук
    - Воняют? Доводят до слез?
    - Нет, слои. У лука есть слои и у стейт машины есть слои.
    Ставьте лайки, если узнали отсылку))
    Если какое-то действие может выполняться независимо от части остальных, то его можно вынести в отдельный слой. По своей сути, это такая же стейт машина, работающая параллельна, но в этом же внешнем контексте. Она смотрит на те же данные и меняет состояния по тем же самым триггерам, что и основная SM. Но точно также все ничего до тех пор, пока ее параллельность абсолютна. Что как правило не так…
    Геймдизайнер поиграл в скайрим и решил что наш NPC тоже может разговаривать во время некоторых действий. Например, он может делать это сидя за столом. Мы создаем отдельный слой для стейт машины, в котором есть только состояния общения. Но ведь персонаж не может уйти из-за стола, пока разговаривает. Тем более когда дает сюжетный квест. Да и разговаривать он может далеко не всегда. Что нам тогда приходится делать? Все равно опосредованно соединять наши стейт машины. Состояние общения должно точно знать что происходит в остальной логике персонажа. И та в свою очередь должна ждать, пока голова договорит. В итоге это даже хуже остальных костылей. Мы не только зазря пытаемся оптимизировать поведение, а еще и прячем зависимости состояний внутрь самого контекста игрока.

P.S. изначально примеры могли быть разнообразнее, но мне понравилось как один жалкий сюжетный квест портит абсолютно всю машину состояний. Очень разрушительный сюжет получается)

Боимся и поджимаем хвост

На самом деле, большей частью эта проблема берется из-за необразованности или лени. Кто-то либо боится либо ленится посмотреть на окружающий мир и на альтернативы, которые он предлагает, либо боится проиграть, реализуя более серьезные подходы.

И не надо далеко ходить, чтобы понять главную альтернативу нашей стейт машине - Behavior Tree или Дерево Поведений. То, что по умолчанию есть в Unreal и то, что и было использовано в альтернативу сжигающей себя стейт машине. То, что возвело противников из серии Halo в пример остальным игроделам.

Посмотрим на “фичи”, которая она предлагает из под коробки. Заметьте, ИЗ ПОД КОРОБКИ, для этого не надо наворачивать сову на глобус как мы делали с NPC:

  • Вложенность (не просто так оно деревом называется)

  • Глобальные переходы между состояниями, как следствие из этого

  • Параллельное выполнение состояний

Конечно, нельзя не забывать и про Utility AI. Он больше подойдет в случае когда состояний много и нам не хочется выстраивать связи между ними (вспомните Sims). Хотя выбор между подходами для написания ИИ посвящена целая отдельная статья.

Итог

Не бойтесь выходить из зоны комфорта и искать новые решения для стандартных проблем! И НИКОГДА НЕ ИСПОЛЬЗУЙТЕ STATE MACHINE ДЛЯ ИГРОВОГО ИИ!!! И конечно же подписывайтесь на мой канал и обращайтесь за менторством, если до сих пор не нашли работу в геймдеве) Спасибо!

Показать полностью

Нужны ли Unity разработчику проекты на гитхабе

На моем опыте, о котором можно больше почитать на канале, довольное большое количество собеседующих в той или иной степени заглядывает на гитхаб. Первые просто хотят убедиться, что у вас есть в наличии хоть какой-то написанный вами (надеюсь) код. Вторые хотят побольше в этот код повникать, чтобы посильнее вас потеребонькать на техническом собеседовании. Уже не знаю для чего… для поднятия собственного это, может быть. Или может хотят сбить с вас спесь вместе с денежными запросами) Хотя последняя категория собеседующих на моей практике попадалась всего два раза:

  • в первый раз сеньор из gaijin полчаса докапывался до "можно тут написать ++i вместо i++, так считаю будет правильнее и на наносекунду быстрее" и прочая чушь про микро оптимизации (мы ведь только этим на работе и занимаемся, правда?)

  • во второй раз затирали что в пет-проекте про ИИ очень "слабо" организован слой работы с UI "ой, а почему у тебя хп бары там не поворачиваются на камеру, ты что не умеешь"

В общем, сюр да и только. В первый раз мне все равно дали оффер, но не самый жирный на свете (в целом так не только они делают, нередкая практика у крупных студий - кичиться своей важностью и прогибать по зарплате). Во второй... хз, собес был недавно, еще посмотрим))

В преобладающем большинстве, когда видят мой гитхаб с 60+ репозиториями, решают не погружаться в эту свалку фриланса и полумертвых пет-проектов. Так что это не для всех, но тоже как вариант))

В остальном достаточно одного небольшого проекта. Ему не надо быть красивым или даже ультра качественно написанным. Но в нем должно быть:

  • отсутствие базовых ошибок и косяков, за которые прям зацепиться глаз. Никаких FindObjectOfType и десятков синглтонов, вызываемых из одного класса. Никаких бесполезных комментариев как по коду, так и “для себя на будущее”. На самом деле, комментарии - довольно сложная тема, иногда они могут быть и нужны. Если интересно подробнее узнать, где их писать/не писать и как это делать, можно посмотреть у великого Сергея Немчинского. Для наших целей достаточно правила “любой комментарий может быть кодом”. Если внутри метода есть сложная часть, которую захотелось прокомментировать, то вынесите ее в отдельный метод с нужным названием. И по аналогии с любым другим комментарием.

  • соблюденный кодстайл. Нейминги, отступы, аккуратные небольшие легкочитаемые классы. Ревьюверы - тоже люди (звучит как лозунг для какого-нибудь митинга), им приятнее будет читать хорошо оформленный код вместо мешанины из кривого нейминга

  • только доделанный функционал, никаких костылей и заглушек для “на потом, когда руки дойдут”

  • оформленный ридми. В нем четко написано: что это за проект, что в нем уже сделано, какие технологии использованы, пара скринов или видео геймплея. Можно даже билд приложить

Во время обучения за подобный проект мы беремся уже параллельно с выходом на рынок. В тот момент, когда ученик уже точно имеет все необходимые навыки как по C# и Unity, так и по прохождению собеседований. Почему именно тогда, а не раньше:

  • опыт написания целиком собственного играбельного решения и понимание, что не так уж это и сложно, сильно помогает ментально. Сразу сбрасывается этот губительный майндсет, мол "вот они то настоящие программисты, а я так... только по туториалам умею". И чем эта позиция будет актуальнее на момент собеседований, тем лучше)

  • может так случиться, что проект и не понадобится. Попадется лид, который вообще не полезет в гитхаб или тот, которому будет достаточно что он просто существует. Поэтому специально растягивать период обучения на написание проекта - лишнее

О чем должен быть такой проект:

  • Это должна быть небольшая, законченная игра. Не надо пытаться в одного делать новую GTA или Assassin’s creed. Оно и не получится, да и потенциальный лид, заглянувший в проект, увидит только человека который не может оценить свои силы и берет на себя слишком много.

  • Сосредоточьтесь в первую очередь на основных механиках. Мета часть игры с ее магазинами, сезонными пропусками, ежедневными бонусами оставьте для жадных издателей. Собеседует вас такой же разработчик, поэтому на продающие картинки и рекламу на каждый пук в вашей игре, он не обратит внимание. Но при этом совсем отодвигать мету на второй план тоже нельзя. В конце концов, большая часть рынка - это донатные обдираловки, собеседующим будет полезно сразу же понять, что именно их ты уже умеешь и главное хочешь делать.

  • Скорее всего, ты не дизайнер, но постарайся сделать визуал не сильно всратым) Для UI возьми любой пак с понравившимися тебе спрайтами. Если кор часть в 3д, то также постарайся подобрать модели в одном стиле хотя бы. Поставь хоть какой-нибудь свет на сцену

  • Используй разумное количество популярных фреймворков. Затащи в проект DI (Zenject или VContainer), при необходимости, добавь UniRx. Для процедурных анимаций добавь в проект щепотку DoTween’а

  • Знай и понимай каждое принятое на проекте решения. Чтобы на условный вопрос “а почему используешь MVP, а не MVVM” было хорошее объяснение вместо “ну мне показалось так лучше будет/ну он вроде проще/ну я за UniRx не шарю”

Конечно же, все это не серебряная пуля и не поможет вам проходить 100 из 100 собеседований. Но оно поможет увеличить конверсию от скрининга к техническому собеседованию и даст повод потратить часть того самого собеседования на обсуждение вашего проекта вместо ответов на душные вопросы. Согласитесь, приятнее рассказывать о своей игре, чем в очередной раз вспоминать как же там устроен словарь под капотом?)

У себя на вместе с выходом этой статьи объявлю небольшой конкурс. Кидайте в комментарии сюда, а лучше к посту, анонсирующему эту статью на моем канале, свои пет-проекты или тестовые. В зависимости от их количества и качества я в прямом эфире посмотрю 3-5 самых, на мой взгляд, интересных!

Показать полностью

Альтушка с Госуслуг - превращаем мем в реальность

Альтушка с Госуслуг - превращаем мем в реальность Gamedev, Unity, Игры, Госуслуги, Инди игра, Инди, Разработка, Не Steam, Визуальная новелла, Steam, Длиннопост, Альтушки

Доброго всем дня!
Недавний успех “Русов против ящеров” - игры, построенной по сути из мемов, заставил задуматься. Достаточно ли сильно “индустрия” мемов проникла в нашу жизнь, чтобы один из них смог эволюционировать в полноценную игру.

Альтушка с Госуслуг - превращаем мем в реальность Gamedev, Unity, Игры, Госуслуги, Инди игра, Инди, Разработка, Не Steam, Визуальная новелла, Steam, Длиннопост, Альтушки

В поисках подходящего “источника вдохновения”, на мои глаза в очередной раз попались мемы про альтушку с госуслуг. И, оказалось, что они - идеальный кандидат. Посудите сами: мем довольно устоявшийся, известный (в кругах нашей целевой аудитории), долго не утрачивает свою “актуальность”. Да что там и говорить, даже я почти превратился с скуфа, которому бы не помешала такая альтушка (хорошо, что моя жена не читает DTF).

Альтушка с Госуслуг - превращаем мем в реальность Gamedev, Unity, Игры, Госуслуги, Инди игра, Инди, Разработка, Не Steam, Визуальная новелла, Steam, Длиннопост, Альтушки

Немного о сюжете:
“В светлом будущем вопрос выбора жизненного спутника - уже давно решенный вопрос. И не решенный не кем-то там, а самим правительством страны! Теперь государство с любовью и заботой возьмет на себя трудности и ответственность подбора той единственной.

Как только человек достигнет тридцати лет и почетного звания Скуфа, правительство с любовью подберет ему невесту. Отныне можно забыть о мучительном поиске пары, свиданиях, конфетно-букетном периоде, ведь, конечно же, государству виднее, чего тебе не хватает для счастья. Кто, как не оно, найдет тебе идеального партнера, который сделает твою жизнь настоящим раем?”

Альтушка с Госуслуг - превращаем мем в реальность Gamedev, Unity, Игры, Госуслуги, Инди игра, Инди, Разработка, Не Steam, Визуальная новелла, Steam, Длиннопост, Альтушки

В центре нашей истории обычный мужчина, который праздновал свое тридцатилетие за популярной игрой “Танковый мир”. После нескольких литров пива заснув за компом, он просыпается от уведомления на телефоне - ему одобрена альтушка.

Альтушка с Госуслуг - превращаем мем в реальность Gamedev, Unity, Игры, Госуслуги, Инди игра, Инди, Разработка, Не Steam, Визуальная новелла, Steam, Длиннопост, Альтушки

Но, разве могло быть все так просто? Естественно бюрократы все перепутали и пришла не одна, а сразу несколько, да еще каких. И как обычному мужику разбираться со всем этим хаосом в своей однушке в Выхино, предстоит еще понять.

Альтушка с Госуслуг - превращаем мем в реальность Gamedev, Unity, Игры, Госуслуги, Инди игра, Инди, Разработка, Не Steam, Визуальная новелла, Steam, Длиннопост, Альтушки

Теперь немного о геймплее:

Кор игры будет представлять из себя визуальную новеллу - рассказ, о том как государство и выделенные им альтушки пытаются изменить жизнь простого русского скуфа.

Диалоги будут разбавлены мини играми, в которые можно будет заработать дополнительные “плюшки”, которые повлияют на игру на мета уровне. Что именно будет представлять из себя мета геймплей, узнаете в следующих частях.

Ближайшие планы на проект:

  1. В ближайшее время планируем сделать тизер трейлер и привлечь внимание еще большей аудитории к нашему проекту.

  2. После этого доделаем прототип и обкатаем его на наших подписчиках на Boosty

  3. Затем учитывая полученный фидбек, будем готовить вертикальный срез. Он уже пойдет в Steam и, может быть, другие площадки.

Альтушка с Госуслуг - превращаем мем в реальность Gamedev, Unity, Игры, Госуслуги, Инди игра, Инди, Разработка, Не Steam, Визуальная новелла, Steam, Длиннопост, Альтушки

Особенности разработки:

Так как я также веду канал о разработке, то некоторые инсайды о создании этого проекта, лайф кодинг и туториалы по тому, как сделать некоторые механики отсюда, будут публиковаться на моем телеграм-канале и на моем Youtube.

Альтушка с Госуслуг - превращаем мем в реальность Gamedev, Unity, Игры, Госуслуги, Инди игра, Инди, Разработка, Не Steam, Визуальная новелла, Steam, Длиннопост, Альтушки

Следить за проектом, поддержать его и поучаствовать в развитии (получив при этом бонусы и дополнительные контент) можно на Boosty
В более пассивном режиме смотреть новости по его разработке можно в телеграм-канале.

В комментах могу рассказать как получить свою альтушку уже подробнее.

Показать полностью 7

Выбор игрового ИИ и его “сложность"

Наконец-то вернулся в строй и начал делать второе видео по шине событий! Но поговорить хотел не об этом.

Вчера блуждал по интернетам - смотрел на различные туториалы по игровым ИИ и их реализации. Сразу признаюсь, что целиком их не просматривал, поэтому если и где-то существует похожий контент, то не брезгуйте тыкнуть меня в него носом в комментариях на моем канале.

Многие из вас наверняка знакомы со всеми подходами, но давайте начнем с небольшого глоссария, чтобы дальнейшие сокращения не вызвали ни у кого сложностей:

  • FSM - finite state machine или машина конечных состояний. Слово "конечные" как правило опускается

  • BT - behavior tree или дерево поведений. По своей сути "апгрейд" машины состояний

  • GOAP - goal oriented action planning. Про него расскажу ниже

Итак, интернет полон туторами по ИИ во всех возможных вариантах: машина состояний, дерево поведений, GOAP и utility AI. Каждое из которых со своей сути лишь определяет алгоритм, по которому сменяются состояния/действия персонажа.

  • Для FSM и BT это простые if else с четкими условиями перехода. “Если видим противника, идем к нему. Если подошли, атакуем”.

  • Для GOAP мы находим такой “путь” из действий игрока, который приводит к желаемому результату. Как правило, для выбора “пути” используем поиск в ширину, но при большом количестве действий можно рассмотреть варианты использования алгоритмов-“старших братьев” поиска в ширину. Например, A*.

  • В Utility AI мы просто выбираем самое “эффективное” действие каким бы то ни было способом. Это можно делать за счет формул расчета, оценки через кривые Безье или через смесь этих способов.

Также существуют различные смешанные способы, но по факту они заканчиваются одним из этих четырех подходов. Например, так называемый tactical AI - по факту он одним из вышеуказанных способов выбирает не конкретное действие, а их последовательность. Но лично я не вижу здесь никакого принципиально нового подхода в сравнении с остальными.

Также нельзя не затронуть вопрос реализации ИИ с помощью машинного обучения. В них есть также три основных проблемы относительно более “классических” подходов.

  • Трудозатраты - потребуются долгие сотни и тысячи часов чтобы обучить такой ИИ даже двигаться в нужную сторону. Даже при ускоренных симуляциях и многих обучаемых агентах одновременно. Ведь ему нельзя напрямую говорить “иди туда”, надо давать “награды”, если он идет куда следует. Правильная и сбалансированная выдача которых тоже довольно не тривиальная задача для всего что сложнее “змейки” или Flappy Bird. Что уже и говорить про интеллект для пошаговых тактик по типу XCOM, стратегий по типу Civilization или Crusaders Kings или про шутеры с хорошим ИИ по типу Killzone или FEAR (могли бы быть другие примеры, но я просто выбрал любимые игры. Напишите в комментарии свои любимые игры или игры с хорошим на ваш взгляд ИИ).

  • Качество - даже при хорошем обучении, очень невелик шанс, что ИИ будет себя гарантированно “правильно” вести. Особенно, в очень сложной и динамической среде. Игроки и разработчики предпочтут “предсказуемый” интеллект “умному”. ИИ, построенный с помощью машинного обучения будет всегда по своему интерпретировать входные условия и действовать в соответствии с тем, чему научился. Отсюда вытекает и третья проблема…

  • Сложность в редактировании. Даже используя более продвинутые подходы, очень легко менять поведение персонажей - подкрутить кривую Безье в одном месте или отредактировать эффекты от действий и цели ИИ в другом. Но это не получится сделать так быстро с ML. Если вы, например, научили ботов в шутере атаковать как берсерков, не смотря на ранения, то сделать их более осторожными займет большое количество времени и итераций. Вспомните youtube с его жуткими алгоритмами - если вы посмотрели какой-то ролик на совершенно новую тему (например, музыкальное видео, хотя все остальное время смотрите подкасты и видео о программировании). То как долго вам придется игнорировать новые музыкальные видео, чтобы youtube наконец-то решил “ладно, видимо ему это и правда не нравится”. Повезет, если при этом он хотя бы не будет показывать тот единственный просмотренный ролик!

Поэтому реализации на самом деле “сложного” ИИ задача гораздо более объемная и невыгодная в сравнении с базовыми реализациями.

Во многих источниках выбор между подходом рисуют в виде прямой, над которой написаны все варианты в порядке “усложнения”. Вроде такого FSM → BT → Utility AI → GOAP. Но такой подход в корне не верен, так как не совсем понятно, что в таком случае есть “усложнение”. Ни один их этих подходов не является “сложным” в реализации. Но о том, в чем может заключаться сложность подхода поговорим немного позже.

В общем и целом, при выборе подхода надо ориентироваться на несколько составляющих:

  • Количество действий/состояний персонажа (ходить, спать, стрелять и тд). Причем не только планируемых в ближайшую версию/спринт, а и планируемых в будущем. Чтобы не остаться со стейт машиной, в которой нужно проводить сотни стрелочек между действиями и помоги боже, если забудете хоть одну!

  • Предсказуемость. Легко понять как будет вести себя персонаж, если у него черным по белому будет написано “если устал - иди спать”. Гораздо сложнее при этом смотреть на какие-нибудь формулы и анимационные кривые, которыми может выражаться “эффективность” для того чтобы “пойти поспать”. Если хотите меньше сюрпризов в его поведении, то смотрите в сторону FSM и BT. Если больше уникальности - GOAP и Utility AI.

  • Горизонт планирования действий персонажа. Тут тоже все просто - при необходимости составления “стратегии” из действий двигаемся в сторону подходов, позволяющих это.

Теперь поговорим о “сложности” ИИ. До сих пор самым “сложным” игровым ИИ считается тот, который реализован в оригинальном F.E.A.R, выпущенном аж в 2005 году! Но сложность того ИИ заключалась не только в “поиске набора действий”, а в реализации дополнительных “фичей” поверх. Помимо них есть существуют еще обвесы для ИИ, такие как:

  • Предсказание поведения игрока: “подожду игрока на левой дорожке, так как скорее всего он пойдет туда”

  • Групповое поведение: “предупредим остальных, если игрок пойдет по левой дорожке”

  • Динамически изменяемое поведение: “какие бы планы у нас ни были, если игрок пойдет по правой дорожке - побежим туда”

Самое интересное, что реализуются эти механики практически одинаково вне зависимости от подхода к реализации ИИ. Поэтому визуально составление игрового ИИ можно нарисовать в виде такой картинки:

Выбор игрового ИИ и его “сложность" Unity, Gamedev, Искусственный интеллект, Игры, Длиннопост

Если не вращать элементы пазла, конечно же

Поэтому в следующий раз, когда возьметесь за написании игрового ИИ, не будьте узколобым сторонником "легких" и "сложных" подходов - выбирайте с умом!

А теперь, когда мы немножко поговорили про матчасть игрового ИИ, по всем инфоцыганским законам сделаю небольшой прогрев)

Вот что оказалось самым забавным в моем поиске - это что ни один из туториалов не предлагает такую реализацию ИИ - реально “сложную” реализацию. Оно и понятно, игроки стали казуальными, даже в ААА. С каждой новой игрой от ubisoft, ютуб заполняется роликами, насколько же тупые у них боты. Поэтому в качестве серии роликов “для продвинутых” хочу сделать видео про написание не просто “ИИ написанный с помощью Х”, а сделать серию роликов про по настоящему “сложный ИИ”, который будет уметь делать все перечисленное и не только.

Поддержите лайками, если нравится идея или напишите что об этом думаете в комментариях на моем канале (я еще не настолько выжил из ума, чтобы читать их здесь)! Или предложите на каком игровом примере на это было бы интереснее всего посмотреть. Я пока что думаю о top down shooter, чтобы и пострелять можно было, но и чтобы при этом было видно издалека, как ведут себя боты.

BTW, новые ролики будут на все том же канале, где и все остальные!

Показать полностью 1
Отличная работа, все прочитано!