Научная статья на тему 'СОВРЕМЕННЫЕ ПОДХОДЫ К ОБУЧЕНИЮ ИНТЕЛЛЕКТУАЛЬНЫХ АГЕНТОВ В СРЕДЕ Atari'

СОВРЕМЕННЫЕ ПОДХОДЫ К ОБУЧЕНИЮ ИНТЕЛЛЕКТУАЛЬНЫХ АГЕНТОВ В СРЕДЕ Atari Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
1091
208
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
Atari / интеллектуальные агенты / обучение с подкреплением / Q-обучение / градиент по стратегиям / асинхронный актор-критик / распознавание образов / выделение признаков / Atari / intelligent agents / reinforcement learning / Q-learning / policy gradient / asynchronous actor-critic / pattern recognition / feature extraction

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Д А. Коробов, С А. Беляев

Статья посвящена разработке и исследованию алгоритмов машинного обучения в задаче обучения интеллектуальных агентов в среде Atari, представляющей эмуляцию игровой консоли Atari2600 при помощи платформы OpenAI Gym. Основные цели исследования – описание и сравнение современных алгоритмов обучения с подкреплением в различных ситуациях, выявление их достоинств и недостатков, а также формирование предложений по повышению эффективности этих алгоритмов. Авторы описывают математическую модель задачи обучения с подкреплением в виде марковского процесса принятия решений и формируют критерий оптимальности системы. Отдельно отмечены особенности, характерные для среды Atari. Описаны принцип работы существующих решений, а также использующиеся в них инструменты. Рассмотрены базовый подход Q-обучения и его известная модификация с использованием нейронной сети. Представлена идея алгоритма на основе градиента по стратегиям. Дано описание подхода алгоритмов типа «актор-критик», а также рассмотрена его асинхронная многопоточная версия. Все рассмотренные алгоритмы описаны в виде псевдокода. Предложен способ повышения эффективности обучения с помощью выделения признаков. Разработан алгоритм генерации вектора признаков на основе распознавания образов. Описаны этапы формирования вектора признаков и его использования в процессе обучения. Алгоритмы реализованы, проведен эксперимент с их использованием. Выполнен сравнительный анализ результатов и получены выводы об эффективности алгоритмов. Предложены идеи по дальнейшему увеличению скорости и качества обучения интеллектуальных агентов.

i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Д А. Коробов, С А. Беляев

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

MODERN APPROACHES TO TRAINING INTELLIGENT AGENTS IN THE Atari ENVIRONMENT

The article describes the research and development of machine learning algorithms for the problem of training intelligent agents in the Atari environment. The environment is the game console Atari2600 emulation on OpenAI Gym platform. The main aims of the research are to describe and compare modern learning algorithms with reinforcement in a number of cases, to expose their advantages and drawbacks and to give suggestions in order to increase their effectiveness. The authors describe a mathematical model of the reinforcement learning task in terms of Markov Decision Process and form a system optimality criterion. In addition, they note the Atari environment properties. There is a description of an operation principle of existing solutions, as well as the tools used in them. The paper considers a basic Q-learning approach and its well-known modification that uses a neural network. It also presents the idea of the algorithm based on policy gradient. The paper gives a description of the approach of “actor-critic” algorithms and considers its asynchronous multithreaded version. All the described algorithms are presented in pseudocode. The authors propose a method of increasing the effectiveness of learning using feature extraction. The developed algorithm for feature vector generation is based on image recognition. The paper describes the steps of feature vector selection and its usage during the learning process. The described algorithms are implemented, and the experiment is conducted. A comparative analysis of the results gave conclusions on the efficiency of the algorithms. Finally, the authors propose some ideas for further increasing the speed and efficiency of training of intelligent agents.

Текст научной работы на тему «СОВРЕМЕННЫЕ ПОДХОДЫ К ОБУЧЕНИЮ ИНТЕЛЛЕКТУАЛЬНЫХ АГЕНТОВ В СРЕДЕ Atari»

УДК 004.02 Дата подачи статьи: 09.02.18

DOI: 10.15827/0236-235X.031.2.284-290 2018. Т. 31. № 2. С. 284-290

СОВРЕМЕННЫЕ ПОДХОДЫ К ОБУЧЕНИЮ ИНТЕЛЛЕКТУАЛЬНЫХ АГЕНТОВ В СРЕДЕ Atari

Д.А. Коробов 1, студент, [email protected] С.А. Беляев 1, к.т.н., доцент, [email protected]

1 Санкт-Петербургский государственный электротехнический университет «ЛЭТИ» им. В.И. Ульянова (Ленина), ул. Профессора Попова, 5, г. Санкт-Петербург, 197376, Россия

Статья посвящена разработке и исследованию алгоритмов машинного обучения в задаче обучения интеллектуальных агентов в среде Atari, представляющей эмуляцию игровой консоли Atari2600 при помощи платформы OpenAI Gym. Основные цели исследования - описание и сравнение современных алгоритмов обучения с подкреплением в различных ситуациях, выявление их достоинств и недостатков, а также формирование предложений по повышению эффективности этих алгоритмов.

Авторы описывают математическую модель задачи обучения с подкреплением в виде марковского процесса принятия решений и формируют критерий оптимальности системы. Отдельно отмечены особенности, характерные для среды Atari.

Описаны принцип работы существующих решений, а также использующиеся в них инструменты. Рассмотрены базовый подход Q-обучения и его известная модификация с использованием нейронной сети. Представлена идея алгоритма на основе градиента по стратегиям. Дано описание подхода алгоритмов типа «актор-критик», а также рассмотрена его асинхронная многопоточная версия. Все рассмотренные алгоритмы описаны в виде псевдокода.

Предложен способ повышения эффективности обучения с помощью выделения признаков. Разработан алгоритм генерации вектора признаков на основе распознавания образов. Описаны этапы формирования вектора признаков и его использования в процессе обучения.

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

Ключевые слова: Atari, интеллектуальные агенты, обучение с подкреплением, Q-обучение, градиент по стратегиям, асинхронный актор-критик, распознавание образов, выделение признаков.

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

Одной из платформ, позволяющих проводить разработку и исследование алгоритмов машинного обучения, является OpenAI Gym, включающая в себя возможность эмуляции игровой консоли Atari2600. В качестве входных данных среда Atari предоставляет последовательность изображений экрана размера 210*160 пикселей, а также общий игровой счет и индикатор победы или поражения. На основе описанных входных данных агент должен выбрать одно из возможных действий с помощью обучения с подкреплением - машинное обучение, направленное на решение задачи принятия решения о выборе действия в заданной ситуации таким образом, чтобы максимизировать выгоду в долгосрочной перспективе [2]. В частности, интерес представляют интеллектуальные агенты, не зависящие от правил игры, то есть способные проходить несколько различных игр Atari без изменения

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

Формальная постановка задачи

Стандартным способом формализации задачи обучения с подкреплением является представление ее в виде марковского процесса принятия решений (МППР) [3]. МППР предоставляет способ редукции задачи принятия решения к следующим ключевым компонентам: множеству состояний S, множеству действий^, функции перехода Р : S х А —>■ —> Disi(S). функции награды Р : S х А —>■ К и фактору дисконтирования у, где Dist(S) - пространство всех распределений вероятности на множестве X. В среде Atari предполагается, что S и A - конечные множества. На каждом шаге t агент исследует состояние st е S и выбирает действие at е A. Далее агент получает награду rt : = R(st, at) и новое состояние st+\ из распределения P(-|st, at). В МППР переходы удовлетворяют свойству марковости: для любых s+1 и для любой истории состояний и действий so, ao, ..., st, at выполняется следующее равенство:

