Conv2d 与 BatchNorm2d的融合计算

May 14, 2020, 10:12 a.m.

read: 2340

感谢知乎大佬的文章,给了我深刻的启发
https://zhuanlan.zhihu.com/p/49329030

原理正如上面的文章所示,上面的文章没有给出Conv和BatchNorm的维度信息,以及一些细节信息。下面给出一些实现细节,适用于BatchNorm2d(Conv2d(x))这种情况,在部署阶段可以节省计算量。
只适合部署阶段

参数导出

Conv2d有参数

weight 经过permute到这个形状 因为我一般用这个维度排列 (kernelSize x kernelSize x inputCh x outputCh)
bias (outputCh)

Norm2d有参数

running_var (outputCh)
running_mean (outputCh)
bn_weight (outputCh) 加上bn前置跟上面的CNN参数表示区分
bn_bias (outputCh)

融合

weight = bn_weight / np.sqrt(var + 1e-5) * weight
实际上 bn_weight的维度和weight的维度不一致,因此需要把bn_weight扩展出前三个为1的维度。上式就能计算下去。

bias = (bias - mean) / np.sqrt(var + 1e-5) * bn_weight + bn_bias

以新的weight和bias加入作为CNN的参数即可。




Linux上如何配置GitHub免密

Step 1运行一下命令 cat ~/.ssh/id_rsa.pub 如果输出公钥信息,则跳转到Step 2不然执行以下命令 ssh-keygen -t rsa 然后按2次回车 Step 2浏览器输…

Kaldi FBank算法阅读笔记

文章标题:Kaldi FBank算法阅读笔记文章内容:阅读过程make_fbank.sh $cmd JOB=1:$nj $logdir/make_fbank_${name}.JOB.log \ …

此站点由 ASP.NETIIS 驱动 | © 2018-2023 hupeng.me. All Rights Reserved.