PyTorch 动态量化(Dynamic Quantization)

PyTorch 的动态量化(Dynamic Quantization),包括原理、适用场景和具体示例。


1. 动态量化的概念

动态量化 (Dynamic Quantization) 是一种 后训练量化(Post-Training Quantization) 方法。

特点:

  1. 只量化权重

    • 模型的权重从 float32int8,减小模型存储大小。
  2. 激活在推理时动态量化

    • 前向传播时,激活会在每次计算时动态转换成 int8,再做矩阵运算。
  3. 不需要重新训练

    • 直接对训练好的模型量化即可。
  4. 适合 CPU 推理

    • 可以显著加速模型推理,同时减少内存占用。
  5. 适合全连接层和 LSTM

    • 对 Transformer、RNN、LSTM、全连接层效果好,对卷积层效果有限。

2. 动态量化原理

  • 对于一个全连接层:

    复制代码
    y = x @ W.T + b
    • W:权重矩阵 → 量化成 int8
    • x:输入激活 → 保持 float32,前向计算时动态量化
  • 矩阵乘法在 int8 上计算,然后转换回 float32 输出。

优势:

  • 模型大小减小 3~4 倍
  • 推理速度提升 2~4 倍(CPU 上明显)

3. PyTorch 使用示例

以你之前的 SimpleModel 为例:

python 复制代码
import torch
import torch.nn as nn
from torch.quantization import quantize_dynamic

# 定义模型
class SimpleModel(nn.Module):
    def __init__(self):
        super().__init__()
        self.fc1 = nn.Linear(128, 96)
        self.fc2 = nn.Linear(96, 64)
        self.fc3 = nn.Linear(64, 32)
        self.relu = nn.ReLU()

    def forward(self, x):
        x = self.relu(self.fc1(x))
        x = self.relu(self.fc2(x))
        out = self.fc3(x)
        return out

# 创建并训练好的模型(假设已经训练好)
model = SimpleModel()
# ----------------------------
# 模拟训练完成,直接量化
# ----------------------------

# 对全连接层进行动态量化
quantized_model = quantize_dynamic(
    model,                      # 原始模型
    {nn.Linear},                # 只量化 Linear 层
    dtype=torch.qint8            # 量化数据类型
)

# 保存量化后的模型
torch.save(quantized_model.state_dict(), "simple_model_dynamic_quant.pth")

# 使用量化模型进行推理
quantized_model.eval()
x_new = torch.randn(5, 128)
with torch.no_grad():
    y_pred = quantized_model(x_new)

print("动态量化模型输出形状:", y_pred.shape)  # [5, 32]

4. 动态量化特点总结

特性 动态量化
权重类型 int8
激活类型 float32 → 推理时动态量化
是否需要训练 不需要
适用层 Linear, LSTM, Transformer
优势 模型小,推理快,兼容 CPU
缺点 对卷积网络加速有限,精度可能略下降

小结

  • 动态量化:训练后直接量化 → CPU 推理加速 → 不改训练代码
  • 静态量化/量化感知训练 (QAT):需要校准或训练 → 精度更高 → GPU/CPU 均可

相关推荐
火山引擎开发者社区6 小时前
没有长期记忆,Agent 谈何持续进化?一图看懂火山 Mem0:解锁 Agent 持续学习与进化之路
人工智能
冬奇Lab10 小时前
Workflow 系列(06):安全——跨步骤注入传播与四层防御
人工智能·工作流引擎
冬奇Lab10 小时前
每日一个开源项目(第149篇):RAG-Anything - 把图片、表格、公式当成一等公民的多模态 RAG 框架
人工智能·开源
米小虾10 小时前
AI Agent 安全实战指南:当智能体开始"不听话",开发者该如何应对?
人工智能·安全·agent
IT_陈寒12 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
用户83562907805113 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
用户83562907805113 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
阿里云大数据AI技术14 小时前
构建高转化海外电商搜索:阿里云OpenSearch行业算法版的全链路智能优化策略实战
人工智能·搜索引擎
Awu122714 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude