Skip to content

lbarasc/Text_based_Game

Repository files navigation

Text_based_Game

Reinforcement Learning

Intro

In this project, we address the task of learning control policies for text-based games using reinforcement learning. In these games, all interactions between players and the virtual world are through text. The current world state is described by elaborate text, and the underlying state is not directly observable. Players read descriptions of the state and respond with natural language commands to take actions.

For this project we will conduct experiments on a small Home World, which mimic the environment of a typical house.The world consists of a few rooms, and each room contains a representative object that the player can interact with. For instance, the kitchen has an apple that the player can eat. The goal of the player is to finish some quest. An example of a quest given to the player in text is You are hungry now . To complete this quest, the player has to navigate through the house to reach the kitchen and eat the apple. In this game, the room is hidden from the player, who only receives a description of the underlying room. At each step, the player read the text describing the current room and the quest, and respond with some command (e.g., eat apple ). The player then receives some reward that depends on the state and his/her command.

In order to design an autonomous game player, we will employ a reinforcement learning framework to learn command policies using game rewards as feedback. Since the state observable to the player is described in text, we have to choose a mechanism that maps text descriptions into vector representations. A naive approach is to create a map that assigns a unique index for each text description. However, such approach becomes difficult to implement when the number of textual state descriptions are huge. An alternative method is to use a bag-of-words representation derived from the text description.

Tasks:

  1. Implement the tabular Q-learning algorithm for a simple setting where each text description is associated with a unique index.
  2. Implement the Q-learning algorithm with linear approximation architecture, using bag-of-words representation for textual state description.
  3. Implement a deep Q-network.
  4. Use the Q-learning algorithms on the Home World game.

Home World Game

image We will conduct experiments on a small Home World, which mimic the environment of a typical house. The world consists of four rooms- a living room, a bed room, a kitchen and a garden with connecting pathways (illustrated in figure below). Transitions between the rooms are deterministic. Each room contains a representative object that the player can interact with. For instance, the living room has a TV that the player can watch , and the kitchen has an apple that the player can eat. Each room has several descriptions, invoked randomly on each visit by the player.

image image image image

Using the defined optimal expected reward achievable, it can be computed that each episode the expected optimal reward is 0.55375.

Q-learning Algorithm

In this section, we will implement the Q-learning algorithm, which is a model-free algorithm used to learn an optimal Q-function. In the tabular setting, the algorithm maintains the Q-value for all possible state-action pairs. Starting from a random Q-function, the agent continuously collects experiences (s, c, R(s, c), s') and updates its Q-function.

image

Epsilon-greedy exploration

image

Tabular Q-learning for Home World game

In this section we will consider a simple approach that assigns a unique index for each text description. In particular, we will build two dictionaries:

  • dict_room_desc that takes the room description text as the key and returns a unique scalar index
  • dict_quest_desc that takes the quest description text as the key and returns a unique scalar index.

image

Performance

By initializing:

  • Q at zero
  • Number of runs 10
  • Number of episodes for training at each epoch 25
  • Number of episodes for testing 50
  • Discount factor (gamma) 0.5
  • Training epsilon-greedy 0.5
  • Testing epsion-greedy 0.05
  • Learning rate (alpha) 0.1 (too large=learning is too unstable but the faster the convergence, too small=learning is too slow to converge)

The number of epoch in which the learning algorithm converges is 13, meanwhile the average episodic rewards of the Q-learning algorithm when it converges is 0.5058.

Fig_1_Agent_Tabular

Q-learning with linear function approximation

First Approach

image The approach as explained above won't work since the feature engineering is not sufficient to learn a good approximation of the optimal Q-function.

Second Approach

image

Computing theta update rule

image image image image

Using the hyperparameters:

  • Number of runs 5,
  • Number of episodes for training at each epoch 25,
  • Number of episodes for testing 50,
  • Discount factor (gamma) 0.5,
  • Training epsilon-greedy 0.5,
  • Testing epsion-greedy 0.05, and
  • Learning rate (alpha) 0.01, the average episodic rewards of the Q-learning algorithm when it converges is 0.3862.

Fig_2_Agent_Linear

Deep Q-network (DQN)

As seen in the previous part, a linear model is not able to correctly approximate the Q-function for our simple task. In this part, we will approximate Q(s, c) with a neural network. We will be using a DQN that takes the state representation (bag-of-words) and outputs the predicted Q values for the different "actions" and "objects".

The hyperparameter values are as follows:

  • Number of runs 10,
  • Number of episodes for training at each epoch 25,
  • Number of episodes for testing 50,
  • Discount factor (gamma) 0.5,
  • Training epsilon-greedy 0.5,
  • Testing epsion-greedy 0.05, and
  • Learning rate (alpha) 0.1,

The setup of the neural nets is as follows:

  • One fully connected layer with size 100 (state encoder)
  • One fully connected layer with size equals to action dimension (4) to get the action index
  • One fully connected layer with size equals to object dimension (4) to get the object index

Using the DQN, the average episodic rewards of the Q-learning algorithm when it converges is 0.48.

Fig_3_Agent_DQN

About

Reinforcement Learning

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages