zoukankan      html  css  js  c++  java
  • caffe Python API 之卷积层(Convolution)

    1、Convolution层:

    就是卷积层,是卷积神经网络(CNN)的核心层。

    层类型:Convolution

      lr_mult: 学习率的系数,最终的学习率是这个数乘以solver.prototxt配置文件中的base_lr。如果有两个lr_mult, 则第一个表示权值的学习率,第二个表示偏置项的学习率。一般偏置项的学习率是权值学习率的两倍。

    在后面的convolution_param中,我们可以设定卷积层的特有参数。

    必须设置的参数:

        num_output: 卷积核(filter)的个数

        kernel_size: 卷积核的大小。如果卷积核的长和宽不等,需要用kernel_h和kernel_w分别设定

    其它参数:

         stride: 卷积核的步长,默认为1。也可以用stride_h和stride_w来设置。

         pad: 扩充边缘,默认为0,不扩充。 扩充的时候是左右、上下对称的,比如卷积核的大小为5*5,那么pad设置为2,则四个边缘都扩充2个像素,即宽度和高度都扩充了4个像素,这样卷积运算之后的特征图就不会变小。也可以通过pad_h和pad_w来分别设定。

          weight_filler: 权值初始化。 默认为“constant",值全为0,很多时候我们用"xavier"算法来进行初始化,也可以设置为”gaussian"
          bias_filler: 偏置项的初始化。一般设置为"constant",值全为0。
          bias_term: 是否开启偏置项,默认为true, 开启
          group: 分组,默认为1组。如果大于1,我们限制卷积的连接操作在一个子集内。如果我们根据图像的通道来分组,那么第i个输出分组只能与第i个输入分组进行连接。
     
    输入:n*c0*w0*h0
    输出:n*c1*w1*h1
    其中,c1就是参数中的num_output,生成的特征图个数
     w1=(w0+2*pad-kernel_size)/stride+1;
     h1=(h0+2*pad-kernel_size)/stride+1;
    如果设置stride为1,前后两次卷积部分存在重叠。如果设置pad=(kernel_size-1)/2,则运算后,宽度和高度不变。
     
     
     
    net.conv1 = caffe.layers.Convolution(
        net.data,
        param=[{"lr_mult": 1, "decay_mult": 1}, {"lr_mult": 2, "decay_mult": 1}], #lr_mult: 学习率的系数,最终的学习率是这个数乘以solver.prototxt配置文件中的base_lr。
                                                  #如果有两个lr_mult, 则第一个表示权值的学习率,第二个表示偏置项的学习率。一般偏置项的学习率是权值学习率的两倍。
    name="Conv1", kernel_size=3, stride=1, pad=1, num_output=20, group=2, weight_filler=dict(type='xavier'), bias_filler=dict(type='constant',value=0))

    输出: layer { name:
    "Conv1" type: "Convolution" bottom: "data" top: "conv1" param { lr_mult: 1 decay_mult: 1 } param { lr_mult: 2 decay_mult: 1 } convolution_param { num_output: 20 pad: 1 kernel_size: 3 group: 2 stride: 1 weight_filler { type: "xavier" } bias_filler { type: "constant" value: 0 } } }
    形式二:
    net.conv2 = caffe.layers.Convolution(
        net.data,
        param=[{"lr_mult": 1, "decay_mult": 1}, {"lr_mult": 2, "decay_mult": 1}],
        name="Conv2",
        convolution_param=dict(
            kernel_size=3,
            stride=1,
            pad=1,
            num_output=20,
            group=2,
            weight_filler=dict(type='xavier'),
            bias_filler=dict(type='constant',value=0))
        )
    
    输出相同:
    layer {
      name: "Conv2"
      type: "Convolution"
      bottom: "data"
      top: "conv2"
      param {
        lr_mult: 1
        decay_mult: 1
      }
      param {
        lr_mult: 2
        decay_mult: 1
      }
      convolution_param {
        num_output: 20
        pad: 1
        kernel_size: 3
        group: 2
        stride: 1
        weight_filler {
          type: "xavier"
        }
        bias_filler {
          type: "constant"
          value: 0
        }
      }
    }
  • 相关阅读:
    Linux共享对象之编译参数fPIC
    如果重新设计网络,有没有可能合并IP地址跟MAC地址?
    HTTP的长连接和短连接
    Icon资源详解[2]
    Icon资源详解[1]
    LZMA demo挑选使用备忘
    SSM 拦截器验证权限和登录与注销的实现
    Intellij idea workflow 工作流插件安装
    C# HttpWebRequest post 请求传参数
    PLSQL 11注册码
  • 原文地址:https://www.cnblogs.com/houjun/p/9910413.html
Copyright © 2011-2022 走看看