[发明专利]一种模型量化方法及其装置在审
| 申请号: | 202310220550.3 | 申请日: | 2023-02-27 |
| 公开(公告)号: | CN116151326A | 公开(公告)日: | 2023-05-23 |
| 发明(设计)人: | 刘振华;韩凯;王云鹤 | 申请(专利权)人: | 华为技术有限公司 |
| 主分类号: | G06N3/0464 | 分类号: | G06N3/0464;G06N3/048;G06N3/084;G06V20/58;G06V10/764;G06V10/82;G06V20/10;G06F16/35;G06V40/10;G06T3/00;G06N5/045 |
| 代理公司: | 深圳市深佳知识产权代理事务所(普通合伙) 44285 | 代理人: | 吴欣蔚 |
| 地址: | 518129 广东*** | 国省代码: | 广东;44 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 一种 模型 量化 方法 及其 装置 | ||
1.一种模型量化方法,其特征在于,所述方法包括:
获取神经网络的第一参数;所述第一参数包括所述神经网络中中间层的权重矩阵或者所述中间层输出的特征图,所述神经网络为浮点模型;
根据所述第一参数的数值分布,确定量化截断区间,所述量化截断区间包括上界阈值和下界阈值,其中,所述第一参数中数值小于所述下界阈值的参数数量、所述第一参数中数值大于所述下界阈值且小于所述上界阈值的参数数量、以及所述第一参数中数值大于所述上界阈值的参数数量三者之间的差异小于阈值;
根据所述量化截断区间,对所述第一参数进行三值量化,得到量化后的所述神经网络。
2.根据权利要求1所述的方法,其特征在于,所述第一参数满足高斯分布,所述数值分布包括所述第一参数的均值和方差,所述上界阈值为所述均值和第一数值的加和结果,所述第一数值为所述方差与预设比例的乘积,所述下界阈值为所述均值和所述第一数值的差值结果。
3.根据权利要求2所述的方法,其特征在于,所述预设比例为0.43。
4.根据权利要求1至3任一所述的方法,其特征在于,所述根据所述量化截断区间,对所述第一参数进行三值量化之后,所述方法还包括:
对所述量化后的所述神经网络进行训练,并更新所述上界阈值和所述下界阈值,以得到更新后的上界阈值和更新后的下界阈值。
5.根据权利要求1至4任一所述的方法,其特征在于,所述根据所述量化截断区间,对所述第一参数进行三值量化,包括:
根据所述量化截断区间,通过第一预设方式,对所述第一参数进行三值量化;其中,所述第一预设方式包括:数值小于所述下界阈值的参数被量化为第一量化系数,数值大于所述上界阈值的参数被量化为第二量化系数;
所述方法还包括:
对所述量化后的所述神经网络进行训练,并更新所述第一量化系数和所述第二量化系数,以得到更新后的第一量化系数和更新后的第二量化系数。
6.根据权利要求5所述的方法,其特征在于,所述第一量化系数和所述第二量化系数为相反数。
7.根据权利要求4至6任一所述的方法,其特征在于,所述第一参数包括所述神经网络中中间层的权重矩阵以及所述中间层输出的特征图;
所述对所述量化后的所述神经网络进行训练,包括:
以所述神经网络为老师模型,对量化后的所述神经网络进行训练,并更新量化后的所述神经网络中中间层的权重矩阵,得到第一神经网络;
以所述神经网络为老师模型,对所述第一神经网络进行训练,并更新所述第一神经网络中所述中间层的权重矩阵以及所述中间层输出的特征图进行更新,得到第二神经网络。
8.根据权利要求4至7任一所述的方法,其特征在于,所述更新所述上界阈值和所述下界阈值,包括:
根据量化后的所述神经网络在前向传播的处理结果确定目标损失;
根据目标损失以及第二预设方式,确定所述上界阈值和所述下界阈值对应的更新梯度;其中,所述第二预设方式为通过将所述第一预设方式调整为可导的变换得到的。
9.根据权利要求5至8任一所述的方法,其特征在于,所述更新所述第一量化系数和所述第二量化系数,包括:
根据量化后的所述神经网络在前向传播的处理结果确定目标损失;
根据目标损失以及第二预设方式,确定所述第一量化系数和所述第二量化系数对应的更新梯度;其中,所述第二预设方式为通过将所述第一预设方式调整为可导的变换得到的。
10.根据权利要求8或9所述的方法,其特征在于,所述第二预设方式为随机量化。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于华为技术有限公司,未经华为技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202310220550.3/1.html,转载请声明来源钻瓜专利网。





