"projects/DALLE2/vscode:/vscode.git/clone" did not exist on "3b355d3f9d5f4f5501ff6e76ba4018d83b640087"
overview_zh.rst 3.79 KB
Newer Older
1
.. b6bdf52910e2e2c72085d03482d45340
2

Chi Song's avatar
Chi Song committed
3
模型压缩
J-shang's avatar
J-shang committed
4
5
========

6
7
8
9
10
11
12
13
14
15
16
17
18
深度神经网络(DNNs)在计算机视觉、自然语言处理、语音处理等领域取得了巨大的成功。   
然而,典型的神经网络是计算和能源密集型的,很难将其部署在计算资源匮乏
或具有严格延迟要求的设备上。 因此,一个自然的想法就是对模型进行压缩,
以减小模型大小并加速模型训练/推断,同时不会显着降低模型性能。 
模型压缩技术可以分为两类:剪枝和量化。 剪枝方法探索模型权重中的冗余,
并尝试删除/修剪冗余和非关键的权重。 量化是指通过减少权重表示或激活所需的比特数来压缩模型。
在接下来的章节中,我们将进一步阐述这两种方法: 剪枝和量化。 
此外,下图直观地展示了这两种方法的区别。  

.. image:: ../../img/prune_quant.jpg
   :target: ../../img/prune_quant.jpg
   :scale: 40%
   :alt:
kvartet's avatar
kvartet committed
19
20

NNI 提供了易于使用的工具包来帮助用户设计并使用剪枝和量化算法。
Chi Song's avatar
Chi Song committed
21
其使用了统一的接口来支持 TensorFlow 和 PyTorch。
22
23
对用户来说, 只需要添加几行代码即可压缩模型。
NNI 中也内置了一些主流的模型压缩算法。
Chi Song's avatar
Chi Song committed
24
用户可以进一步利用 NNI 的自动调优功能找到最佳的压缩模型,
25
该功能在自动模型压缩部分有详细介绍。
Chi Song's avatar
Chi Song committed
26
另一方面,用户可以使用 NNI 的接口自定义新的压缩算法。
27
28
29
30
31
32
33
34
35


NNI 具备以下几个核心特性:
* 内置许多流行的剪枝和量化算法。
* 利用最先进的策略和NNI的自动调整能力,来自动化模型剪枝和量化过程。
* 加速模型,使其有更低的推理延迟。
* 提供友好和易于使用的压缩工具,让用户深入到压缩过程和结果。
* 简洁的界面,供用户自定义自己的压缩算法。

36
37
压缩流程
---------
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52

.. image:: ../../img/compression_pipeline.png
   :target: ../../img/compression_pipeline.png
   :alt:
   :align: center
   :scale: 30%

NNI中模型压缩的整体流程如上图所示。
为了压缩一个预先训练好的模型,可以单独或联合使用修剪和量化。
如果用户希望同时应用这两种模式,建议采用串行模式。


.. note::
  值得注意的是,NNI的pruner或quantizer并不能改变网络结构,只能模拟压缩的效果。
  真正能够压缩模型、改变网络结构、降低推理延迟的是NNI的加速工具。
53
  为了获得一个真正的压缩的模型,用户需要执行 :doc:`剪枝加速 <../tutorials/pruning_speedup>` or :doc:`量化加速 <../tutorials/quantization_speedup>`. 
54
55
56
  PyTorch和TensorFlow的接口都是统一的。目前只支持PyTorch版本,未来将支持TensorFlow版本。


57
58
模型加速
---------
59
60
61
62
63
64
65
66
67
68
69
70
71
72

模型压缩的最终目标是减少推理延迟和模型大小。
然而,现有的模型压缩算法主要是通过仿真来检测压缩模型的性能。
例如,修剪算法使用掩码,量化算法仍将值存储在float32中。
如果能给定这些算法产生的输出掩码和量化位,NNI的加速工具就可以真正地压缩模型。

下图显示了NNI如何修剪和加速您的模型。

.. image:: ../../img/nni_prune_process.png
   :target: ../../img/nni_prune_process.png
   :scale: 30%
   :align: center
   :alt:

73
74
关于用掩码进行模型加速的详细文档可以参考 :doc:`here <../tutorials/pruning_speedup>`.
关于用校准配置进行模型加速的详细文档可以参考 :doc:`here <../tutorials/quantization_speedup>`.
75
76
77
78
79
80
81


.. attention::

  NNI的模型剪枝框架已经升级到更高级的版本 (在 nni 2.6 版本前称为pruning v2)。
  旧版本 (`named pruning before nni v2.6 <https://nni.readthedocs.io/en/v2.6/Compression/pruning.html>`_) 不再进行维护. 
  如果出于某些原因您不得不使用,v2.6 是最后的支持旧版剪枝算法的版本。