Skip to content

Readme

8-bit CPU Quantization of ResNet50 using NNCF on CIFAR-10 Dataset via NyunCLI Installation

8-bit quantization of Image Classification models are done via NNCF, ONNX Quantizers for CPU and TensorRT Quantizer for GPU deployment. This example shows how to Quantize a ResNet50 model with NNCF for CPU Quantization via nyuncli

Table of Contents

  1. Downloading NyunCLI
  2. Downloading the Dataset
  3. Model Loading
  4. Loading Pretrained Weights (Optional)
  5. Finetuning Model Before Training (Optional)
  6. Starting the Job
  7. Results

1. Downloading NyunCLI

Nyun-cli offers the users the luxury to compress their neural networks via a single command line. To download and install NyunCLI.

pip install git+https://github.com/nyunAI/nyunzero-cli.git
nyun init {WORKSPACE_PATH} ""

Here WORKSPACE_PATH is the root folder for running the experimentation and CUSTOM_DATA_PATH defines the path of custom data. The YAML_PATH is the path of configuration to be used. The base configuration used for this example can be found at vision scripts.This example offers a basic example for installing nyuncli visit nyuncli documentation for a more advanced installation.

2. Downloading the dataset

Downloading and formatting CIFAR-10 dataset is automated via Nyuntam. We need to specify the following hyperparameters in the YAML configuration

DATASET_NAME: CIFAR10
DATASET_PATH: {DATASET_PATH}
TASK: image_classification

Note: Dataset Path is expected to to be the path relative to WORKSPACE_PATH

3. Model Loading

Nyuntam supports most Classification models supported via HuggingFace, Timm and Torchvision libraries. We load ResNet50 from torchvision in this experiment. The following parameters in the YAML configuration are to be updated

MODEL_NAME: resnet50
PLATFORM: torchvision

4. Loading Pretrained Weights (Optional)

You can optionally load pretrained weights if you already have the same. In case of this tutorial we would be finetuning the CIFAR 10 on 10 epochs instead (see sec.5)

CUSTOM_MODEL_PATH: {CUSTOM_MODEL_PATH}
#leave CUSTOM_MODEL_PATH as "" if unused

5. Finetuning Model Before Training (Optional)

You can optionally fine-tune the model with these parameters to tune in with the custom dataset.

TRAINING: True
LEARNING_RATE: 0.001
FINETUNE_EPOCHS: 10
VALIDATE: True
VALIDATION_INTERVAL: 1

6. Starting the Job

The following command starts the job using nyun-cli. The NNCF

nyun run {CONFIG_PATH}

CONFIG Path Config path is the edited yaml used for defining the hyperparameters of the job.

After the job is completed the folder structure will be as follows

{WORKSPACE}
├── datasets
│   ├── {JOB_ID}
│   |   ├── train
│   |   ├── val
├── logs
│   ├── log.log
├── jobs
│   ├── mds.xml
│   ├── mds.bin

7. Results

The model post finetuning on cifar-10 for 10 epochs had validation 67.4 % validation accuracy and after quantization had an accuracy of 67.2 %. To benchmark the reduced latency of the model use NNCF Benchmarking tool using the following command.

benchmark_app -m {path to .xml file} -d CPU -api async

The Final Results are as follows:

Model Accuracy Latency
FP32 67.7 1.32 ms
INT8 67.2 0.68 ms