Hello and thanks for considering contributing to Xfer! It's people like you who make the project great!
Whether it's a bug report, new feature, correction, or additional documentation, we greatly value feedback and contributions from our community.
Following these guidelines helps smooth out the process of contributing for both you as a contributor and those who maintain the project, making better use of everyone's time and energy.
If you find a bug in Xfer, please file an issue, detailing as much about your setup as possible to help future developers in reproducing the issue. Tag it as a bug, with any additional tags as relevant.
Information should contain the following:
- What version of Xfer and MXNet are you using?
- What operating system are you using?
- What python version are you using?
- What did you do?
- What did you expect to happen?
- What actually happened?
- Have you made any modifications relevant to the bug?
If you're wishing for a feature that doesn't exist yet in Xfer, there are probably others who need it too. Open an issue on GitHub describing what it is you'd like to see added, why it's useful, and how it might work. Add an "Enhancement" tag for bonus points! Better yet, submit a pull request providing the feature you need!
If you're thinking about adding code to Xfer, here are some guidelines to get you started.
-
If the change is a major feature, create an issue using the feature request template to get community feedback on the proposed changes and document the design reasoning of Xfer for future reference.
-
Keep pull requests small, preferably one feature per pull request. This lowers the bar to entry for a reviewer, and keeps feedback focused for each feature.
Some major areas where we appreciate contributions:
- Creating new Repurposers
- Expanding on the capabilities of Model Handler.
- Example notebooks showing how to repurpose models in new data domains.
If you're still not sure where to begin, have a look at our issues page for open work.
So you've written up a new Repurposer and you want to give it back to the community. Now it's time to submit a pull request! Before sending us a pull request, please ensure that:
- You check existing open, and recently merged, pull requests to make sure someone else hasn't addressed the problem already.
- You open an issue to discuss any significant work - we would hate for your time to be wasted.
- You are working against the latest source on the develop branch and raise pull request against develop branch.
To send us a pull request, please:
- Fork the repository.
- Modify the source; please focus on the specific change you are contributing. If you also reformat all the code, it will be hard to focus on your change.
- Ensure local tests pass.
- Commit to your fork using clear commit messages.
- Send us a pull request, making sure you've answered the questions in the pull request checklist (see below.)
- Pay attention to any automated CI failures reported in the pull request, and stay involved in the conversation.
GitHub provides additional document on forking a repository and creating a pull request.
Feel free to ask for help if you're unsure what to do at any point in the process, or on how best to integrate your code with the existing codebase!
After submitting a pull request, you can expect a response from a maintainer within 7 days. If you still haven't heard back by then, feel free to ping the thread as a reminder.
We follow to PEP8 standards as a general rule.
We prefer explicit variable names like mean
and variance
to ones like location
and scale
or greek letters like mu
and sigma
.
Before submitting the pull request, please go through this checklist to make the process smoother for both yourself and the reviewers.
- Are there unit tests with good code coverage? Please include numerical stability checks against edge cases if applicable.
- Do all public functions have docstrings including examples? If you added a new module, did you add it to the Sphinx
api.rst
file in thedoc
folder? - Is the code style correct (PEP8)? You can verify this by running
flake8
from the top level directory. - Is the commit message formatted correctly?
- If this is a large addition, is there a tutorial or more extensive module-level description? Did you discuss the addition in a feature request and provide a link to it?
Once you have the repository cloned from git, installing it should be as simple as running:
pip install -e .
Install test requirements by running:
pip install -r test_requirements.txt
Run the unit tests by running the following command from the top level directory:
pytest
To run integration tests or notebook tests too, use:
pytest --integration
pytest --notebook
Before running notebook tests, be sure to import the notebook dependencies from docs/demos/requirements
.
When running the tests on OSX, you may get this error when running the GpRepurposer.
from matplotlib.backends import _macosx
RuntimeError: Python is not installed as a framework. The Mac OS X backend will not be able to function correctly if Python is not installed as a framework. See the Python documentation for more information on installing Python as a framework on Mac OS X. Please either reinstall Python as a framework, or try one of the other backends. If you are using (Ana)Conda please install python.app and replace the use of 'python' with 'pythonw'. See 'Working with Matplotlib on OSX' in the Matplotlib FAQ for more information.
This can be fixed by running the following command from the root directory of the repo.
echo 'backend: Agg' > matplotlibrc
Documentation contributions are much appreciated! If you see something incorrect or poorly explained, please fix it and send the update!
If you'd like to generate the docs locally, first install the required Xfer dependencies from requirements.txt
and the necessary documentation packages from the docs/requirements.txt
file. Due a dependency on nbconvert, you will need to install Pandoc separately from here. Then, from inside the doc directory, run:
make html
See the LICENSE file for our project's licensing. We will ask you to confirm the licensing of your contribution.
We may ask you to sign a Contributor License Agreement (CLA) for larger changes.
This project has adopted the Amazon Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.
CONTRIBUTING contents partially inspired from scipy's and Rust's contribution guides!