Skip to content
/ DFQ Public
forked from jakc4103/DFQ

PyTorch implementation of Data Free Quantization Through Weight Equalization and Bias Correction.

License

Notifications You must be signed in to change notification settings

mucaoshen/DFQ

Repository files navigation

DFQ

PyTorch implementation of Data Free Quantization Through Weight Equalization and Bias Correction with some ideas from ZeroQ: A Novel Zero Shot Quantization Framework.

Results on classification task

MobileNetV2 ResNet-18
model/precision FP32 Int8*
Original 71.81 0.102
+ReLU 71.78 0.102
+ReLU+LE 71.78 70.32
+ReLU+LE +DR -- 70.47
+BC -- 57.07
+BC +clip_15 -- 65.37
+ReLU+LE+BC -- 70.79
+ReLU+LE+BC +DR -- 70.9
model/precision FP32 Int8*
Original 69.76 69.13
+ReLU 69.76 69.13
+ReLU+LE 69.76 69.2
+ReLU+LE +DR -- 67.74
+BC -- 69.04
+BC +clip_15 -- 69.04
+ReLU+LE+BC -- 69.04
+ReLU+LE+BC +DR -- 67.65

Results on segmentation task

Pascal VOC 2012 val set (mIOU) Pascal VOC 2007 test set (mIOU)
model/precision FP32 Int8*
Original 70.81 60.03
+ReLU 70.72 60.0
+ReLU+LE 70.72 66.22
+ReLU+LE +DR -- 67.04
+ReLU+BC -- 69.04
+ReLU+BC +clip_15 -- 66.99
+ReLU+LE+BC -- 69.46
+ReLU+LE+BC +DR -- 70.12
model/precision FP32 Int8*
Original 74.54 62.36
+ReLU 74.35 61.66
+ReLU+LE 74.35 69.47
+ReLU+LE +DR -- 70.28
+BC -- 72.1
+BC +clip_15 -- 70.16
+ReLU+LE+BC -- 72.84
+ReLU+LE+BC +DR -- 73.5

Results on detection task

Pascal VOC 2012 val set (mAP with 12 metric) Pascal VOC 2007 test set (mAP with 07 metric)
model/precision FP32 Int8*
Original 70.77 70.46
+ReLU 67.49 67.22
+ReLU+LE 67.49 67.58
+ReLU+LE +DR -- --
+BC -- 70.47
+BC +clip_15 -- 70.71
+ReLU+LE+BC -- 68.09
+ReLU+LE+BC +DR -- --
model/precision FP32 Int8*
Original 60.69 60.54
+ReLU 57.84 57.21
+ReLU+LE 57.84 57.63
+ReLU+LE +DR -- --
+BC -- 60.48
+BC +clip_15 -- 60.68
+ReLU+LE+BC -- 58.09
+ReLU+LE+BC +DR -- --

Usage

There are 6 arguments, all default to False

  1. quantize: whether to quantize parameters and activations.
  2. relu: whether to replace relu6 to relu.
  3. equalize: whether to perform cross layer equalization.
  4. correction: whether to apply bias correction
  5. clip_weight: whether to clip weights in range [-15, 15] (for convolution and linear layer)
  6. distill_range: whether to use distill data for setting min/max range of activation quantization

run the equalized model by:

python main_cls.py --quantize --relu --equalize

run the equalized and bias-corrected model by:

python main_cls.py --quantize --relu --equalize --correction

run the equalized and bias-corrected model with distilled data by:

python main_cls.py --quantize --relu --equalize --correction --distill_range

Note

Distilled Data (2020/02/03 updated)

According to recent paper ZeroQ, we can distill some fake data to match the statistics from batch-normalization layers, then use it to set the min/max value range of activation quantization.
It does not need each conv followed by batch norm layer, and should produce better and more stable results using distilled data (the method from DFQ sometimes failed to find a good enough value range).

Here are some modifications that differs from original ZeroQ implementation:

  1. Initialization of distilled data
  2. Early stop criterion

Also, I think it can be applied to optimizing cross layer equalization and bias correction. The results will be updated as long as I make it to work.

Fake Quantization

The 'Int8' model in this repo is actually simulation of 8 bits, the actual calculation is done in floating points.
This is done by quantizing-dequantizing parameters in each layer and activation between 2 consecutive layers;
Which means each tensor will have dtype 'float32', but there would be at most 256 (2^8) unique values in it.

  Weight_quant(Int8) = Quant(Weight)
  Weight_quant(FP32) = Weight_quant(Int8*) = Dequant(Quant(Weight))

16-bits Quantization for Bias

Somehow I cannot make Bias-Correction work on 8-bits bias quantization (even with data dependent correction).
I am not sure how the original paper managed to do it with 8 bits quantization, but I guess they either use some non-uniform quantization techniques or use more bits for bias parameters as I do.

TODO

  • cross layer equalization
  • high bias absorption
  • data-free bias correction
  • test with detection model
  • test with classification model
  • use distilled data to set min/max activation range
  • use distilled data to find optimal scale matrix
  • use distilled data to do bias correction
  • True Int8 inference

Acknowledgment

About

PyTorch implementation of Data Free Quantization Through Weight Equalization and Bias Correction.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 97.8%
  • C++ 1.8%
  • Other 0.4%