Skip to content

Latest commit

 

History

History
122 lines (81 loc) · 3.59 KB

CONTRIBUTING.md

File metadata and controls

122 lines (81 loc) · 3.59 KB

Contributing to Stable-Baselines

If you are interested in contributing to Stable-Baselines, your contributions will fall into two categories:

  1. You want to propose a new Feature and implement it
    • Create an issue about your intended feature, and we shall discuss the design and implementation. Once we agree that the plan looks good, go ahead and implement it.
  2. You want to implement a feature or bug-fix for an outstanding issue

Once you finish implementing a feature or bug-fix, please send a Pull Request to https://github.com/hill-a/stable-baselines/

If you are not familiar with creating a Pull Request, here are some guides:

Developing Stable-Baselines

To develop Stable-Baselines on your machine, here are some tips:

  1. Clone a copy of Stable-Baselines from source:
git clone https://github.com/hill-a/stable-baselines/
cd stable-baselines
  1. Install Stable-Baselines in develop mode, with support for building the docs and running tests:
pip install -e .[docs,tests]

Codestyle

We follow the PEP8 codestyle. Please order the imports as follows:

  1. built-in
  2. packages
  3. current module

with one space between each, that gives for instance:

import os
import warnings

import numpy as np

from stable_baselines import PPO2

In general, we recommend using pycharm to format everything in an efficient way.

Please document each function/method and type them using the following template:

def my_function(arg1: type1, arg2: type2) -> returntype:
    """
    Short description of the function.

    :param arg1: (type1) describe what is arg1
    :param arg2: (type2) describe what is arg2
    :return: (returntype) describe what is returned
    """
    ...
    return my_variable

Pull Request (PR)

Before proposing a PR, please open an issue, where the feature will be discussed. This prevent from duplicated PR to be proposed and also ease the code review process.

Each PR need to be reviewed and accepted by at least one of the maintainers (@hill-a, @araffin, @erniejunior, @AdamGleave or @Miffyli). A PR must pass the Continuous Integration tests (travis + codacy) to be merged with the master branch.

Note: in rare cases, we can create exception for codacy failure.

Test

All new features must add tests in the tests/ folder ensuring that everything works fine. We use pytest. Also, when a bug fix is proposed, tests should be added to avoid regression.

To run tests with pytest:

make pytest

Type checking with pytype:

make type

Build the documentation:

make doc

Check documentation spelling (you need to install sphinxcontrib.spelling package for that):

make spelling

Changelog and Documentation

Please do not forget to update the changelog (docs/misc/changelog.rst) and add documentation if needed. A README is present in the docs/ folder for instructions on how to build the documentation.

Credits: this contributing guide is based on the PyTorch one.