TensorFlow for Researchers:
A Start to Finish Guide
Implementation and engineering are becoming increasingly important parts of machine learning as data gets bigger and the competition between researchers and companies heats up. Being able to quickly iterate on ideas is both necessary to keep up and makes machine learning a lot more fun.
This guide focuses on how to implement projects in TensorFlow. This is a mid-to-advanced level guide geared towards researchers working in AI. If you are looking for a quick introduction for to TensorFlow you may want to look for something simpler.
TensorFlow is Google’s “open-source software library for Machine Intelligence”. TensorFlow is a great tool for everyone in machine learning but I often myself:
- Repeating a lot of boiler plate code
- Searching for undocumented features and best practices across several blogs
- Finding an article for the correct topic but it is already out of date
- Not knowing which method to pick when there are several ways of implementing something
Here, I share a start-to-finish guide for taking your project from a messy set of data to a trained production model. Additionally, I’m planning on updating in place - when one of my practices changes because I improved my approach or TensorFlow has released a new version, I’ll update the guide here.
There are also templates from my related project TensorPlates to get a new project going faster, pro-tips from little tricks I’ve learned along the way, and explanations for un-or-under-documented features.
The explanations here assume prior knowledge of TensorFlow basics, python, and machine learning.
* Part 1 – Setup
Configuring your development environment for TensorFlow development.
* Part 2 – Preparing Data
Taking your 20GB worth of jpeg images saved in 50 different directories and converting them into TensorFlow’s preferred data format - TFRecords.
* Part 3 – Consuming Data
Creating a data Iterator that reads TFRecords, performs any pre-processing, and feeds data into your compute graph.
* Part 4 – Defining a Model
Defining your model as a TensorFlow Estimator – part of the new high-level API that handles some of the details of train/eval/test logic, logging results, and exporting your saved model.
* Part 5 – Training and Evaluating
This section covers the train/eval loop with Estimators as well as watching training with TensorBoard. I also share tips on how to do this when training remotely.
* Part 6 – Exporting, Testing, and Deploying
Exporting your trained model, testing on held-out data, and deploying that model as a service.
* Part 7 – All Together Now
Now that you understand every step of the process, let’s review and show how to put them all together quickly using templates that handle most of the boiler plate code.
* Part 8 – Furthur Reading and References
Links to articles I’ve found most useful, TensorFlow documentation, video guides, etc.