Book Image

Intelligent Mobile Projects with TensorFlow

By : Jeff Tang
Book Image

Intelligent Mobile Projects with TensorFlow

By: Jeff Tang

Overview of this book

As a developer, you always need to keep an eye out and be ready for what will be trending soon, while also focusing on what's trending currently. So, what's better than learning about the integration of the best of both worlds, the present and the future? Artificial Intelligence (AI) is widely regarded as the next big thing after mobile, and Google's TensorFlow is the leading open source machine learning framework, the hottest branch of AI. This book covers more than 10 complete iOS, Android, and Raspberry Pi apps powered by TensorFlow and built from scratch, running all kinds of cool TensorFlow models offline on-device: from computer vision, speech and language processing to generative adversarial networks and AlphaZero-like deep reinforcement learning. You’ll learn how to use or retrain existing TensorFlow models, build your own models, and develop intelligent mobile apps running those TensorFlow models. You'll learn how to quickly build such apps with step-by-step tutorials and how to avoid many pitfalls in the process with lots of hard-earned troubleshooting tips.
Table of Contents (14 chapters)

Drawing classification – how it works

The drawing classification model built into the TensorFlow tutorial (https://www.tensorflow.org/tutorials/recurrent_quickdraw) first takes the user drawing input represented as a list of points and converts the normalized input to a tensor of the deltas of consecutive points along with information about whether each point is the beginning of a new stroke. Then it passes the tensor through several convolutional layers and LSTM layers, and finally a softmax layer, as shown in Figure 7.1, to classify the user drawing:

Figure 7.1: The drawing classification mode

Unlike the 2D convolution API tf.layers.conv2d that accepts a 2D image input, the 1D convolution API tf.layers.conv1d is used here for temporal convolution such as drawing. By default, in the drawing classification model, three 1D convolutional layers are used and each layer has...