Join TensorFlow at Google I/O, May 11-12 Register now

TensorFlow Lite for Android

TensorFlow Lite lets you run TensorFlow machine learning (ML) models in your Android apps. The TensorFlow Lite system provides prebuilt and customizable execution environments for running models on Android quickly and efficiently, including options for hardware acceleration.

Learning roadmap

Learn concepts and code design for building Android apps with TensorFlow Lite, just keep reading.
Start coding an Android app with TensorFlow Lite right away with the Quickstart.
Learn about choosing and using ML models with TensorFlow Lite, see the Models docs.

Machine learning models

TensorFlow Lite uses TensorFlow models that are converted into a smaller, portable, more efficient machine learning model format. You can use pre-built models with TensorFlow Lite on Android, or build your own TensorFlow models and convert them to TensorFlow Lite format.

This page discusses using already-built machine learning models and does not cover building, training, testing, or converting models. Learn more about picking, modifying, building, and converting machine learning models for TensorFlow Lite in the Models section.

Run models on Android

A TensorFlow Lite model running inside an Android app takes in data, processes the data, and generates a prediction based on the model's logic. A TensorFlow Lite model requires a special runtime environment in order to execute, and the data that is passed into the model must be in a specific data format, called a tensor. When a model processes the data, known as running an inference, it generates prediction results as new tensors, and passes them to the Android app so it can take action, such as showing the result to a user or executing additional business logic.

Functional execution flow for TensorFlow Lite models in Android
apps

Figure 1. Functional execution flow for TensorFlow Lite models in Android apps.

At the functional design level, your Android app needs the following elements to run a TensorFlow Lite model:

  • TensorFlow Lite runtime environment for executing the model
  • Model input handler to transform data into tensors
  • Model output handler to receive output result tensors and interpret them as prediction results

The following sections describe how the TensorFlow Lite libraries and tools provide these functional elements.

Build apps with TensorFlow Lite

This section describes the recommended, most common path for implementing TensorFlow Lite in your Android App. You should pay most attention to the runtime environment and development libraries sections. If you have developed a custom model, make sure to review the Advanced development paths section.

Runtime environment options

There are several ways you can enable a runtime environment for executing models in your Android app. These are the preferred options:

In general, you should use the standard TensorFlow Lite runtime environment, since this is the most versatile environment for running models on Android. The runtime environment provided by Google Play services is more convenient and space-efficient than the standard environment, since it is loaded from Google Play resources and not bundled into your app. Some advanced use cases require customization of model runtime environment, which are described in the Advanced runtime environments section.

You access these runtime enviroments in your Android app by adding TensorFlow Lite development libraries to your app development environment. For information about how to use the standard runtime environment in your app, see the next section. For information about other runtime environments, see Advanced runtime environments.

Development APIs and libraries

There are two main APIs you can use to integrate TensorFlow Lite machine learning models into your Android app:

The Interpreter API provides classes and methods for running inferences with existing TensorFlow Lite models. The TensorFlow Lite Task API wraps the Interpreter API and provides a higher-level programming interface for performing common machine learning tasks on handling visual, audio, and text data. You should use the Task API unless you find it does not support your specific use case.

Libraries

You can access the Task API by including the TensorFlow Lite Task Library in your Android app. The Task library also includes the Interpreter API classes and methods if you need them.

If just want to use the Interpreter API, you can include the TensorFlow Lite library. Alternatively, you can include Google Play services library for TensorFlow Lite, and access the Interpreter API through Play services, without bundling a separate libary into your app.

The TensorFlow Lite Support library is also available to provide additional functionality for managing data for models, model metadata, and model inference results.

For programming details about using TensorFlow Lite libraries and runtime environments, see Development tools for Android.

Obtain models

Running a model in an Android app requires a TensorFlow Lite-format model. You can use prebuilt models or build one with TensorFlow and convert it to the Lite format. For more information on obtaining models for your Android app, see the TensorFlow Lite Models section.

Handle input data

Any data you pass into a ML model must be a tensor with a specific data structure, often called the shape of the tensor. To process data with a model, your app code must transform data from its native format, such as image, text, or audio data, into a tensor in the required shape for your model.

The TensorFlow Lite Task library provides data handling logic for transforming visual, text, and audio data into tensors with the correct shape to be processed by a TensorFlow Lite model.

Run inferences

Processing data through a model to generate a prediction result is known as running an inference. Running an inference in an Android app requires a TensorFlow Lite runtime environment, a model and input data.

The speed at which a model can generate an inference on a particular device depends on the size of the data processed, the complexity of the model, and the available computing resources such as memory and CPU, or specialized processors called accelerators. Machine learning models can run faster on these specialized processors such as graphics processing units (GPUs) and tensor processing units (TPUs), using TensorFlow Lite hardware drivers called delegates. For more information about delegates and hardware acceleration of model processing, see the Hardware acceleration overview.

Handle output results

Models generate prediction results as tensors, which must be handled by your Android app by taking action or displaying a result to the user. Model output results can be as simple as a number corresponding to a single result (0 = dog, 1 = cat, 2 = bird) for an image classification, to much more complex results, such as multiple bounding boxes for several classified objects in an image, with prediction confidence ratings between 0 and 1.

Advanced development paths

When using more sophisticated and customized TensorFlow Lite models, you may need to use more advanced development approaches than what is described above. The following sections describe advanced techniques for executing models and developing them for TensorFlow Lite in Android apps.

Advanced runtime environments

In addition to the standard runtime and Google Play services runtime environments for TensorFlow Lite, there are additional runtime environments you can use with your Android app. The most likely use for these environments is if you have a machine learning model that uses ML operations that are not supported by the standard runtime environment for TensorFlow Lite.

  • Flex runtime for TensorFlow Lite
  • Custom-built TensorFlow Lite runtime

The TensorFlow Lite Flex runtime allows you to include specific operators required for your model. As an advanced option for running your model, you can build TensorFlow Lite for Android to include operators and other functionality required for running your TensorFlow machine learning model. For more information, see Build TensorFlow Lite for Android.

C and C++ APIs

TensorFlow Lite also provides an API for running models using C and C++. If your app uses the Android NDK, you should consider using this API. You may also want to consider using this API if you want to be able to share code between multiple platforms. For more information about this development option, see the Development tools page.

Server-based model execution

In general, you should run models in your app on an Android device to take advantage of lower latency and improved data privacy for your users. However, there are cases where running a model on a cloud server, off device, is a better solution. For example, if you have a large model which does not easily compress down to a size that fits on your users' Android devices, or can be executed with reasonable performance on those devices. This approach may also be your preferred solution if consistent performance of the model across a wide range of devices is top priority.

Google Cloud offers a full suite of services for running TensorFlow machine learning models. For more information, see Google Cloud's AI and machine learning products page.

Custom model development and optimization

More advanced development paths are likely to include developing custom machine learning models and optimizing those models for use on Android devices. If you plan to build custom models, make sure you consider applying quantization techniques to models to reduce memory and processing costs. For more information on how to build high-performance models for use with TensorFlow Lite, see Performance best practices in the Models section.

Next Steps