本文主要是介绍QLoRa 低秩分解+权重量化的微调,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
QLoRa的核心思想是首先使用低秩分解技术降低参数的数量,然后对这些低秩表示的参数应用量化技术,进一步减少所需的存储空间和计算量。
https://arxiv.org/abs/2305.14314
低秩分解
低秩分解(Low-Rank Factorization):通过将模型中的权重矩阵分解为更小的矩阵乘积,减少模型中的参数数量。
参看:LoRA 微调和低秩矩阵
类似下图,4×5
的矩阵变成 4×2
的矩阵跟 2×5
的矩阵乘积:
这种方法特别适用于减少全连接层和卷积层的参数,因为这些层通常包含大量的参数。
权重量化
权重量化(Weight Quantization):在进行低秩分解之后,QLoRa对得到的低秩矩阵进行量化,将浮点数权重转换为低比特宽度的表示形式。
这进一步减少了模型的存储需求和计算复杂度,使模型更适合部署在资源受限的设备上。
下面是一些常见的权重量化方法及其对计算和存储复杂度的影响的比较:
-
存储复杂度降低:这指的是模型权重存储空间的减少。例如,使用8位整数(INT8)量化时,存储需求是原始32位浮点数(FP32)的1/4,因此存储复杂度降低了4倍。
-
计算复杂度降低:这主要指的是运行模型所需的计算资源减少。计算复杂度的降低程度取决于特定硬件对不同数据类型操作的支持程度。一般来说,使用低比特宽度进行量化可以显著加速计算,尤其是在支持特定量化操作的硬件上。
需要注意的是,量化的比特宽度越低,对模型精度的潜在影响越大。因此,在选择量化策略时,需要在模型大小、计算效率与模型性能之间做出权衡。此外,实际的存储和计算复杂度降低也取决于特定的模型架构、硬件平台以及量化后的优化程度。
这篇关于QLoRa 低秩分解+权重量化的微调的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!