neural-networks

Tutorial on basic neural network concepts

DOI License: GPL v3

Material for this tutorial

Download the repository

Get the repository with Git

You will need to have Git previously installed in your computer. To check if you have it installed, open your terminal and type:

git --version

Git installation in MacOS

brew update
brew install git

Git installation in Linux

In Ubuntu/Debian

sudo apt install git

In CentOS

sudo yum install git

Once you have Git installed open your terminal, go to your desired directory, and type:

git clone https://github.com/machine-learning-tutorial/neural-networks
cd neural-networks

Get the repository with direct download

Open your terminal, go to your desired directory, and type:

wget https://github.com/machine-learning-tutorial/neural_networks/archive/refs/heads/main.zip
unzip main.zip
cd neural-networks

Getting started

You need to install the dependencies before running the notebooks.

Using conda

If you don’t have conda installed already and want to use conda for environment management, you can install the miniconda as described here.

python -m jupyter contrib nbextension install --user
python -m jupyter nbextension enable varInspector/main

Using venv only

If you do not have conda installed:

Alternatively, you can create the virtual env with venv in the standard library

python -m venv nn-tutorial

and activate the env with $ source /bin/activate (bash) or C:> /Scripts/activate.bat (Windows)

Then, install the packages with pip within the activated environment

python -m pip install -r requirements.txt
python -m jupyter contrib nbextension install --user
python -m jupyter nbextension enable varInspector/main

Afterwards, you should be able to run the provided notebooks.

Running the tutorial

After installing the package

You can start the jupyter notebook in the terminal, and it will start a browser automatically

python -m jupyter notebook

Alternatively, you can use supported Editor to run the jupyter notebooks, e.g. with VS Code.

Jupyter Notebooks

Use cmd+Enter to execute one cell block

Part 1 Neural Network Basics

The first part of the tutorial is in 1-neural_networks.ipynb.

Part 2 MNIST Training

The second part of the tutorial is in 2-mnist_training.ipynb

Citing the tutorial

This tutorial is registered Zenodo. Please use this DOI when citing this code:

@software{santamaria_garcia_2024_10792273,
  author       = {Santamaria Garcia, Andrea and
                  Xu, Chenran},
  title        = {Tutorial on basic neural network concepts},
  month        = 03,
  year         = 2024,
  publisher    = {Zenodo},
  version      = {v1.0.1},
  doi          = {10.5281/zenodo.10792273},
  url          = {https://doi.org/10.5281/zenodo.10792273}
}

Disclaimer

The content of this repository was developed by the AI4Accelerators team at the Institute of Beam Physics and Technology (IBPT), Karlsruhe Institute of Technology.