Welcome to the Lava Developers Guide! Lava is an open-source software framework and community for developing neuro-inspired applications and mapping them to neuromorphic hardware.
Lava is an open, community-developed code base.
The purpose of this document is to provide a guide for contributing to Lava and explain how the Lava Project operates. The Lava Project can only grow through the contributions and work of this community.
Thanks for your interest in contributing to Lava!
The initial code for the Lava project (github.com/lava-nc) was seeded by Intel's Neuromorphic Computing Lab (NCL), a group within Intel Labs. NCL researchers continue to actively manage and expand the functionality of Lava, with the goal of building an active community of contributors and users.
To receive regular updates on the latest developments and releases of the Lava Software Framework please subscribe to our newsletter.
Email the Intel Lava Team at: lava@intel.com
- :ref:`Development Roadmap`
- :ref:`How to contribute to Lava`
- :ref:`Coding Conventions`
- :ref:`Contributors`
- :ref:`Repository Structure`
- :ref:`Code of Conduct`
Our development roadmap will be published soon.
Component | HW support | Features |
---|---|---|
Magma | CPU, GPU |
|
Process library | CPU, GPU | Initially supports basic processes to create spiking neural networks with different neuron models, connection topologies and input/output processes. |
Deep Learning library | CPU, GPU | Allows for direct training of stateful and event-based spiking neural networks with backpropagation via SLAYER 2.0 as well as inference through Lava. Training and inference will initially only be supported on CPU/GPU HW. |
Optimization library | CPU, GPU | Offers a variety of constraint optimization solvers such as constraint satisfaction (CSP) or quadratic unconstraint binary optimization (QUBO) and more. |
Dynamic Neural Field library | CPU, GPU | Allows to build neural attractor networks for working memory, decision making, basic neuronal representations, and learning. |
Magma and Process library | Loihi 1, 2 | Compiler, Runtime and the process library will be upgraded to support Loihi 1 and 2 architectures. |
Profiler | CPU, GPU | Enables power and performance measurements on neuromorphic HW as well as the ability to simulate power and performance of neuromorphic HW on CPU/GPU platforms. Initially only CPU/GPU support will be available. |
DL, DNF and Optimization library | Loihi 1, 2 | All algorithm libraries will be upgraded to support and be properly tested on neuromorphic HW. |
Contributions to Lava are made through pull requests from personal forks of Lava (https://github.com/lava-nc) on Github. We welcome contributions at all levels of the software stack:
- Runtime
- Compiler
- API
- New Processes
- Algorithm or application libraries built on top of Lava
- Seperate utilities
- 3rd party interfaces
Before you submit a pull request, please create an issue that describes why the pull request is needed. Please link your pull request to the issue covering the request upon pull request creation.
If you find a bug or would like to add additional functionality to Lava follow the steps below to create an issue.
Note
These instructions are written using lava-nc/lava repository, however they can be used with any of the lava-nc/<repo> repositories.
- Open an issue
- Add a descriptive title
- Describe the issue in detail in the body
- Add an issue type label:
- documentation
- enhancement
- bug
- Add a review label:
- needs-review
- The issue will be reviewed by a lava committer
- Please participate in the review
- Respond to any questions
- Update the issue with changes as requested
- The issue will be triaged with labels based on status:
- reviewed-approved
- reviewed-declined
- reviewed-needs-work
- duplicate
- invalid
- wontfix
- <release version>-target
- If 'reviewed-approved' a label of '<release version>-target' will be added
Before you send your pull requests follow these steps:
- Read the :ref:`Code of Conduct`
- Check if your changes are consistent with :ref:`Coding Conventions`
- :ref:`Apply a license<Add a License>` to your contributions
- Run :ref:`linting and unit tests<Lint Unit Tests>`
Warning
Code submissions must be original source code written by you.
For full coverage of how to create a fork and work with it see Github Fork Procedures
Note
These instructions are written using lava-nc/lava repository, however they can be used with any of the lava-nc/<repo> repositories.
Fork lava-nc/lava
- Click on the 'Fork' button in the upper right corner
Get the code locally
Clone your fork to your local machine
git clone git@github.com:<user-name>/lava.git
Alternatively add a remote from your local repository to your fork
git remote add lava-fork git@github.com:<user-name>/lava.git
Create a new descriptive branch
git checkout -b <branch-name>
Write your code
Make code changes
Run linting and unit tests (install pybuilder)
## Flake8 linting pyb analyze ## Bandit security linting pyb bandit ## Unit tests pyb -E unit # Alternately python -m unittest discover -s lava/tests -p "test_*.py" -vvv
Fix any issues flagged by linting and unit tests and check again to ensure the issues are resolved
Note
Please include, at the top of each source file, a BSD 3 or LGPL 2.1+ License. Check with Lava Committers if you have a question about licenses.
For Lava code contributions excepting lava-nc/magma/compiler and lava-nc/magma/runtime, use BSD 3. Example Intel BSD 3 License:
# Copyright (C) 2021 Intel Corporation# SPDX-License-Identifier: BSD-3-Clause# See: https://spdx.org/licenses/For lava-nc/magma/compiler and lava-nc/magma/runtime use either BSD 3 or LGPL 2.1+. Example Intel LGPL 2.1+ License:
# Copyright (C) 2021 Intel Corporation# SPDX-License-Identifier: LGPL-2.1-or-later# See: https://spdx.org/licenses/Commit code changes to your branch
git add <code> # Sign your commit and add a commit summary git commit -sm "<title-description>"
Push this branch to your fork
# If you cloned git push -u origin <branch-name> # If you added remote lava-fork git push -u lava-fork <branch-name>
Open a pull request to lava-nc/lava main
- Add a descriptive pull request title
- Describe the pull request in detail in the body
- Link an issue to the pull request
- Add a pull request label:
- documentation
- enhancement
- bug
Add a review label:
- needs-review
Work with committers on your code review
Answer any questions or comments
Make updates as required
Meet code requirements before merge
- Unit tests cover the pull request- Code contains class and method doc strings- The build and tests on the pull request pass- Style Guidelines are met
Required before merge: 2 Code Reviews and the approval of a committer
- Code must be styled according to PEP8.
- Line limit is 80 characters
- Use short descriptive variable & function names
- Code must use docstrings:
- module docstring
- class docstring
- method docstring
- See :ref:`docstring format<Docstring Format>`
- Code should be developed using TDD (Test Driven Development)
- Descriptive unit tests are required
- Tests prove your code works
- Tests help keep your code working when other contribute
- Write descriptive unit tests that explain the intent of the test
- Write minimal unit tests for just the feature you want to test
- Unit tests must cover the code in each pull request
- Descriptive unit tests are required
- All continuous integration checks must pass before pull requests are merged
- Code must be reviewed twice and merged by a :ref:`committer`
- Before you embark on a big coding project, document it with an :ref:`issue <Open an Issue>` and discuss it with others including Lava Committers.
- Use consistent :ref:`numpy docstring format<Docstring Format>`
- Strive for a 100% linter score
- Prefer short yet descriptive variable and function names
- The more global a variable or function name the longer it may be. The more local the shorter the name should be
- When something breaks, many tests may fail. But don't be overwhelmed. Fix the lowest level unit tests first. Chances are good these will also fix higher level unit tests.
- Document everything
- module doc string
- class doc string
- method docstring
# Use numpy-style docstring formatting: https://numpydoc.readthedocs.io/en/latest/format.html#docstring-standard
def function(self, arg1, arg2):
""" <Short description>
<Optional: Detailed description>
Parameters
----------
arg1
arg2
Returns
-------
"""
A contributor is someone who contributes to the Lava Community. Contributions can take many forms and include:
- Create and update documentation
- Contribute code
- Contribute reviews of code and issues
- Rate, comment on and give "thumbs up" on issues, pull requests etc.
A Committer is a contributor who has the authority, and responsibility to review code and merge pull requests in the Lava Community. Committers are the leaders of the Lava Project and they have the following responsibilities:
- Plan and decide the direction of the Lava Project
- Facilitate community meetings and communication
- Mentor new developers and community members
- Review issues
- Review pull requests, enforce requirements, merge code
- Keep CI working
Committer promotion is the responsibility of the current committers.
A current committer can nominate a contributor to become a committer based on contributions to the Lava Community.
Contributions that qualify a contributor should include:
- Contributing significant document creation and document updates
- Contributing significant amounts of code and high value features
- Contributing reviews of code and issues
- Facilitation of community planning, communication, and infrastructure
Upon nomination of a new committer, all current committers will vote on the new committer nomination.
- A quorum of 80% of committers must vote for a valid election
- A nominee must not receive any vetos
Lava directory structure:
Core repository containing the runtime, compiler and API.
Lava Dynamic Neural Fields Library
Lava Deep Learning Library
Lava Neuromorphic Constraint Optimization Library
Lava Documentation
Your behavior contributes to a successful community. As such community members should observe the following behaviors:
- Welcome others, use inclusive and positive language.
- Be truthful and transparent.
- Be respectful of difference in viewpoint and experience.
- Work towards the community's best interest.
- Show empathy towards others.
- Accept constructive criticism.
All Lava spaces are professional interaction spaces and prohibit inappropriate behavior or any behavior that could reasonably be thought to be inappropriate.
Inappropriate behavior that is intolerable includes:
- Harassment in any form.
- Sexual language or images.
- Without permission, sharing private information of another, i.e., electronic, or physical address.
- Political attacks, derogatory or insulting comments.
- Conduct which could reasonably be considered inappropriate for the forum in which it occurs.
Lava is licensed as BSD 3 or LGPL 2.1+. Specific components are licensed as follows:
Go to :ref:`how to apply a license<Add a License>` for more information on using a license in your contribution.