Minimalistic Gridworld Environment (MiniGrid)

Maxime Chevalier-Boisvert 396fb953cf Fixup 7 роки тому
basicrl 8fc72cda9f Fixed basicrl code 7 роки тому
figures db29cb23d6 Added descriptions and images to README 7 роки тому
gym_minigrid cacb438c76 Added list of environments to README 7 роки тому
.gitignore 8fc72cda9f Fixed basicrl code 7 роки тому
LICENSE 51a5d9079d Initial commit 7 роки тому
README.md 396fb953cf Fixup 7 роки тому
setup.py f28a1ba73f Updated README 7 роки тому
standalone.py a7a56cdfe2 Added keyboard handling to standalone.py 7 роки тому

README.md

Minimalistic Grid World Environment (MiniGrid)

There are other grid world Gym environments out there, but this one is designed to be particularly simple, lightweight and fast. The code has very few dependencies, making it less likely to break or fail to install. It loads no external sprites/textures, and it can run at up to 5800 FPS on a quad-core laptop, which means you can run your experiments faster.

Installation

Clone this repository and install the other dependencies with pip3:

git clone https://github.com/maximecb/gym-minigrid.git
cd gym-minigrid
pip3 install -e .

Optionally, if you wish use the reinforcement learning code included under /basicrl, you can install its dependencies as follows:

cd basicrl

# PyTorch
conda install pytorch torchvision -c soumith

# OpenAI baselines
git clone https://github.com/openai/baselines.git
cd baselines
pip install -e .

# Other requirements
pip install -r requirements.txt

Note: the basicrl code is a custom fork of this repository, which was modified to work with this environment.

Basic Usage

To run the standalone UI application, which allows you to manually control the agent with the arrow keys:

./standalone.py

The environment being run can be selected with the --env-name option, eg:

./standalone.py --env-name MiniGrid-Empty-8x8-v0

Basic reinforcement learning code is provided in the basicrl subdirectory. You can perform training using the ACKTR algorithm with:

python3 basicrl/main.py --env-name MiniGrid-Empty-8x8-v0 --no-vis --num-processes 32 --algo acktr

You can view the result of training using the enjoy.py script:

python3 basicrl/enjoy.py --env-name MiniGrid-Empty-8x8-v0 --load-dir ./trained_models/acktr

Included Environments

The environments listed below are implemented and registered in simple_envs.py.

Empty environment

Registered configurations:

  • MiniGrid-Empty-8x8-v0
  • MiniGrid-Empty-6x6-v0

This environment is an empty room, and the goal of the agent is to reach the green goal square, which provides a sparse reward. A small penalty is subtracted for the number of steps to reach the goal. This environment is useful, with small rooms, to validate that your RL algorithm works correctly, and with large rooms to experiment with sparse rewards.

Door & key environment

Registered configurations:

  • MiniGrid-Door-Key-8x8-v0
  • MiniGrid-Door-Key-16x16-v0

This environment has a key that the agent must pick up in order to unlock a goal and then get to the green goal square. This environment is difficult, because of the sparse reward, to solve using classical RL algorithms. It is useful to experiment with curiosity or curriculum learning.

Multi-room environment

Registered configurations:

  • MiniGrid-Multi-Room-N6-v0

Multi-room environment

This environment has a series of connected rooms with doors that must be opened in order to get to the next room. The final room has the green goal square the agent must get to. This environment is extremely difficult to solve using classical RL. However, by gradually increasing the number of rooms and building a curriculum, the environment can be solved.

Fetch Environment

Registered configurations:

  • MiniGrid-Fetch-8x8-v0

Fetch environment

This environment has multiple objects of assorted types and colors. The agent receives a textual string as part of its observation telling it which object to pick up. Picking up the wrong object produces a negative reward.