Skip to main content

Repository of Intel® Low Precision Optimization Tool

Project description

Introduction to Intel® LPOT

The Intel® Low Precision Optimization Tool (Intel® LPOT) is an open-source Python library that delivers a unified low-precision inference interface across multiple Intel-optimized Deep Learning (DL) frameworks on both CPUs and GPUs. It supports automatic accuracy-driven tuning strategies, along with additional objectives such as optimizing for performance, model size, and memory footprint. It also provides easy extension capability for new backends, tuning strategies, metrics, and objectives.

Note

GPU support is under development.

Visit the Intel® LPOT online document website at: https://intel.github.io/lpot.

Architecture

Intel® LPOT features an infrastructure and workflow that aids in increasing performance and faster deployments across architectures.

Infrastructure

Infrastructure

Click the image to enlarge it.

Workflow

Workflow

Click the image to enlarge it.

Supported Frameworks

Supported Intel-optimized DL frameworks are:

Installation

Select the installation based on your operating system.

Linux Installation

You can install LPOT using one of three options: Install just the LPOT library from binary or source, or get the Intel-optimized framework together with the LPOT library by installing the Intel® oneAPI AI Analytics Toolkit.

Option 1 Install from binary

# install stable version from pip
pip install lpot

# install nightly version from pip
pip install -i https://test.pypi.org/simple/ lpot

# install stable version from from conda
conda install lpot -c conda-forge -c intel 

Option 2 Install from source

git clone https://github.com/intel/lpot.git
cd lpot
pip install -r requirements.txt
python setup.py install

Option 3 Install from AI Kit

The Intel® LPOT library is released as part of the Intel® oneAPI AI Analytics Toolkit (AI Kit). The AI Kit provides a consolidated package of Intel's latest deep learning and machine optimizations all in one place for ease of development. Along with LPOT, the AI Kit includes Intel-optimized versions of deep learning frameworks (such as TensorFlow and PyTorch) and high-performing Python libraries to streamline end-to-end data science and AI workflows on Intel architectures.

The AI Kit is distributed through many common channels, including from Intel's website, YUM, APT, Anaconda, and more. Select and download the AI Kit distribution package that's best suited for you and follow the Get Started Guide for post-installation instructions.

Download AI Kit AI Kit Get Started Guide

Windows Installation

Prerequisites

The following prerequisites and requirements must be satisfied for a successful installation:

  • Python version: 3.6 or 3.7 or 3.8

  • Download and install anaconda.

  • Create a virtual environment named lpot in anaconda:

    # Here we install python 3.7 for instance. You can also choose python 3.6 & 3.8.
    conda create -n lpot python=3.7
    conda activate lpot
    

Installation options

Option 1 Install from binary

# install stable version from pip
pip install lpot

# install nightly version from pip
pip install -i https://test.pypi.org/simple/ lpot

# install from conda
conda install lpot -c conda-forge -c intel 

Option 2 Install from source

git clone https://github.com/intel/lpot.git
cd lpot
pip install -r requirements.txt
python setup.py install

Documentation

Get Started

  • APIs explains Intel® Low Precision Optimization Tool's API.
  • Transform introduces how to utilize LPOT's built-in data processing and how to develop a custom data processing method.
  • Dataset introduces how to utilize LPOT's built-in dataset and how to develop a custom dataset.
  • Metric introduces how to utilize LPOT's built-in metrics and how to develop a custom metric.
  • Tutorial provides comprehensive instructions on how to utilize LPOT's features with examples.
  • Examples are provided to demonstrate the usage of LPOT in different frameworks: TensorFlow, PyTorch, MXNet, and ONNX Runtime.
  • UX is a web-based system used to simplify LPOT usage.
  • Intel oneAPI AI Analytics Toolkit Get Started Guide explains the AI Kit components, installation and configuration guides, and instructions for building and running sample apps.
  • AI and Analytics Samples includes code samples for Intel oneAPI libraries.

Deep Dive

  • Quantization are processes that enable inference and training by performing computations at low-precision data types, such as fixed-point integers. LPOT supports Post-Training Quantization (PTQ) and Quantization-Aware Training (QAT). Note that (Dynamic Quantization) currently has limited support.
  • Pruning provides a common method for introducing sparsity in weights and activations.
  • Benchmarking introduces how to utilize the benchmark interface of LPOT.
  • Mixed precision introduces how to enable mixed precision, including BFP16 and int8 and FP32, on Intel platforms during tuning.
  • Graph Optimization introduces how to enable graph optimization for FP32 and auto-mixed precision.
  • Model Conversion introduces how to convert TensorFlow QAT model to quantized model running on Intel platforms.
  • TensorBoard provides tensor histograms and execution graphs for tuning debugging purposes.

Advanced Topics

  • Adaptor is the interface between LPOT and framework. The method to develop adaptor extension is introduced with ONNX Runtime as example.
  • Strategy can automatically optimized low-precision recipes for deep learning models to achieve optimal product objectives like inference performance and memory usage with expected accuracy criteria. The method to develop a new strategy is introduced.

System Requirements

Intel® Low Precision Optimization Tool supports systems based on Intel 64 architecture or compatible processors, specially optimized for the following CPUs:

  • Intel Xeon Scalable processor (formerly Skylake, Cascade Lake, and Cooper Lake)
  • future Intel Xeon Scalable processor (code name Sapphire Rapids)

