PyTorch AO v0.10.0发布:量化训练与低比特优化的新突破
PyTorch AO(torchao)是PyTorch生态中专注于模型量化和优化的核心库。作为PyTorch官方支持的量化工具链,它提供了从训练时量化(QAT)到推理优化的完整解决方案。最新发布的v0.10.0版本带来了多项重要更新,特别是在低比特优化、新型量化格式支持和模块化量化API方面取得了显著进展。
MXFP8训练支持:NVIDIA B200上的性能飞跃
v0.10.0版本最引人注目的特性是对MXFP8(Microscaling Formats)数据类型的端到端训练支持。MXFP8是一种新型的8位浮点格式,专为AI训练设计,在NVIDIA最新的B200 GPU上展现出卓越的性能表现。
测试数据显示,使用cuBLAS的MXFP8矩阵乘法(GEMM)操作相比传统的bfloat16实现了超过2倍的加速比。更令人印象深刻的是,从bfloat16到MXFP8的数据类型转换操作达到了惊人的5.5TB/s带宽。这一突破主要得益于:
- 优化的Triton内核实现,支持MXFP8的列主序存储
- 改进的编译器融合策略,减少数据类型转换开销
- 针对大规模张量的特殊处理优化
开发者现在可以通过简单的API调用将模型转换为MXFP8格式进行训练,同时保持与标准浮点训练相当的模型精度。这一特性特别适合大规模语言模型训练场景,能显著降低显存占用和计算开销。
PARQ:基于正则化的渐进式量化新范式
v0.10.0引入了一种创新的量化方法——Piecewise-Affine Regularized Quantization(PARQ)。与传统的量化感知训练(QAT)不同,PARQ通过优化器层面的正则化实现量化,无需修改模型的前向或反向传播过程。
PARQ的核心优势在于:
- 统一框架支持标准QAT和渐进式量化策略
- 仅需在优化器中添加量化配置,不影响模型结构
- 基于理论保证的量化诱导方法,确保训练稳定性
使用示例展示了其简洁性:开发者只需在参数组中指定量化位数,然后用QuantOptimizer包装原有优化器即可。这种方法大幅降低了量化训练的实现复杂度,同时提供了灵活的量化策略配置空间。
模块化量化API:研究友好的新接口
新版本推出了模块交换量化API的原型实现,为研究社区提供了更灵活的量化工具。该API允许开发者直接将线性层或嵌入层替换为量化版本,并通过量化器对象精细控制权重和输入的量化方式。
关键特性包括:
- 支持动态量化和静态量化配置
- 可组合的量化器设计,支持对称/非对称量化
- 灵活的位宽和分组大小设置
- 与现有量化流程的兼容性设计
这种模块化设计使得研究者可以快速实验新的量化算法,而无需深入底层实现细节。虽然目前仍处于原型阶段,但这一API代表了torchao向更通用、更可扩展的量化框架演进的重要一步。
低比特优化器正式支持与性能提升
此前作为原型特性的低比特优化器在v0.10.0中升级为正式支持功能。这些优化器专为量化训练设计,能够在保持模型精度的同时显著减少内存占用和计算开销。
配套的低比特CPU和MPS内核现在支持通过源码安装,特别针对Arm架构的Mac设备进行了优化。新版本引入了多项改进:
- 1-8位通用内核支持,覆盖更广泛的量化需求
- 共享嵌入量化器,优化Llama等模型的嵌入层处理
- 基于CPU特性的运行时微内核选择机制
- KleidiAI微内核库集成,提升Arm CPU上的GEMM性能
开发者现在可以使用简洁的API实现高性能的低比特推理,特别是在资源受限的边缘设备上,这些优化能带来显著的加速效果。
向后兼容性调整与未来方向
v0.10.0版本也包含了一些重要的API调整:
- 移除了Float8Config中的延迟缩放(delayed scaling)支持
- 强化了quantize_函数的类型检查
- 解耦了量化配置与torchinductor的依赖关系
这些变化虽然需要开发者进行少量代码调整,但使得API更加清晰和一致。项目团队表示,未来将继续优化MXFP8性能,完善模块化量化API,并扩展对更多硬件平台的支持。
PyTorch AO v0.10.0的发布标志着量化训练技术的重要进步,特别是为需要高效训练大规模模型的研究者和工程师提供了更多可能性。随着这些新特性的成熟和普及,我们有望看到更多低资源消耗、高性能的AI模型在实际场景中得到应用。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C090
baihu-dataset异构数据集“白虎”正式开源——首批开放10w+条真实机器人动作数据,构建具身智能标准化训练基座。00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python058
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7GLM-4.7上线并开源。新版本面向Coding场景强化了编码能力、长程任务规划与工具协同,并在多项主流公开基准测试中取得开源模型中的领先表现。 目前,GLM-4.7已通过BigModel.cn提供API,并在z.ai全栈开发模式中上线Skills模块,支持多模态任务的统一规划与协作。Jinja00
AgentCPM-Explore没有万亿参数的算力堆砌,没有百万级数据的暴力灌入,清华大学自然语言处理实验室、中国人民大学、面壁智能与 OpenBMB 开源社区联合研发的 AgentCPM-Explore 智能体模型基于仅 4B 参数的模型,在深度探索类任务上取得同尺寸模型 SOTA、越级赶上甚至超越 8B 级 SOTA 模型、比肩部分 30B 级以上和闭源大模型的效果,真正让大模型的长程任务处理能力有望部署于端侧。Jinja00