Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/a-r-r-o-w/nn-c
from scratch implementation of a nn for handwritten digit classification in c
https://github.com/a-r-r-o-w/nn-c
Last synced: about 1 month ago
JSON representation
from scratch implementation of a nn for handwritten digit classification in c
- Host: GitHub
- URL: https://github.com/a-r-r-o-w/nn-c
- Owner: a-r-r-o-w
- Created: 2022-06-12T18:20:36.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2022-06-24T00:35:00.000Z (over 2 years ago)
- Last Synced: 2024-12-05T17:41:58.944Z (about 1 month ago)
- Language: C
- Homepage:
- Size: 400 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# handwritten-digit-classifier
Inspired by the [3Blue1Brown neural network series](https://youtube.com/playlist?list=PLZHQObOWTQDNU6R1_67000Dx_ZCJB-3pi), this is an implementation of a neural network that tries to classify Handwritten Digits.
The neural network makes use of the [MNIST dataset](https://www.kaggle.com/datasets/oddrationale/mnist-in-csv). Training is done by iterating over the entire dataset for 5 epochs, calculating losses for each epoch and performing gradient descent backpropagation.
The network manages to achieve an average testing accuracy of 91% (the best accuracy I've seen in all my testing was 93%). Constructing a similar network structure with same parameters achieves 97% when using Tensorflow, which is quite a lot and something that I look forward to achieving with my own implementation. Here's how both implementations perform on the MNIST testing dataset:
![nn-performance](./res/nn.png)
Building the program requires [CMake](https://cmake.org/).
```bash
# clone the repository
git clone https://github.com/a-r-r-o-w/handwritten-digit-classifier-in-c
cd handwritten-digit-classifier-in-c# build the binaries
mkdir build
cd build
cmake ..
make
```The binaries should be created in the `build/` directory and can be executed to replicate the results mentioned above.
```bash
./matrix-test
./mnist-test
./handwritten-digit-classifier
```_Note: `./mnist-test` requires that the terminal supports ANSI Escape Codes. If your terminal does support it, the output may look something like:_
![mnist-test.png](./res/mnist-test.png)