Neuronika Save

Tensors and dynamic neural networks in pure Rust.

Project README

Neuronika Logo


CircleCI Codecov branch

Neuronika is a machine learning framework written in pure Rust, built with a focus on ease of use, fast prototyping and performance.

Add neuronika to your project

[dependencies]

neuronika = { git = "https://github.com/neuronika/neuronika" }

Dynamic neural networks and auto-differentiation

At the core of Neuronika lies a mechanism called reverse-mode automatic differentiation, that allows you to define dynamically changing neural networks with very low effort and no overhead by using a lean, fully imperative and define by run API.

The power of Rust

The Rust language allows for an intuitive, light and easy to use interface while achieving incredible performance. There's no need for a FFI, everything happens in front of your eyes.

Crate Feature Flags

  • cuda Enables gpu accelerated primitives.

You can use the following crate feature flags to configure the ndarray backend:

  • serialize Enables serialization support for serde 1.x.

  • blas Enables transparent BLAS support for matrix multiplication, which uses blas-src for pluggable backend and needs to be configured separately. See here for more informations.

  • matrixmultiply-threading Enables the threading feature in the matrixmultiply package.

Contributing

We appreciate and welcome all contributions. If you are planning to contribute back bug-fixes, please do so without any further discussion.

If you plan to contribute new features, utility functions, or extensions to the framework, please first open a discussion and discuss the feature with us. Sending a PR without discussion might end up resulting in a rejected PR because we might be taking the project in a different direction than you might be aware of.

To learn more about making a contribution to Neuronika, please see our contribution page.

Getting Help

First, see if the answer to your question can be found in the API documentation. If the answer is not there, please ask for help by opening a discussion with the question. We'll be glad to help you.

Project Status

Neuronika is very young and rapidly evolving, we are continuously developing the project and breaking changes are expected during transitions from version to version. We adopt the newest stable Rust's features if we need them.

License

Dual-licensed to be compatible with the Rust project.

Licensed under the Apache License, Version 2.0 or the MIT license, at your option. This file may not be copied, modified, or distributed except according to those terms.

Open Source Agenda is not affiliated with "Neuronika" Project. README Source: neuronika/neuronika
Stars
1,034
Open Issues
13
Last Commit
1 year ago
Repository
License

Open Source Agenda Badge

Open Source Agenda Rating