TensorFlow Tutorials
Original author is Magnus Erik Hvass Pedersen
Introduction
- These tutorials are intended for beginners in Deep Learning and TensorFlow.
- Each tutorial covers a single topic.
- The source-code is well-documented.
- There is a YouTube video for each tutorial.
Tutorials
-
Simple Linear Model (Notebook) (Google Colab)
-
Convolutional Neural Network (Notebook) (Google Colab)
-
Pretty Tensor(Notebook) (Google Colab)
3-B. Layers API (Notebook) (Google Colab)
3-C. Keras API (Notebook) (Google Colab)
-
Save & Restore (Notebook) (Google Colab)
-
Ensemble Learning (Notebook) (Google Colab)
-
CIFAR-10 (Notebook) (Google Colab)
-
Inception Model (Notebook) (Google Colab)
-
Transfer Learning (Notebook) (Google Colab)
-
Video Data (Notebook) (Google Colab)
-
Fine-Tuning (Notebook) (Google Colab)
-
Adversarial Examples (Notebook) (Google Colab)
-
Adversarial Noise for MNIST (Notebook) (Google Colab)
-
Visual Analysis (Notebook) (Google Colab)
13-B. Visual Analysis for MNIST (Notebook) (Google Colab)
-
DeepDream (Notebook) (Google Colab)
-
Style Transfer (Notebook) (Google Colab)
-
Reinforcement Learning (Notebook) (Google Colab)
-
Estimator API (Notebook) (Google Colab)
-
TFRecords & Dataset API (Notebook) (Google Colab)
-
Hyper-Parameter Optimization (Notebook) (Google Colab)
-
Natural Language Processing (Notebook) (Google Colab)
-
Machine Translation (Notebook) (Google Colab)
-
Image Captioning (Notebook) (Google Colab)
-
Time-Series Prediction (Notebook) (Google Colab)
Videos
These tutorials are also available as YouTube videos.
Obsolete Tutorials
Some of these tutorials use an API called PrettyTensor for creating Neural Networks in TensorFlow, but the PrettyTensor API is now obsolete. Some of the Notebooks are therefore also obsolete and they are clearly marked at the top of each Notebook. It is recommended that you instead use the Keras API for creating Neural Networks in TensorFlow.
Translations
These tutorials have been translated to the following languages:
You can help by translating the remaining tutorials or reviewing the ones that have already been translated. You can also help by translating to other languages.
Forks
See the selected list of forks for community modifications to these tutorials.
Downloading
Some of the Python Notebooks use source-code located in different files to allow for easy re-use across multiple tutorials. It is therefore recommended that you download the whole repository from GitHub, instead of just downloading the individual Python Notebooks.
Git
The easiest way to download and install these tutorials is by using git from the command-line:
git clone https://github.com/Hvass-Labs/TensorFlow-Tutorials.git
This will create the directory TensorFlow-Tutorials
and download all the files to it.
This also makes it easy to update the tutorials, simply by executing this command inside that directory:
git pull
Zip-File
You can also download the contents of the GitHub repository as a Zip-file and extract it manually.
Installation
There are different ways of installing and running TensorFlow. This section describes how I did it for these tutorials. You may want to do it differently and you can search the internet for instructions.
If you are new to using Python and Linux, etc. then this may be challenging to get working and you may need to do internet searches for error-messages, etc. It will get easier with practice.
Python Version 3.5 or Later
These tutorials were developed on Linux using Python 3.5 / 3.6 (the Anaconda distribution) and PyCharm.
There are reports that Python 2.7 gives error messages with these tutorials. Please make sure you are using Python 3.5 or later!
Environment
After installing Anaconda, you should create a conda environment so you do not destroy your main installation in case you make a mistake somewhere:
conda create --name tf python=3
When Python gets updated to a new version, it takes a while before TensorFlow also uses the new Python version. So if the TensorFlow installation fails, then you may have to specify an older Python version for your new environment, such as:
conda create --name tf python=3.6
Now you can switch to the new environment by running the following (on Linux):
source activate tf
Required Packages
The tutorials require several Python packages to be installed. The packages are listed in requirements.txt First you need to edit this file and select whether you want to install the CPU or GPU version of TensorFlow.
To install the required Python packages and dependencies you first have to activate the conda-environment as described above, and then you run the following command in a terminal:
pip install -r requirements.txt
Note that the GPU-version of TensorFlow also requires the installation of various NVIDIA drivers, which is not described here.
How To Run
If you have followed the above installation instructions, you should now be able to run the tutorials in the Python Notebooks:
cd ~/development/TensorFlow-Tutorials/ # Your installation directory.
jupyter notebook
This should start a web-browser that shows the list of tutorials. Click on a tutorial to load it.
Run in Google Colab
If you do not want to install anything on your own computer, then the Notebooks can be viewed, edited and run entirely on the internet by using Google Colab. There is a YouTube video explaining how to do this. You click the "Google Colab"-link next to each tutorial listed above. You can view the Notebook on Colab but in order to run it you need to login using your Google account. Then you need to execute the following commands at the top of the Notebook, which clones the contents of this repository to your work-directory on Colab.
import os
work_dir = "/content/TensorFlow-Tutorials/"
if os.getcwd() != work_dir:
!git clone https://github.com/Hvass-Labs/TensorFlow-Tutorials.git
os.chdir(work_dir)
All required packages should already be installed on Colab, otherwise you can run the following command:
!pip install -r requirements.txt
Older Versions
Sometimes the source-code has changed from that shown in the YouTube videos. This may be due to bug-fixes, improvements, or because code-sections are moved to separate files for easy re-use.
If you want to see the exact versions of the source-code that were used in the YouTube videos, then you can browse the history of commits to the GitHub repository.
License (MIT)
These tutorials and source-code are published under the MIT License which allows very broad use for both academic and commercial purposes.
A few of the images used for demonstration purposes may be under copyright. These images are included under the "fair usage" laws.
You are very welcome to modify these tutorials and use them in your own projects. Please keep a link to the original repository.