This is the starter kit for the NeurIPS 2020 - Procgen competition hosted on AIcrowd
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.
pip install ray[rllib]==0.8.5
pip install tensorflow==2.1.0 # or tensorflow-gpu
pip install procgen==0.10.2
git clone git@github.com:AIcrowd/neurips2020-procgen-starter-kit.git
cd neurips2020-procgen-starter-kit
./run.sh --train
./run.sh --rollout
Please refer to the instructions here for advanced users.
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.
Please refer to the instructions here
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.
.
├── 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
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.
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 usepip install -r requiremens.txt
to install your packages.environment.yml
: We will useconda
to install the packages in your environment.apt.txt
: We will install the packages inapt.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 forapt.txt
,requirements.txt
, andenvironment.txt
yourself.
A sample Dockerfile
and a corresponding requirements.txt
are provided in this repository for you reference.
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.
- Setup an AIcrowd GitLab account if you don't have one by going to https://gitlab.aicrowd.com/
- Add your SSH key
- If you accept the challenge rules, click the
Participate
button on the AIcrowd contest page - 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.
- 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!! 🚀