Pr( st+i I so> ao> ■■■> s,-1' at-i> st - at) = (1)

= Pr(st+! 1 st, at):= P(st+1 1 s,, at).

Результат действия зависит только от текущего состояния и не зависит от предыдущих состояний. Поведение агента описывается стратегией л : S ^ ^ Dist(A), которая отображает множество состояний в распределение вероятностей над множеством действий. Под стратегией понимаются весовые коэффициенты модели, корректируемые агентом в процессе обучения.

Важным является то, что в среде Atari отдаленные награды менее значимы, чем ближайшие. Фактор дисконтирования у может иметь значение 0 или 1: 0 означает, что только настоящее имеет значение, а 1 - что будущие награды имеют полный вес в принятии решения:

Rt = rt + y(rt+1 + y(rt+2 +...» = rt + yR +1. Цель агента - найти оптимальный план - стратегию, максимизирующую ожидаемую полезность из любого состояния st, определяемую как математическое ожидание суммы дисконтированных бу-

дущих наград:

где последователь-

ность будущих состояний {sv+1, st+2, ...} индуцируется функцией перехода P и стратегией п.

Существующие решения

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

- Deep Q-learning (глубокое Q-обучение);

- REINFORCE (алгоритм на основе градиентов по стратегиям);

- A3C (алгоритм асинхронного актора-критика).

Алгоритмы Q-обучения оперируют функцией качества Q(s, a), обозначающей наибольший возможный счет, которого можно достичь в конце игры после выбора действия a в состоянии s. Функцию Q(s, a) можно определить рекурсивно:

Q*(s, a) = R(s, a) =

= yV T (s, a, s') * max Q*(s', a'), (2)

s ES a'

где T(s, a, s') - вероятность перехода в состояние s' из состояния s в случае выбора действия a. Однако, так как функции R(s, a) и T(s, a, s') априори неизвестны, требуется оценивать Q*(s, a) и обновлять

оценку по мере исследования игры в соответствии с различными действиями а в различных состояниях s, учитывая при этом награду r и следующее состояние s'. Правило итеративного обновления оценки Q выглядит следующим образом: Q (s, a) = Q(s, a) +

Г 1 (3)

+a r + y max Q(s' , a') - Q(s, a) ,

_ a' _

где у - фактор дисконтирования; a - скорость обучения, определяющая степень значимости новых наблюдений при обновлении оценки. При a = 1, например, предыдущие оценки не учитываются. В начале обучения оценка max Q(s', a') может

a'

быть далека от истинного значения, но по мере обновления Q(s, a) гарантируется сходимость к истинной функции [5]. Основная идея алгоритма Q-обучения выглядит следующим образом:

Инициализировать Q(s, a) произвольным образом Получить начальное состояние s для каждого эпизода:

Выбрать и выполнить действие a Получить награду r и новое состояние s'

Q(s, a) ^ Q(s, a) + a |r + y max Q(s, a') - Q(s, a) j

В случае, когда среда имеет дискретное пространство состояний, а агент дискретное количество возможных действий, модель динамики среды представляет собой одношаговую матрицу перехода: T(s(t+1) | s(t), s(a)). Данная стохастическая матрица содержит все вероятности перехода в желаемое состояние из текущего при выборе каждого действия. В среде Atari пространство состояний после масштабирования без потери информации является множеством изображений размера 64*64 пикселя, а агент имеет 18 возможных действий, значит, размер матрицы перехода вычисляется следующим образом: |S х S х A| и |(66.7 х 109) х (66.7 х х 109) х 18 |, что при 32-битном размере элемента матрицы требует 3.4*1014 Гб памяти. Из-за невозможности хранить такой объем памяти требуется аппроксимировать таблицу переходов.

Алгоритм Deep Q-learning (DQN), описанный впервые в [6], использует нейронную сеть для аппроксимации функции Q. Теперь вместо того, чтобы обновлять функцию Q напрямую, нейронной сети передается состояние s, после чего сеть возвращает значения Q для каждого возможного действия.

Одной из особенностей использования нейронных сетей в обучении с подкреплением является отсутствие гарантий сходимости. Для улучшения сходимости применяется метод сохранения предыдущего опыта в памяти (experience replay memory). Вместо обучения сети на каждом переходе в новое состояние и отбрасывания этого перехода в памяти сохраняются N предыдущих переходов, а при обучении используется случайная выборка из данных

s = s

переходов [7]. При выборе действия теперь также используется е-жадная стратегия, которая заключается в том, что вместо выбора наиболее выгодного действия агент с вероятностью е выбирает случайное действие. В итоге с учетом рассмотренных замечаний алгоритм DQN выглядит следующим образом:

Инициализировать память переходов D Инициализировать модель вычисления Q(s, a)

случайными весами Получить начальное состояние s для каждого эпизода:

Выбрать и выполнить действие a:{

с вероятностью е выбрать случайное

действие

иначе выбрать a = argmaxQ(s, a')

}

Получить награду r и новое состояние s'

Сохранить переход <s, a, r, s'> в памяти D

Получить выборку переходов <ss, aa, rr, ss'>

из памяти

Вычислить tt для каждого элемента выборки{ если ss' - терминальное состояние,

то tt = rr

иначе tt = rr + 7 max Q (ss aa ')

}

Обучить сеть, используя (tt - Q ( ss, aa))

в качестве функции потерь

Алгоритмы на основе градиентов по стратегиям (policy gradient) представляют собой тип алгоритмов обучения с подкреплением, которые полагаются на оптимизацию параметров стратегии в соответствии с ожидаемой суммарной наградой, используя для этого градиентный спуск [8]. Классическим алгоритмом данного типа является REINFORCE, особенность которого в том, что в процессе обновления стратегии (корректировки весов модели) он учитывает всю траекторию агента. Под траекторией понимается последовательность всех переходов - четверок объектов S х A ^ S х R (состояние, действие, новое состояние, награда) на протяжении периода одной игры. Задачей алгоритма является максимизация ожидаемой суммарной награды:

рО) = Е

(4)

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

p(s) = х P со * RCO, (5)

X

где 0 определяет параметры обучаемой модели. С целью максимизации функции p(s) вычисляется

градиент р по 0, который после преобразований, описанных в [3], представляется в виде

dpÇQ 56

R(z)

5 log (ад)

56

(6)

„ (Df ^ 5log(p(x))

Градиент V0 (p (x)) =---1 - это вектор,

50

направленный в сторону возрастания функции p(.v). Аппроксимируя математическое ожидание 1Ег средним арифметическим по T переходам в рамках одного эпизода (игры), получаем правило обновления вектора коэффициентов 0, максимизирующее функцию суммарной награды:

0i+1 =0, +« * R(x)* V0(P0 (X)). (7)

Псевдокод алгоритма будет следующим:

Вход: модель, задающая стратегию

я(а| s, 0), Va е A, s е S Инициализировать веса модели 0 повторять бесконечно:

Сгенерировать эпизод S0, A0, Ri, ..., ST-i, AT-J, RT,

следуя стратегии п для каждого шага t=0,...,T-1: Rt ^ вычислить 0^0 + а* R, *V( P (t))

Алгоритмы типа «актор-критик» оперируют как стратегией (актор), так и функцией полезности (критик), формируя стратегию подобно алгоритму REINFORCE. Отличие заключается в том, что для расчета градиента используется функция полезности, а не траектория. Во время перехода в новое состояние система получает сигнал о значении награды и вычисляет функцию полезности по методу временной разности (temporal difference) при помощи уравнения Беллмана [9]. Функция полезности затем используется для корректировки весов модели.

В статье [10], описывающей асинхронные методы для глубокого обучения с подкреплением, был представлен алгоритм асинхронного актора-критика (Asynchronous Advantage Actor-Critic -A3C), использующий несколько копий нейронной сети и несколько экземпляров среды, где каждый агент взаимодействует со своей собственной копией среды. Результаты, полученные несколькими агентами, в дальнейшем объединяются в глобальную модель. Рассматриваемая версия алгоритма использует функцию преимущества A, которая оценивается, используя дисконтированную сумму будущих наград R: A = R - V(s), где V(s) - функция, обозначающая наибольший счет, которого можно достичь из состояния s, и не зависящая от действий агента. Псевдокод алгоритма АЗС:

Задать глобальные общие векторы параметров 0 и 0v и глобальный общий счётчик

T = 0

Задать векторы параметров 0' и 0V' для каждого

потока

т

s — s

Инициализировать счётчик шагов потока t^1 повторять:

Обновить градиенты: d0 и d9V ^ 0

Синхронизировать: 0' = 0 и 0V' = 0V

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

tstart = t

Получить состояние st

повторять:

Выполнить действие at согласно

стратегии л(a I s,,9' ) Получить награду rt и новое состояние st+1 t ^ t + 1 T ^ T + 1

до тех пор пока st терминал или t - tstart == tmax f0, для терминала st

(s,9'„), для нетерминала st

для i e {t - 1, ..., tsstcrt]:

R ^ r + y * R

d9^ d9 + V0, log л(a I s,9')(R - V(s,,9'))

d9^d9, + 3(R-V(s ,Q'v))2/39'v

Выполнить асинхронное обновление 0 и 0v пока T < TmaI

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

Редукция задачи посредством распознавания образов

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

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

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

2. Обучение. Как только агент начинает действовать, на каждом шаге распознаются объекты классов c e C, с их помощью происходит генерация вектора признаков.

Метод распознавания объектов классов использует классы, полученные на предыдущем этапе. Формально ставится задача нахождения списка Tt(c), содержащего координаты и скорости всех экземпляров класса c на экране Xt для каждого класса c e C. Сначала строится список всех возможных фигур всех классов, который затем упорядочивается по размеру от самой большой фигуры к самой маленькой. Далее изображение экрана сканируется на предмет наличия каждой фигуры o из списка. Если совпадение найдено, пиксели помечаются как

L!™!J

ru ; Ü I

Статический фон

Распознанные сгущения

Результат предобработки The result of preprocessing

I.

Классы объектов

распознанные и в дальнейшем не учитываются. Центр масс распознанных пикселей добавляется в список T(o. class).

За распознаванием объектов классов следует этап генерации вектора признаков для обучения модели. В результате вектор признаков содержит следующие данные:

- количество объектов каждого класса (в зависимости от наличия или отсутствия определенных объектов действия агента могут различаться);

- абсолютное положение каждого объекта (координаты объектов - основная информация, необходимая для построения эффективной стратегии);

- векторы скорости объектов (направление движения играет значительную роль при принятии решения о выборе следующего действия; скорость определяется разностью координат объектов и

W-0.

На каждом экране класс с может иметь от 0 до nc(t) экземпляров, где nc(t) не является постоянным и зависит от этапа игры. Однако все алгоритмы обучения с подкреплением требуют на входе вектор фиксированной длины. Следовательно, необходимо найти способ эффективной генерации вектора фиксированной длины из распознанных объектов.

Пусть N = max n (t) - максимально возмож-

c t c

ное число объектов класса с, которые встретились в последовательности изображений экрана [X1, X2, ., Xn]. Тогда для нахождения числа Nc для каждого класса c e C необходимо на этапе предобработки сохранять и максимальное количество встретившихся объектов каждого класса.

При использовании данного подхода вектор признаков будет иметь размер, зависящий от суммы максимального количества объектов каждого класса. Помимо количества объектов n класса c, в векторе признаков содержатся 2-n координат (x и у) и 2-n скоростей (vx и vy). Значит, итоговый размер вектора будет следующим: N = Z(1 + 2 * N + 2 * N) = size(C) + 4* £ N . (8)

c c

Псевдокод общего алгоритма генерации вектора признаков на основе распознавания образов:

Пусть заданы C - множество классов и Nc -максимальное возможное количество экземпляров класса c для данной игры Входные данные: Xt - изображение экрана Выходные данные: Vt - вектор признаков

1. ^ распознать объекты класса (Xt)

2. вычислить скорости (^t, *¥t.j)

3. для ceC:

n ^ количество непустых, объектов класса *¥t(c) Добавить n в вектор Vt для \^ex¥t(c):

если ^ - не пустой:

Добавить [^.x, ^.x, ^.vy] в вектор Vt

иначе :

Добавить [null, null, null, null] в вектор Vt

OpenAI Gym.

Сравнительная характеристика алгоритмов

Эксперимент проводился при помощи открытой платформы машинного обучения OpenAI Gym. Реализованные на языке Python с использованием фреймворка Tensorflow алгоритмы исследовались в следующих играх Atari: Pong, Breakout, SpaceInvaders, MsPacman. В качестве оборудования использовалась виртуальная машина Google Cloud, имеющая 4 Гб оперативной памяти и один виртуальный CPU, где под виртуальным CPU понимается вычислительная мощность, эквивалентная мощности одного ядра процессора Intel Xeon E5 v3 (Haswell) - 2.3 GHz.

Для проведения оценки результатов введем следующие понятия. Пусть эпизод - одна тренировочная игра от начала партии до перезагрузки (победы или поражения). Принятие решения о выборе действия a в состоянии s с переходом в состояние s' назовем итерацией. Шагом обучения будем называть процесс обучения сети, то есть пересчет весов модели, который может выполняться либо каждую итерацию (как в REINFORCE), либо через каждые к итераций.

Первый эксперимент проводился в среде Pong. Модели обучались на вычислительном сервере в течение 32 часов. Оценка результатов проводилась с помощью 100 тестовых игр, затем вычислялись средний и максимальный игровой счет в выборке. Также оценивались следующие параметры: количество эпизодов и количество шагов обучения (табл. 1).

Таблица 1

Эксперимент 1 - pong

Table 1

Experiment 1 - pong

Время Коли- Количе- Сред- Макси-

Алго- обуче- чество ство ша- ний маль-

ритм ния эпизо- гов обуче- счет ный

(часов) дов ния счет

REINFORCE 2 1476 348000 -14.8 -11

8 4792 1329000 -10.2 -7

32 11035 4782000 -11.8 -4

DQN 2 167 48000 -18.1 -17

8 598 186000 -13.3 -7

32 1490 686000 -11.2 -4

A3C 2 813 4300 -16.9 -11

8 2075 12000 -13.2 -10

32 7359 45000 -7.8 -2

Алгоритм A3C требует наименьшего числа шагов обучения на эпизод игры (6 шагов/эпизод) по сравнению с REINFORCE (756 шагов/эпизод) и DQN (460 шагов/эпизод), что позволяет сократить

количество обновлений модели. Тем не менее, для алгоритма DQN требуется наименьшее число эпизодов по сравнению с другими алгоритмами при сравнимом конечном результате (максимальном счете). Учитывая, что производительность разработанного метода формирования вектора признаков пропорциональна количеству эпизодов, было принято решение применить алгоритм распознавания образов к алгоритму DQN.

Задачей второго эксперимента было исследование возможностей использования DQN в различных играх. Для каждой игры представлены три результата: до начала обучения (стратегия случайного выбора действия), а также счет после 32 часов обучения на пикселах и в результате применения метода формирования вектора признаков (табл. 2). В первом случае в классическом варианте DQN используется сверточная нейронная сеть следующего вида: слой с 32 фильтрами размера 8*8 с шагом 4, слой с 64 фильтрами размера 4*4 с шагом 2, слой с 64 фильтрами размера 3*3 с шагом 1, полносвязный слой из 512 нейронов. Каждый из слоев также содержит ReLU-блок. В варианте, включающем процедуру распознавания образов, полученный вектор признаков проходит обучение лишь на полносвязном слое, содержащем 512 нейронов и ReLU-блок, минуя при этом сверточные слои.

Таблица 2 Эксперимент 2 - исследование DQN

Table 2

Experiment 2 - research on DQN

По результатам эксперимента можно сделать вывод, что алгоритм DQN показывает хорошие результаты в игре MsPacman. Вероятно, это связано с тем, что в данной игре агенту довольно просто принять решение, ориентируясь на отдельное состояние экрана. Неплохие результаты обучения в игре Pong связаны с достаточно простыми правилами игры и небольшим числом сущностей (3 объекта). В таких динамичных играх, как Spacelnvaders и Breakout, есть сложности в оценке динамики по одному состоянию без использования траектории и расчет Q-функции оказывается не слишком эффек-

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

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

Заключение

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

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

Литература

1. Рассел С., Норвиг П. Искусственный интеллект. Современный подход. М.: Вильямс, 2007. 1410 с.

2. Mnih V., Kavukcuoglu K., Silver D., Graves A., Antono-glou I., Wierstra D., Riedmiller M. Playing Atari with deep reinforcement learning. NIPS Deep Learning Workshop, 2013. URL: https://arxiv.org/pdf/1312.5602.pdf (дата обращения: 08.02.2018).

3. Саттон Р.С., Барто Э.Г. Обучение с подкреплением. М.: Бином, 2017. 400 с.

4. Гудфеллоу Я., Бенджио И., Курвилль А. Глубокое обучение. М.: ДМК-Пресс, 2017. 652 с.

5. Melo F.S. Convergence of Q-learning: A simple proof. Tech. Rep. 2011. URL: http://users.isr.ist.utl.pt/~mtjspaan/reading-Group/ProofQlearning.pdf (дата обращения: 08.02.2018).

6. Mnih V. Human-level control through deep reinforcement learning. Nature, 2015, vol. 518, no. 7540, pp. 529-533.

7. Schaul T., Quan J., Antonoglou I., Silver D. Prioritized experience replay. Proc. ICLR-16. 2016. URL: http://www0.cs.ucl. ac.uk/staff/d.silver/web/Publications_files/prioritized-replay.pdf (дата обращения: 08.02.2018).

8. Silver D., Lever G., Heess N., Degris T., Wierstra D., Riedmiller M. Deterministic policy gradient algorithms. Proc. ICML-14. 2014. URL: http://www0.cs.ucl.ac.uk/staff/d.silver/web/Publica-tions_files/deterministic-policy-gradients.pdf (дата обращения: 08.02.2018).

9. Николенко С., Кадурин А., Архангельская Е. Глубокое обучение. СПб: Питер, 2017. 480 с.

10. Mnih V., Badia A.P., Mirza M., Graves A., Harley T., Lil-licrap T.P., Silver D., Kavukcuoglu K. Asynchronous methods for deep reinforcement learning. Proc. ICML-16, 2016. URL: https:// arxiv.org/pdf/1602.01783.pdf (дата обращения: 08.02.2018).

Игра Стратегия случайного выбора действия Обучение с использованием сверточ-ной нейронной сети Обучение с использованием вектора признаков

А B А B А B

Pong -20.2 -19 -11.2 -4 -9.1 2

MsPacman 216 420 562 1210 798 1730

Space-Invaders 207.5 290 296 560 345 735

Breakout 1.3 3 3.2 7 6.3 12

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

Примечание: в таблице А - средний счет, B - максимальный счет.

11. Liu D.R., Li H.L., Wang D. Feature selection and feature I vey. Intern. J. Automation and Computing. 2015, vol. 12, learning for high-dimensional batch reinforcement learning: A sur- | pp. 229-242.

Software & Systems Received 09.02.18

DOI: 10.15827/0236-235X.031.2.284-290 2018, vol. 31, no. 2, pp. 284-290

MODERN APPROACHES TO TRAINING INTELLIGENT AGENTS IN THE Atari ENVIRONMENT D.A. Korobov 1, Student, [email protected]

S.A. Belyaev 1, Ph.D. (Engineering), Associate Professor, [email protected]

1 St. PetersburgElectrotechnical University "LETI", Prof. Popov St. 5, St. Petersburg, 197376, Russian Federation

Abstract. The article describes the research and development of machine learning algorithms for the problem of training intelligent agents in the Atari environment. The environment is the game console Atari2600 emulation on OpenAI Gym platform. The main aims of the research are to describe and compare modern learning algorithms with reinforcement in a number of cases, to expose their advantages and drawbacks and to give suggestions in order to increase their effectiveness.

The authors describe a mathematical model of the reinforcement learning task in terms of Markov Decision Process and form a system optimality criterion. In addition, they note the Atari environment properties.

There is a description of an operation principle of existing solutions, as well as the tools used in them. The paper considers a basic Q-learning approach and its well-known modification that uses a neural network. It also presents the idea of the algorithm based on policy gradient. The paper gives a description of the approach of "actor-critic" algorithms and considers its asynchronous multithreaded version. All the described algorithms are presented in pseudocode.

The authors propose a method of increasing the effectiveness of learning using feature extraction. The developed algorithm for feature vector generation is based on image recognition. The paper describes the steps of feature vector selection and its usage during the learning process.

The described algorithms are implemented, and the experiment is conducted. A comparative analysis of the results gave conclusions on the efficiency of the algorithms. Finally, the authors propose some ideas for further increasing the speed and efficiency of training of intelligent agents.

Keywords: Atari, intelligent agents, reinforcement learning, Q-learning, policy gradient, asynchronous actor-critic, pattern recognition, feature extraction.

References

1. Russell S., Norvig P. Artificial Intelligence. A Modern Approach. 2nd ed., Pearson Publ., 2006, 1112 p. (Russ. ed.: Moscow, Vilyams Publ., 2007, 1410 p.).

2. Mnih V., Kavukcuoglu K., Silver D., Graves A., Antonoglou I., Wierstra D., Riedmiller M. Playing Atari with deep reinforcement learning. NIPS Deep Learning Workshop. USA, 2013. Available at: https://arxiv.org/pdf/1312.5602.pdf (accessed February 8, 2018).

3. Sutton R.S., Barto A.G. Reinforcement Learning: An Introduction. A Bradford Book Publ., 1998, 322 p. (Russ. ed.: Moscow, Binom Publ., 2017, 400 p.).

4. Goodfellow I., Bengio Y., Courville A. Deep Learning. MIT Press, 2016, 775 p. (Russ. ed.: Moscow, DMK-Press, 2017, 652 p.).

5. Melo F.S. Convergence of Q-learning: A simple proof. Institute of Systems and Robotics. Tech. Rep. Lisbon. 2011. Available at: http://users.isr.ist.utl.pt/~mtjspaan/readingGroup/ProofQlearning.pdf (accessed February 8, 2018).

6. Mnih V. Human-level control through deep reinforcement learning. Nature. 2015, vol. 518, no. 7540, pp. 529-533.

7. Schaul T. Quan J., Antonoglou I., Silver D. Prioritized experience replay. Proc. ICLR-16. 2016. Available at: http://www0.cs.ucl.ac.uk/staff/d.silver/web/Publications_files/prioritized-replay.pdf (accessed February 8, 2018).

8. Silver D. Lever G., Heess N., Degris T., Wierstra D., Riedmiller M. Deterministic policy gradient algorithms. Proc. ICML-14. 2014. Available at: http://www0.cs.ucl.ac.uk/staff/d.silver/web/Publications_files/deterministic-policy-gradi-ents.pdf (accessed February 8, 2018).

9. Nikolenko S., Kadurin A., Arkhangelskaya E. Glubokoe obuchenie [Deep Learning]. Piter Publ., 2017, 480 p.

10. Mnih V. Badia A.P., Mirza M., Graves A., Harley T., Lillicrap T.P., Silver D., Kavukcuoglu K. Asynchronous methods for deep reinforcement learning. Proc. ICML-16. 2016. Available at: https://arxiv.org/pdf/1602.01783.pdf (accessed February 8, 2018).

11. Liu D.R., Li H.L., Wang D. Feature selection and feature learning for high-dimensional batch reinforcement learning: A survey. Int. J. of Automation and Computing. 2015, vol. 12, pp. 229-242.

i Надоели баннеры? Вы всегда можете отключить рекламу.