Skip to content

dipamc/procgen-competition

Repository files navigation

NeurIPS 2020 - Procgen Starter Kit

AIcrowd-Logo

This is the starter kit for the NeurIPS 2020 - Procgen competition hosted on AIcrowd

🕵️ About ProcGen Benchmark

16 simple-to-use procedurally-generated gym environments which provide a direct measure of how quickly a reinforcement learning agent learns generalizable skills. The environments run at high speed (thousands of steps per second) on a single core.

These environments are associated with the paper Leveraging Procedural Generation to Benchmark Reinforcement Learning (citation). Compared to Gym Retro, these environments are:

  • Faster: Gym Retro environments are already fast, but Procgen environments can run >4x faster.
  • Non-deterministic: Gym Retro environments are always the same, so you can memorize a sequence of actions that will get the highest reward. Procgen environments are randomized so this is not possible.
  • Customizable: If you install from source, you can perform experiments where you change the environments, or build your own environments. The environment-specific code for each environment is often less than 300 lines. This is almost impossible with Gym Retro.

🔧 Installation

pip install ray[rllib]==0.8.5
pip install tensorflow==2.1.0 # or tensorflow-gpu
pip install procgen==0.10.2

💪 Getting Started

Clone the repository

git clone git@github.com:AIcrowd/neurips2020-procgen-starter-kit.git
cd neurips2020-procgen-starter-kit

Train your agent

./run.sh --train

Rollout the agent

./run.sh --rollout

Please refer to the instructions here for advanced users.

How do I add a custom Model ?

To add a custom model, create a file inside models/ directory and name it models/my_vision_network.py. Please refer here for a working implementation of how to add a custom model. You can then set the custom_model field in the experiment yaml to my_vision_network to cause that model to be used.

How do I add a custom Algorithm/Trainable/Agent ?

Please refer to the instructions here

What configs parameters do I have available ?

This is a very thin wrapper over RLLib. Hence, you have all the RLLib config options available in the experiment configuration (YAML) file to play with. Please refer to this example for an explanation on the structure and available options in the experiment config file.

🚀 Submission

Repository Structure

.
├── aicrowd.json                     # Submission config file (required)
├── algorithms                       # Directory to implement your custom algorithm/trainable/agent
│   ├── custom_random_agent
│   │   ├── custom_random_agent.py
│   │   └── __init__.py
│   ├── __init__.py
│   └── registry.py
├── callbacks.py                    # Custom Callbacks & Custom Metrics
├── Dockerfile                      # Docker config for your submission environment
├── docs
│   ├── algorithms.md
│   ├── procgen-basic-usage.md
│   └── submission.md
│   └── running.md
├── envs                            # `rllib` wrapper for procgen (required)
│   └── procgen_env_wrapper.py
├── experiments                     # Directory contaning the config for different experiments
│   └── procgen-starter-example.yaml
│   └── impala-baseline.yaml        # Baseline using impala
│   └── <your-experiment>.yaml      # Contribute your experiment by adding it here and send us merge request
├── models                          # Directory to implement custom models
│   └── my_vision_network.py
├── README.md
├── requirements.txt                # These python packages will be installed using `pip`
├── rollout.py                      # Rollouts for your model
├── run.sh                          # Entrypoint to your submission code (required)
├── train.py                        # Simple script to trigger the training using `rllib` (do not change)
└── utils                           # Directory containing utility functions
    └── loader.py

aicrowd.json

Your repository should have an aicrowd.json file with following fields:

{
    "challenge_id" : "evaluations-api-neurips-2020-procgen",
    "grader_id": "evaluations-api-neurips-2020-procgen",
    "authors" : ["aicrowd-bot"],
    "description" : "NeurIPS 2020: Procgen Competition Agent",
    "docker_build" : false
}

This file is used to identify your submission as a part of the NeurIPS 2020 Procgen Competition Challenge. You must use the challenge_id, grader_id, and evaluations_api_grader_id specified above in the submission.

Submission environment configuration

By default we will run your code in an Ubuntu 18.04 environment with tensorflow, pytorch, mlflow, ray[rllib] and procgen installed.

If you want to run your submissions in a customized environment, first head to aicrowd.json and set docker_build to true. This flag tells that you need a custom environment.

You can specify your software environment by using Dockerfile, environment.yml, requirements.txt, apt.txt. Available options are

  • requirements.txt: We will use pip install -r requiremens.txt to install your packages.
  • environment.yml: We will use conda to install the packages in your environment.
  • apt.txt: We will install the packages in apt.txt before conda/pip installations.
  • Dockerfile: We will build the docker image using the specified Dockerfile. If you have a Dockerfile in your repository, any other automatic installation will not be triggered. This means that you will have to include installation steps for apt.txt, requirements.txt, and environment.txt yourself.

A sample Dockerfile and a corresponding requirements.txt are provided in this repository for you reference.

Code entrypoint

The evaluator will use /home/aicrowd/run.sh as the entrypoint. Please remember to have a run.sh at the root which can instantiate any necessary environment variables and execute your code. This repository includes a sample run.sh file.

Submitting

  1. Setup an AIcrowd GitLab account if you don't have one by going to https://gitlab.aicrowd.com/
  2. Add your SSH key
  3. If you accept the challenge rules, click the Participate button on the AIcrowd contest page
  4. Create a submission by pushing a tag to your repository with a prefix submission-. An example is shown below (you can keep repository name as you desire or have multiple repositories):
# Optional: Start working with starter kit as starting point.
git clone git@github.com:AIcrowd/neurips2020-procgen-starter-kit.git
cd neurips2020-procgen-starter-kit

# Add AICrowd git remote endpoint
git remote add aicrowd git@gitlab.aicrowd.com:<your-aicrowd-username>/neurips-2020-procgen-starter-kit.git
git push aicrowd master

# Create a tag for your submission and push
git tag -am "submission-v0.1" submission-v0.1
git push aicrowd master
git push aicrowd submission-v0.1

# Note : If the contents of your repository (latest commit hash) does not change, 
# then pushing a new tag will not trigger a new evaluation.
  1. You should now be able to see the details of your submission in the repository's issues page. https://gitlab.aicrowd.com/<your-aicrowd-username>/neurips-2020-procgen-starter-kit/issues

and something along the lines of :

Happy Submitting!! 🚀

Author(s)

About

Repo for Neurips 2020 ProcGen competition

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published