Thank you for your interest in contributing to neurodsp
!
We welcome all contributions to the project that extend or improve code and/or documentation!
This page includes information for how to get involved and contribute to the project, and guidelines for how to do so.
This project adheres to a code of conduct that you are expected to uphold when participating in this project.
On this page, you can find information on:
- Reporting a problem
- Getting involved in the project
- Project scope
- Making a contribution
- Project conventions
To report an issue with the code, please submit it to our issue tracker.
In doing so, please try to include the following:
- A short, top-level summary of the issue (usually 1-2 sentences)
- A short, self-contained code snippet to reproduce the issue, ideally allowing a simple copy and paste to reproduce
- Please do your best to reduce the code snippet to the minimum required
- The actual outcome of the code snippet
- The expected outcome of the code snippet
We welcome all kinds of contributions to the project, including suggested features and help with documentation, maintenance, and updates.
If you have a new idea you would like to suggest or contribute, please do the following:
- Check if the idea is already being discussed on the issues or development page
- Check that your idea is within the project scope
- Open an issue describing what you would like to see added / changed, and why
- Indicate in the issue if the idea is something you would be willing to help implement
- if so, project maintainers can give feedback to help make a plan for the contribution
- If you want to work on the contribution, follow the contribution guidelines to do so
If you are interested in getting involved and helping with the project, a great place to start is to visit the issues or development page and see if there is anything you would be interested in helping with. If so, join the conversation, and project developers can help get you started.
All contributions must be within the scope of the module.
neurodsp
is a module that collects digital signal processing approaches for neural data that operate on neural time series. This includes filtering, spectral estimation, time-frequency analyses, and more. The majority of the methods operate on single time-series, though multivariate approaches may be added on a case-by-case basis.
This module collects analyses that are broadly agnostic to specific recording modalities, and particularities of how the data is organized, operating on arrays of time-series. Code and utilities that focused on data management are considered out of scope. Algorithms and topics that are already available and well-supported in other Python toolboxes will typically not be added here.
If there is a feature you would like to add, or an issue you saw that you think you can help with, you are ready to make a submission to the project!
If you are working on a feature, please indicate so in the relevant issue, so that we can keep track of who is working on what.
Once you're ready to start working on your contribution, do the following:
- Fork this repository, which makes your own version of this project you can edit
- Make your changes, updating or adding code to add the desired functionality
- Check the project conventions, and make sure all new or updated code follows the guidelines
- Submit a pull request, to start the process of merging the new code to the main branch
If it's your first time contributing to open source software, check out this free resource on how to contribute to an open-source project on GitHub.
All code contributed to the module should follow these conventions:
-
Code Requirements
- All code should be written in Python, and run on the minimum required version that is noted in the README
- New dependencies should be avoided if possible, especially if they are not in the Anaconda distribution
- If any new dependencies are needed, they should be added to the
requirements.txt
file
-
Code Style
-
API & Naming Conventions
- Try to keep the API consistent with existing code in terms of parameter names and ordering
- Standard naming and parameter ordering in NeuroDSP include:
sig
is commonly the first input, representing the neural time seriesfs
is commonly the second input, representing the sampling rate- variables named 'f_...' refer to frequencies (e.g. 'f_range' is a bandpass filter's cutoff frequencies)
- Use standard casing, for example:
- function names should be in snake_case (all lowercase with underscores)
- class names should be in CamelCase (leading capitals with no separation)
- If passing through arguments to an external function, the naming and ordering of parameters in this module should generally follow that of the external function
-
Code Documentation
- All code should be documented, including in-code comments describing procedures, and detailed docstrings
- Docstrings should follow the numpy docs format
- At minimum, there should be a sentence describing what the function does and a list of parameters and returns
- Private functions should be indicated with a leading underscore, and should still include a docstring including at least a sentence describing what the function does
- If possible, add an
Examples
section to the docstrings, that demonstrates a simple use case- If so, these examples should be executable, using doctest
- If examples cannot be run, use the SKIP directive
-
Code Tests
- This project uses the pytest testing tool for testing module code
- All new code requires test code, written as unit tests that check each function and class in the module
- Tests should be, at a minimum, 'smoke tests' that execute the code and check that it runs without raising an error
- Where possible, accuracy checking is encouraged, though not strictly required
- Merge candidates must pass all existing tests, and add new tests such as to not reduce test coverage
- To run the tests locally, pytest needs to be installed (
pip install pytest
)- To run the tests on a local copy of the module, move into the folder and run
pytest .
- To run the tests on a local copy of the module, move into the folder and run
-
Documentation Website
- This project uses a documentation website, created using sphinx
- Any new public functions or classes should be added to the
doc/api.rst
file, so they get included in the API list - Any new functionality should be added and described in the tutorials and/or examples
- If a new approach is added, a new tutorial or example may be appropriate
- To build and check the documentation locally:
- Install the requirements for the docsite (
pip install -r requirements-doc.txt
) - Move to the
neurodsp/doc
directory (cd doc
) - Run
make html
to create a local copy of the documentation website - The documentation can then be opened in a web browser by opening the file
neurodsp/doc/_build/html/index.html
- Install the requirements for the docsite (
For more guidelines on how to write well formated and organized code, check out the Python API Checklist.