Intel® Low Precision Optimization Tool requires installing the pertinent Intel-optimized framework version for TensorFlow, PyTorch, and MXNet.

Validated Hardware/Software Environment

Platform OS Python Framework Version
Cascade Lake

Cooper Lake

Skylake
CentOS 7.8

Ubuntu 18.04
3.6

3.7

3.8
TensorFlow 2.4.0
2.2.0
1.15.0 UP1
1.15.0 UP2
2.3.0
2.1.0
1.15.2
PyTorch 1.5.0+cpu
1.6.0+cpu
IPEX
MXNet 1.7.0
1.6.0
ONNX Runtime 1.6.0

Validated Models

Intel® Low Precision Optimization Tool provides numerous examples to show promising accuracy loss with the best performance gain. A full quantized model list on various frameworks is available in the Model List.

Framework version Model dataset Accuracy Performance speed up
INT8 Tuning Accuracy FP32 Accuracy Baseline Acc Ratio[(INT8-FP32)/FP32] Realtime Latency Ratio[FP32/INT8]
tensorflow 2.4.0 resnet50v1.5 ImageNet 76.70% 76.50% 0.26% 3.23x
tensorflow 2.4.0 Resnet101 ImageNet 77.20% 76.40% 1.05% 2.42x
tensorflow 2.4.0 inception_v1 ImageNet 70.10% 69.70% 0.57% 1.88x
tensorflow 2.4.0 inception_v2 ImageNet 74.10% 74.00% 0.14% 1.96x
tensorflow 2.4.0 inception_v3 ImageNet 77.20% 76.70% 0.65% 2.36x
tensorflow 2.4.0 inception_v4 ImageNet 80.00% 80.30% -0.37% 2.59x
tensorflow 2.4.0 inception_resnet_v2 ImageNet 80.10% 80.40% -0.37% 1.97x
tensorflow 2.4.0 Mobilenetv1 ImageNet 71.10% 71.00% 0.14% 2.88x
tensorflow 2.4.0 ssd_resnet50_v1 Coco 37.90% 38.00% -0.26% 2.97x
tensorflow 2.4.0 mask_rcnn_inception_v2 Coco 28.90% 29.10% -0.69% 2.66x
tensorflow 2.4.0 vgg16 ImageNet 72.50% 70.90% 2.26% 3.75x
tensorflow 2.4.0 vgg19 ImageNet 72.40% 71.00% 1.97% 3.79x
Framework version model dataset Accuracy Performance speed up
INT8 Tuning Accuracy FP32 Accuracy Baseline Acc Ratio[(INT8-FP32)/FP32] Realtime Latency Ratio[FP32/INT8]
pytorch 1.5.0+cpu resnet50 ImageNet 75.96% 76.13% -0.23% 2.63x
pytorch 1.5.0+cpu resnext101_32x8d ImageNet 79.12% 79.31% -0.24% 2.61x
pytorch 1.6.0a0+24aac32 bert_base_mrpc MRPC 88.90% 88.73% 0.19% 1.98x
pytorch 1.6.0a0+24aac32 bert_base_cola COLA 59.06% 58.84% 0.37% 2.19x
pytorch 1.6.0a0+24aac32 bert_base_sts-b STS-B 88.40% 89.27% -0.97% 2.28x
pytorch 1.6.0a0+24aac32 bert_base_sst-2 SST-2 91.51% 91.86% -0.37% 2.30x
pytorch 1.6.0a0+24aac32 bert_base_rte RTE 69.31% 69.68% -0.52% 2.15x
pytorch 1.6.0a0+24aac32 bert_large_mrpc MRPC 87.45% 88.33% -0.99% 2.73x
pytorch 1.6.0a0+24aac32 bert_large_squad SQUAD 92.85% 93.05% -0.21% 2.01x
pytorch 1.6.0a0+24aac32 bert_large_qnli QNLI 91.20% 91.82% -0.68% 2.69x

Additional Content

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

lpot-1.4.tar.gz (1.7 MB view details)

Uploaded Source

Built Distribution

lpot-1.4-py3-none-any.whl (2.0 MB view details)

Uploaded Python 3

File details

Details for the file lpot-1.4.tar.gz.

File metadata

  • Download URL: lpot-1.4.tar.gz
  • Upload date:
  • Size: 1.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0.post20200518 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.3

File hashes

Hashes for lpot-1.4.tar.gz
Algorithm Hash digest
SHA256 e65a24b7a2049a0ddd18de92daaf1d845e06184d2f1b88d739652d45970718ce
MD5 33fb1b14ff6e0f0012cf20827e0d5ddf
BLAKE2b-256 c2fdb8fd3b95d3ccc1946e9a36821e0f79edf483cfe04ce47e9c9ef9e6659747

See more details on using hashes here.

File details

Details for the file lpot-1.4-py3-none-any.whl.

File metadata

  • Download URL: lpot-1.4-py3-none-any.whl
  • Upload date:
  • Size: 2.0 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.4.0.post20200518 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.3

File hashes

Hashes for lpot-1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 e511a8450cb6cdfac1762a72cf791e871f822f0a4595919c858b577341a17198
MD5 e1a8889ea14221c62048108bd22d4b0d
BLAKE2b-256 c411cae13e9e2b0db5cfb57d33bc955638d1ea1f8f04fbb9d1741664f1e150e0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page