Thanks for contributing!
To get the development installation with all the necessary dependencies for linting, testing, and building the documentation, run the following:
git clone https://github.com/cornellius-gp/gpytorch.git
cd gpytorch
pip install -e .[dev,docs,examples,keops,pyro,test] # keops and pyro are optional
pre-commit install
GPyTorch uses pre-commit for code formatting and flake8 for linting. This enforces a common code style across the repository. The development installation instructions should install both tools, and no additional configuration should be necessary.
flake8
and pre-commit
are both run every time you make a local commit.
To run both commands independent of making a commit:
SKIP=flake8 pre-commit run --files test/**/*.py gpytorch/**/*.py
flake8
We use standard sphinx docstrings (not Google-style).
GPyTorch aims to be fully typed using Python 3.8+ type hints.
We recognize that we have a long way to go towards fully typing the library, but we expect all contributions to also use proper type annotations. While we currently do not enforce full consistency of these in our continuous integration test, you should strive to type check your code locally. For this we recommend using pyre.
We use python's unittest
to run unit tests:
python -m unittest
- To run tests within a specific directory, run (e.g.)
python -m unittest discover -s test/kernels
. - To run a specific unit test, run (e.g.)
python -m unittest test.operators.test_rbf_kernel.TestRBFKernel.test_active_dims_range
.
GPyTorch uses sphinx to generate documentation, and ReadTheDocs to host documentation. To build the documentation locally, ensure that sphinx and its plugins are properly installed (see the development installation section for instructions). Then run:
cd docs
SKIP_EXAMPLES=true make html
cd build/html
python -m http.server 8000
If you are making an update to one of the example notebooks, drop the SKIP_EXAMPLES=true
environment variable:
(This takes longer to build.)
cd docs
make html
cd build/html
python -m http.server 8000
The documentation will be available at http://localhost:8000.
You will have to rerun the make html
or SKIP_EXAMPLES=true make html
command every time you wish to update the docs.
Important: Our CI requires that the documentation compiles WITHOUT WARNINGS. Please ensure that you can build the documentation locally without producing any warnings.
We greatly appreciate PRs! To minimze back-and-forward communication, please ensure that your PR includes the following:
- Code changes. (the bug fix/new feature/updated documentation/etc.)
- Unit tests. If you are updating any code, you should add an appropraite unit test.
- If you are fixing a bug, make sure that there's a new unit test that catches the bug. (I.e., there should be a new unit test that fails before your bug fix, but passes after your bug fix. This ensures that we don't have any accidental regressions in the code base.)
- If you are adding a new feature, you should add unit tests for this new feature.
- Documentation. Any new objects/methods should have appropriate docstrings.
- If you are adding a new object, please ensure that it appears in the documentation. You may have to add the object to the appropriate file in docs/source.
- Example notebooks. Any major new functionality, tutorials, or examples should have an example jupyter notebook.
- If you are adding a new notebook, please ensure that it appears in the documentation. You may have to add the object to the appropriate file in docs/source.
Before submitting a PR, ensure the following:
- Code is proprerly formatted and linted. Linting and formatting checking should happen automatically if you have followed the development installation instructions. See the formatting and linting section for more info.
- Unit tests pass. See the unit tests section for more info.
- Documentation renders correctly without warnings. Build the documentation locally to ensure that your new class/docstrings are rendered correctly. Ensure that sphinx can build the documentation without warnings.
We use GitHub issues to track public bugs. Please ensure your description is clear and has sufficient instructions to be able to reproduce the issue.
We accept the following types of issues:
- Bug reports
- Requests for documentation/examples
- Feature requests
- Opportuntities to refactor code
- Performance issues (speed, memory, etc.)
Please refrain from using the issue tracker for questions or debugging personal code. Instead please use the GPyTorch discussions forum.
By contributing to GPyTorch, you agree that your contributions will be licensed under the LICENSE file in the root directory of this source tree.