Можно написать майнкрафт
Ответы на вопросы, касающиеся приобретении лицензионной копии Minecraft, изложены в одном из разделов данной статьи:
Программируем в мире Minecraft
Хабр, привет! Пока все обсуждают ИИ в мире Pacman, мы начнем делать свой ИИ в Minecraft с фреймворком Malmo от Microsoft Research. Pacman у нас тоже появится. Если вы любите кубический мир, или вам хотелось бы начать изучать искусственный интеллект, или у вас есть дети, с которыми вы не можете найти общие увлечения, или же вас просто заинтересовала тема – прошу под кат.
В этой статье я постараюсь затронуть несколько тем:
- Выскажу свое мнение о помешательстве детей на кубической игрушке
- Расскажу об основной идее Malmo
- Покажу несколько примеров с кодом и дам понимание, куда можно идти дальше
- Расскажу об идее и результатах Malmo Challenge
Первый день
После генерации игрового мира игрок заспаунится в случайном биоме. При нажатии кнопки E (по умолчанию) откроется окно инвентаря.
Ориентирование
Биомы отличаются между собой.
Используйте высокое значение кнопки Прорисовка во вкладке Настройки графики в настройках для того, чтобы улучшить дальность рендеринга. Если FPS стал значительно меньше, то можно вернуться к значению по умолчанию.
При путешествии, старайтесь не заблудиться.
Добыча древесины
Создание верстака
Первое вооружение
Палка в данном случае используется в качестве рукоятки для оружия и инструментов.
Обновление
Под земным покровом расположен камень в обильном количестве. Добудьте его с помощью деревянной кирки для создания каменной кирки, каменного меча каменного топора, каменной лопаты и каменной мотыги.
Каменный меч необходим для убийства мобов и получения дропа.
Каменный топор лучше предыдущего по скорости добычи древесины.
С помощью каменной лопаты добываются блоки верхнего слоя земного покрова.
Каменная мотыга позволяет вспахать землю для дальнейшей посадки семян.
Выплавка
Помимо крафтинга предметов, в Minecraft существует выплавка.
Печь необходима для приготовления сырого мяса и переплавки руды.
Добыча руд
Необходимые руды на первое время:
- Угольная руда добывается с помощью деревянной кирки и выше.
При разрушении оставляет уголь, который используется для изготовления факелов и в качестве топлива.
Полученный в процессе переплавки железной руды железный слиток используется для создания большинства предметов.
Жилище
Изначально выбирайте месторасположение для строительства дома и дальнейшего усовершенствования.
Поиск пищи
После создания необходимых предметов и первого жилища, вашей следующей задачей будет являться добыча пищи для утоления голода. Получайте сырое мясо в качестве дропа, убивая: куриц, коров, , свиней, кроликов и овец. Также, можно раздобыть семена пшеницы, получаемой при разрушении высокой травы. Когда пшеница вырастет, производится её сбор для создания хлеба.
Malmo Challenge: история и результаты
Кроме самого фреймворка, Microsoft также проводил соревнование на базе платформы, названной Malmo Challenge. Оно было призвано побудить ученых и исследователей к работе над коллаборативными алгоритмами. Конкурс стартовал примерно полгода назад, а результаты появились 5 июня.
Суть челленджа в следующем: у нас есть плоский мир, забор сложной формы, внутри загона бегает хрюшка и ходит 2 человека. Наша задача – создать ИИ для одного из персонажей, которых сможет взаимодействовать со вторым, чтобы вместе они загнали хрюшку в замкнутое пространство. Второй персонаж может вести себя рандомно, может управляться человеком, другим ИИ, это может быть даже второй экземпляр вашего собственного ИИ.
При этом, вы можете получить максимальное число очков, поймав хрюшку, или же получить небольшое число очков, прыгнув в лужу сбоку. Вы не получите ничего, если ваш напарник решит прыгнуть в лужу, отказавшись от взаимодействия с вами.
Эта задача в общем виде называется Охота на оленя. Она была сформулирована еще в 18 веке Жан Жаком Руссо. Несмотря на внушительный возраст проблемы, до сих пор неясно, какой алгоритм наиболее эффективно решает поставленную задачу.
Я рада поделиться с вами результатами соревнования. Меня очень удивило распределение мест в турнирной таблице.
Первое место занял проект команды из Великобритании. Авторы трезво оценили сильный недостаток времени, поняли, что они вряд ли успеют адаптировать для задачи сложные существующие алгоритмы. Они выбрали Байесовский вывод для определения типа напарника, а также Марковские цепи для непосредственного игрового процесса. И победили.
Участники, занявшие второе место, решили взять самые сложные из существующих решений, они использовали DNN, Reinforcement learning, DQN, A3C model… И это все не помогло им обойти Байеса и Марковские цепи.
Подытожим статью мыслью о том, что нужно быть проще.
Видео с моим рассказом о Malmo на встрече Петербургского Python митапа уже появилось на моем канале на Youtube. Там также есть записи других моих лекций и прочая болтовня про IT.
- Воздух
- Вода
- Земля
- Лестница
- Коренная порода (Bedrock)
- Вода растекается по доступной поверхности
- На персонажа действует гравитация
- Персонаж может создавать все блоки, кроме коренной породы
- Персонаж может разрушать землю и лестницы
Update1:
Добавил коренную породу.
Update2:
Убрал мерцание и дерганье экрана.
Update3:
Добавил бинарное демо.
Картинка для привлечения внимания:
- W S A D — движение персонажа
- W S A D + Shift — удаление блоков в соответствующем направлении
- 1 2 3 4 — создание блоков воздуха, земли, лестницы и воды
При создании кода не использовал «нечестные» ухищрения для уменьшения размера и придерживался следующего кодестайла:
Содержание
Как играть программировать в Malmo
Основной процесс выглядит следующим образом: в одном окошке вам необходимо поднять сервер и клиента. Для этого есть скрипт ./Minecraft/launchClient.* . После того, как сервер поднялся, в другом окне вы можете запустить код с основной логикой для управления персонажем. Как узнать, что сервер поднялся? Все крайне логично: вы увидите запущенный экземпляр Minecraft с начальным меню внутри, а в терминале будет гордо красоваться надпись Building 95% .
Вы можете запустить сколько угодно экземпляров launchClient . В таком случае первый запущенный экземпляр будет являться сервером, а также клиентом, представляющим из себя одного персонажа. Все последующие экземпляры будут подключаться к уже поднятому серверу, добавляя дополнительного персонажа в мир.
Логику для каждого из человечков вы можете реализовать в коде, а также можно управлять персонажем самостоятельно всем знакомыми клавишами AWSD.
Кроме сервака с клиентом и файла с логикой, мы также имеем xml файл с описанием начального состояния мира. Авторы не настаивают на его существовании, и в своих примерах они часто кладут его в строку и хранят в коде, но, на мой взгляд, удобнее сразу сделать его отдельным файлом, добавляя нужные куски по мере необходимости.
Авторы позаботились о нас и сделали внушительное число примеров, добавив к ним описание.
Мой совет: не пытайтесь начинать с нуля, возьмите за базу первый пример. В нем ничего не происходит, мы просто создаем самый простой плоский мир и присоединяемся к персонажу. В цикле while в конце вы можете по своему усмотрению добавить экшена в происходящее. Например, напишите там:
И насладитесь первыми шагами своего героя. Учтите, что по умолчанию используется т.н. ContinuousMovementCommands. Воспринимайте отдаваемые персонажу команды как изменение положения рычага. Говоря "move 1" , вы сделаете не один шаг. Вы будете бежать, пока не дадите команду "move 0" . Такой код на практике не сдвинет человечка с места:
Команды выполнятся за считанные доли секунды. Не забывайте вставлять периодические строчки "time.sleep(X)" . Я уверена, что вы знаете, где брать информацию об остальных командах (хотя, по моему опыту, проще по диагонали просмотреть туториал и затем искать нужное в исходниках).
В xml файле вы можете задать режим игры:
Задайте начальное время, позицию персонажа, кастомизируйте мир: сделайте его плоским или приближенным к реальности.
Вот этот код нарисует вам Пакмана, который поедает шарики и уходит в радужный кратер:
Наконец, в xml можно добавить необходимые координаты для добавления обзора персонажу:
По умолчанию у нас нет возможности осмотреться и получить информацию о ближайших блоках. Тем не менее, мы можем сказать, что хотим знать, что находится вокруг нас. Учтите, что в этом случае нам нужно использовать относительные координаты, отсчитываемые от кубика с ногами героя. В результате выполнения подобной строчки:
Мы получим массив со строками. Каждая строка – это текстовое представление типа одного из кубиков.
Таким образом можно создать ИИ, который исследует мир, ищет что-либо и не умирает по глупым причинам. Простейший вариант без использования машинного обучения я реализовала тут.
Фичи для ИИ
Конечно же, первое, что мне захотелось увидеть для реализации алгоритмов ИИ в malmo – это возможность двигаться дискретно. В вопросе ИИ и так хватает сложностей, и не хочется добавлять ко всему прочему постоянную корректировку направления и скорости движения.
Включаем нужное в xml так:
К сожалению, этого будет недостаточно. Чтобы двигаться дискретно, ваше начальное положение должно быть строго в центре кубика:
Целые координаты поставят вас в пересечение кубов, персонаж откажется двигаться с места, никаких предупреждений и ошибок вы не увидите. В туториале об этом также не предупреждают. Я потратила около 4 часов, чтобы осознать суть проблемы и сделать координаты x и z половинчатыми. (y отвечает за высоту и не играет роли в данной истории).
Кроме этого, исследователи добавили несколько приятных фич для решения задачи обучения с подкреплением (Reinforcement Learning). Алгоритмы этого типа подразумевают постоянное награждение или наказание искусственного интеллекта за те или иные действия. Разработчики продумали этот момент и добавили возможность прописать эти действия/события в xml, избавив код от постоянных одинаковых проверок. Вы также можете задать окончание игры по наступлению некоторого события:
Например, тут мы постоянно чуть-чуть наказываем персонажа за каждый шаг, не увенчавшийся победой; сильно награждаем за победу и наказываем за смерть; наконец, завершаем раунд в случае смерти или выигрыша.
Malmo: основная идея
Фреймворк Malmo был создан совместными усилиями нескольких исследователей, главной целью которых было адаптировать интересный мир к экспериментам в области искусственного интеллекта. Алгоритмов ИИ по-прежнему относительно мало, и все они имеют огромный потенциал для более детального изучения и усовершенствования. Мне очень нравится, что Microsoft создает дополнительную мотивацию к изучению неизведанного.
Технические моменты
Установка
Несмотря на четкое следование инструкции, вы можете столкнуться с целым рядом проблем в процессе установки. Мои проблемы в основном были связаны с тем, что некоторые компоненты у меня уже были поставлены, но версия отличалась. Все проблемы лечатся с помощью всем известного сайта.
Поддержка ОС и языков программирования
Несмотря на смелое заявление о поддержке всех трех популярных ОС, мне показалось, что тестирование было как следует проведено лишь для ОС Windows. Победив проблемы с установкой, ваша головная боль на ОС Windows обещает закончиться. На Linux проблемы, скорее всего, продолжатся, так как поднятый сервер периодически падает, не сообщая причин. Если вы продолжите мои эксперименты – обязательно пишите в комментарях о вашем опыте.
Minecraft Wiki
Из-за новой политики Microsoft в отношении сторонних ресурсов, Minecraft Wiki больше не является официальной. В связи с этим были внесены некоторые изменения, в том числе и обновлён логотип вики-проекта. Подробности на нашем Discord-сервере.
Первая ночь
Заметьте, что переждать первую ночь рекомендуется с помощью кровати. Для её изготовления потребуется отстричь с помощью ножниц или убить овцу, чтобы получить шерсть.
В ночное время суток особую опасность представляют враждебные мобы, которые спаунятся исключительно в темноте. Скорее всего, первыми будут: зомби, скелеты и пауки. Если вы не переждали первую ночь с помощью кровати, рекомендуется создать аварийное жилище и расставить факелы вокруг себя.
Будьте осторожны при встрече более опасных враждебных мобов: странников края, ведьм и криперов. Если не спать более 3-х игровых суток, то над вами начнут появляться фантомы.
Если вы постоянно проигрываете во время ведения боя с враждебными мобами, используйте кнопку Сложность в настройках с параметром Мирный , для отключения спауна. Однако, это не рекомендуется делать, поскольку данная опция имеет ряд недостатков, включая пропадание интереса к Minecraft.
После первого дня
В данном разделе статьи приведены некоторые советы для дальнейшего выживания.
Безопасность жилища
На следующий день, вероятно, ваш дом нуждается в совершенствовании и безопасности:
Вы можете соорудить ловушки для враждебных мобов.
Имейте ввиду, что сон в кровати способствует созданию точки респауна, то есть вам не придётся бегать после проигрыша от точки спауна к своему дому. Используйте компас для нахождения точки респауна.
Добыча руд
Чтобы собирать руды, вам потребуется копать вниз. В сгенерированных пещерах проще найти руды, нежели в искусственных, однако в них спаунятся враждебные мобы, если пещера не освещена. Существуют множество продвинутых способов добычи руд.
Содержание
Malmo: вывод
Авторы фреймворка подарили нам потрясающую возможность погрузиться в любимый мир с другой стороны. Malmo пока что находится в бете, во многих ситуациях он… заставляет совершенствовать свои навыки в troubleshooting. Тем не менее, его плюсы перевешивают все его минусы, а тот факт того, что исходники лежат в открытом доступе на github, позволяет нам самостоятельно доделать нужное место или создать issue для исправления критических багов.
Авторы проекта по понятным для меня причинам не упоминают ни в одной из статей возможность обучать детей на основе фреймворка: ребенок вряд ли справится с борьбой с мелкими, но частыми багами. Тем не менее, я уверена, что если родитель поможет своему ребенку и будет программировать вместе с ним, это даст отличные результаты и позволит вам провести время с пользой.
Форматирование текста
Для форматирования текста в Minecraft используются коды форматирования. Каждый код форматирования начинается с символа § . Для его ввода нужно нажать Alt + 21 .
- текст в чате;
- текст в книге с пером;
- текст в файлах локализации (пример тому название фиолетового цвета у золотого яблока, зачарованного золотого яблока);
- текст на табличках;
- описание сервера;
- название мира;
- название предметов;
- описание предметов (Lore);
- имена сущностей.
По умолчанию в игре форматировать можно только текст в книге с пером. Для этого нужно скопировать символ § , вставить в книгу, ввести нужный символ и написать то, что вы хотите. Некоторые модификации, программы (например, MCEdit) и плагины (например, Essentials) позволяют форматировать текст также в чате, на табличках и в любых других возможных местах.
Форматирование
Цветовое форматирование
Текстовое форматирование
Minecraft: моя предыстория
Я познакомилась с игрушкой, будучи уже студенткой. Это не помешало мне в тот же день отложить все свои личные, рабочие и академические цели, и целиком уйти в кубическую вселенную. Отпустило меня тогда только через месяц, но до сих пор я с радостью захожу иногда побегать часок по любимому миру.
Для меня Minecraft стал продолжением любимой игрушки детства – Lego, исправив ее главный недостаток: постоянную нехватку деталей. Аналог Lego с безлимитными деталями, что может быть лучше.
Хочется особо отметить отсутствие жестокости в этой игре. Вы можете убить зомби или разбежавшись, прыгнуть со скалы. Никто не спорит. Но отсутствие крови очень радует, так же как и милая визуализация зарождения новой жизни.
У Minecraft очень размытое понятие финальной цели. Конечно, вы можете прокачаться и убить дракона, с гордостью сказав, что вы прошли игру. Но так никто не делает. Основной кайф мира Minecraft в том, что каждый раз в нем можно придумать свою личную цель: исследовать мир и найти пещеру с тайниками, построить дом своей мечты, изучить основы электричества или зайти на сервер вместе с другом и делать друг другу всевозможные ловушки. Отсутствие цели в игре – на мой взгляд, главное ее преимущество. Minecraft дает огромный простор для творчества, при этом почти не ставит ограничений.
Изучая сабж, я случайно узнала, что мир Minecraft не ограничивается игрой, мерчем, летсплеями и фан артами. В игре снимают целые сериалы, и – неожиданно – они являются довольно популярными. На мой взгляд, это забавно.
Меня очень обрадовала новость о наличии open source фреймворка для программирования в мире Minecraft. Я твердо уверена, что в будущем в подавляющем числе профессий могут понадобиться базовые навыки программирования. Фреймворк на базе любимой игрушки, на мой взгляд, отличный способ показать ребенку захватывающий мир программирования.
Пример
Следующий текст можно вставить в книгу с пером, чтобы создать то, что показано на картинке:
Читайте также: