Skip to content

Personal playground for AI implemented from scratch in Rust and visualized with WASM. For research and educational purpose.

Notifications You must be signed in to change notification settings

HugoKempfer/rust-nn

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Rust NN

I share through this repository my personal Proof Of Concept and implementation of self made AI.

Educational only.

[TOC]

Simple Feed-forward 3 layers Perceptron

With prior training, you can use this NN to predict and classify input data.

Architecture description

This neural network is composed of 3 layers of perceptrons. The input, hidden and output layers.

This is one of the simplest setup for a neural network, we can refer it as the vanilla NN. Each layer of perceptron has weighted activations.

Simple NN

Note that I didn't used Bias neurons in the network.

Training

There are two main steps of the training process:

  • Forward Feeding (calculating output values based on provided inputs)
  • Error Back Propagation (summing error based on expected and actual output, and adjusting all weights according to their influence on the total error)

These two steps are repeated for every entry in the training dataset (possibly in multiple epochs).

We're able to define how fast we evolve over the Gradient Descent by adjusting the learning rate.

Forward Feeding

The product of the inputs we'll be calculated based on all neurons weights and passed through activation function (once per layer).

The chosen non-linear activation function is Sigmoid (Logistic function).

Then the total error is calculated via the MSE loss function:

Error Back Propagation

Using the Chained Rule and the Delta Rule we're able to determine the responsibility of each neuron in the Total error.

So we can adjust each neuron's weight in order to reduce the total error for the next Forward Pass (for the same input or similar ones).

Library API

You can directly make use of the library to create your own models.

/// Initialize a non-trained network with uniforrmly randomly generated weights
pub fn new(inputs_nb: usize, outputs_nb: usize, hiddens_nb: usize, learning_rate: f64) -> Self 

/// Proceed to one forward pass to predict the output values according to the                                                   /// model weights 
pub fn predict(&self, inputs: &Vec<f64>) -> Result<DMatrix<f64>, String> //Should be refactored to use slices

pub fn train(&mut self, inputs: &Vec<f64>, targets: &Vec<f64>) -> Result<(), String> // Same here

/// Save the model under a RON formatted file
pub fn save_to_file(&self, file_path: &str) -> Result<(), String>

pub fn save_to_file(&self, file_path: &str) -> Result<(), String>

If you want an up-to-date documentation of the library I advice you to use the cargo doc tool!

Example with MNIST dataset

I made an example for this library with the MNIST handwritten digits dataset. This is like the Hello world exercise for NN.

The dataset is composed of 60 000 inverted greyscaled 28 * 28 bitmaps of handwritten digits. Each image has a one byte label (0-9).

CLI

You can try this example using CLI interface. The dataset will be automatically downloaded.

Rust NN for MNIST 
Hugo Kempfer <[email protected]>
Demonstration of the multilayer perceptron usage for the MNIST handwritten digits dataset.

USAGE:
    mnist [FLAGS] [OPTIONS]

FLAGS:
        --help       Prints help information
    -p               Use a model to predict the test image set
    -t               Train the model.
    -V, --version    Prints version information

OPTIONS:
    -f <file>          Model file to use (RON format)
    -h <hidden>        Number of hidden nodes to use [default: 100]
    -r <rate>          Learning rate value [default: 0.1]

Example:

cargo run --release --example mnist -- -tp -h 200

Web Assembly Based Version

A more fun and visual way to test it is via Vuejs + WASM client, this version also enable you to draw your own digits and predict them.

You can configure the network using the sliders and train it directly in your web browser using the Rust library running on a dedicated Web Worker and Wasm.

To try it on your local machine you can run the following commands from the repository root:

wasm-pack build --release
cd rust-nn-playground
yarn install
yarn serve

and then access the http://localhost:8080/ page.

Note that you need the yarn or npm binary and a Rust toolchain (preferably stable), including wasm-pack.

References

I used a lot of articles and content to understand the basics of neural networks.

About

Personal playground for AI implemented from scratch in Rust and visualized with WASM. For research and educational purpose.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published