深度学习中参数量与计算量的理解

接下来要分别概述以下内容:

  1 首先什么是参数量,什么是计算量

  2 如何计算 参数量,如何统计 计算量

  3 换算参数量,把他换算成我们常用的单位,比如:mb

  4 对于各个经典网络,论述他们是计算量大还是参数两,有什么好处

  5 计算量,参数量分别对显存,芯片提出什么要求,我们又是怎么权衡

 

1 首先什么是计算量,什么是参数量

  计算量对应我们之前的时间复杂度,参数量对应于我们之前的空间复杂度,这么说就很明显了

也就是计算量要看网络执行时间的长短,参数量要看占用显存的量

 

2 如何计算 参数量,计算量

  (1)针对于卷积层的

  

    其中上面的公式是计算时间复杂度(计算量),而下面的公式是计算空间复杂度(参数量) 

    对于卷积层:

      参数量就是  (kernel*kernel) *channel_input*channel_output

        kernel*kernel 就是weight * weight

        其中kernel*kernel = 1个feature的参数量

      计算量就是  (kernel*kernel*map*map) *channel_input*channel_output

        kernel*kernel 就是weight*weight

        map*map是下个featuremap的大小,也就是上个weight*weight到底做了多少次运算

        其中kernel*kernel*map*map= 1个feature的计算量

   (2)针对于池化层:

      无参数

   (3)针对于全连接层:

        参数量=计算量=weight_in*weight_out

 

3 对于换算计算量

  1一般一个参数是值一个float,也就是4个字节,

  21kb=1024字节

4 对于各个经典网络:

  

  (1)换算

    以alexnet为例:

    参数量:6000万

    设每个参数都是float,也就是一个参数是4字节,

    总的字节数是24000万字节

    24000万字节= 24000万/1024/1024=228mb

  (2)为什么模型之间差距这么大

    这个关乎于模型的设计了,其中模型里面最费参数的就是全连接层,这个可以看alex和vgg,

    alex,vgg有很多fc(全连接层)

    resnet就一个fc

    inceptionv1(googlenet)也是就一个fc

  (3)计算量

    densenet其实这个模型不大,也就是参数量不大,因为就1个fc

    但是他的计算量确实很大,因为每一次都把上一个feature加进来,所以计算量真的很大

 

5 计算量与参数量对于硬件要求

  计算量,参数量对于硬件的要求是不同的

  计算量的要求是在于芯片的floaps(指的是gpu的运算能力)

  参数量取决于显存大小

   

 

posted @ 2019-04-08 17:23  freebirds  阅读(15296)  评论(0编辑  收藏  举报