Tic商业评论

关注微信公众号【站长自定义模块】,定时推送前沿、专业、深度的商业资讯。

 找回密码
 立即注册

QQ登录

只需一步,快速开始

微信登录

微信扫码,快速开始

  • QQ空间
  • 回复
  • 收藏

基于caffe resnet25三次下采样

lijingle 图像分类 2022-5-11 10:28 1713人围观

这里主要记录下基于caffe的resnet Python版本实现:主要是代码

# -*- coding: utf-8 -*-"""
Created on Thu Mar 31 13:45:54 2016
@author: doubility"""
from argparse import ArgumentParser, ArgumentDefaultsHelpFormatter
def parse_args():
    """Parse input arguments    """
    parser = ArgumentParser(description=__doc__,formatter_class=ArgumentDefaultsHelpFormatter)
    parser.add_argument('solver_file', help='Output solver.prototxt file')
    parser.add_argument('train_val_file',help='Output train_val.prototxt file')
    parser.add_argument('--layer_number', nargs='*', help=('Layer number for each layer stage.'), default=['5,5,5,0'])
    parser.add_argument('-t', '--type', type=int,help=('0 for deploy.prototxt, 1 for train_val.prototxt.'),default=1)        args = parser.parse_args()
    return args
def generate_data_layer(n):
    data_layer_str = '''name: "ResNet-%d"
layer {
  name: "data"
  type: "Data"
  top: "data"
  top: "label"
  include {
    phase: TRAIN
  }
  transform_param {
    mirror: true
    crop_size: 32
    mean_file: "examples/cifar10/mean.binaryproto"
  }
  data_param {
    source: "examples/cifar10/cifar10_train_lmdb"
    batch_size: 128
    backend: LMDB
  }
}
layer {
  name: "data"
  type: "Data"
  top: "data"
  top: "label"
  include {
    phase: TEST
  }
  transform_param {
    mirror: false
    crop_size: 32
    mean_file: "examples/cifar10/mean.binaryproto"
  }
  data_param {
    source: "examples/cifar10/cifar10_test_lmdb"
    batch_size: 128
    backend: LMDB
  }
}\n''' % (6 * n + 2)
    return data_layer_str
def generate_conv1_layer(kernel_size, kernel_num, stride, pad, layer_name, bottom, top, filler="msra"):
    conv_layer_str = '''layer {
  name: "%s"
  type: "Convolution"
  bottom: "%s"
  top: "%s"
  param {
    lr_mult: 1
    decay_mult: 1
  }
  param {
     lr_mult: 2
     decay_mult: 0
  }
  convolution_param {
    num_output: %d
    pad: %d
    kernel_size: %d
    stride: %d
    weight_filler {
      type: "%s"
      std: 0.010
    }
    bias_filler {
      type: "constant"
      value: 0
    }
  }
}\n'''%(layer_name, bottom, top, kernel_num, pad, kernel_size, stride, filler)
    return conv_layer_str
def generate_conv_layer(kernel_size, kernel_num, stride, pad, layer_name, bottom, top, filler="msra"):
  conv_layer_str = '''layer {
  name: "%s"
  type: "Convolution"
  bottom: "%s"
  top: "%s"
  param {
    lr_mult: 1
    decay_mult: 1
  }
  convolution_param {
    num_output: %d
    pad: %d
    kernel_size: %d
    stride: %d
    weight_filler {
      type: "%s"
      std: 0.010
    }
    bias_term: false
  }
}\n'''%(layer_name, bottom, top, kernel_num, pad, kernel_size, stride, filler)
    return conv_layer_str


def generate_pooling_layer(kernel_size, stride, pool_type, layer_name, bottom, top):
    pool_layer_str = '''layer {
  name: "%s"
  type: "Pooling"
  bottom: "%s"
  top: "%s"
  pooling_param {
    pool: %s
    kernel_size: %d
    stride: %d
  }
}\n'''%(layer_name, bottom, top, pool_type, kernel_size, stride)
    return pool_layer_str
def generate_global_pooling_layer(pool_type, layer_name, bottom, top):
    pool_layer_str = '''layer {
  name: "%s"
  type: "Pooling"
  bottom: "%s"
  top: "%s"
  pooling_param {
    pool: %s
    kernel_size: 8
    stride: 8
  }
}\n'''%(layer_name, bottom, top, pool_type)
    return pool_layer_str

def generate_fc_layer(num_output, layer_name, bottom, top, filler="msra"):
    fc_layer_str = '''layer {
  name: "%s"
  type: "InnerProduct"
  bottom: "%s"
  top: "%s"
  param {
    lr_mult: 1
    decay_mult: 1
  }
  param {
    lr_mult: 2
    decay_mult: 0
  }
  inner_product_param {
     num_output: %d
     weight_filler {
       type: "%s"
       std: 0.001
     }
     bias_filler {
       type: "constant"
       value: 0
     }
  }
}\n'''%(layer_name, bottom, top, num_output, filler)
    return fc_layer_str

def generate_eltwise_layer(layer_name, bottom_1, bottom_2, top, op_type="SUM"):
    eltwise_layer_str = '''layer {
  name: "%s"
  type: "Eltwise"
  bottom: "%s"
  bottom: "%s"
  top: "%s"
  eltwise_param {
    operation: %s
  }
}\n'''%(layer_name, bottom_1, bottom_2, top, op_type)
    return eltwise_layer_str

def generate_activation_layer(layer_name, bottom, top, act_type="ReLU"):
    act_layer_str = '''layer {
  name: "%s"
  type: "%s"
  bottom: "%s"
  top: "%s"
}\n'''%(layer_name, act_type, bottom, top)
    return act_layer_str

def generate_softmax_loss(bottom):
    softmax_loss_str = '''layer {
  name: "loss"
  type: "SoftmaxWithLoss"
  bottom: "%s"
  bottom: "label"
  top: "loss"
}\n

layer {
    bottom: "%s"
    bottom: "label"
    top: "accuracy"
    name: "accuracy"
    type: "Accuracy"
}\n'''%(bottom, bottom)
    return softmax_loss_str

def generate_bn_layer(layer_name, bottom, top):
    bn_layer_str = '''layer {
  name: "%s"
  type: "BatchNorm"
  bottom: "%s"
  top: "%s"
  param {
    lr_mult: 0
  }
  param {
    lr_mult: 0
  }
  param {
    lr_mult: 0
  }
  batch_norm_param {
      use_global_stats: false
  }
}\n'''%(layer_name, bottom, top)
    return bn_layer_str
def generate_scale_layer(layer_name, bottom, top):
    scale_layer_str = '''layer {
  name: "%s"  
  type: "Scale"
  bottom: "%s"
  top: "%s"
  scale_param {
	bias_term: true
  }
  param { 
        lr_mult: 1
  }
}\n ''' % (layer_name, bottom, top)
    return scale_layer_str

def generate_state_layer_names(stage, seq):    '''    layer_name: res
    stage: 1
    branch: 2
    seq: 1        examples: res_1_branch2_1
              scale_2_branch2_2

              res_stage_1_seq_1    '''
    layer_names = []        for i in range(2):
        sub_branches = []
        sub_branches.append('res_stage_' + str(stage)    + '_' + str(seq) + '_' + str(i + 1))
        sub_branches.append('bn_stage_' + str(stage)     + '_' + str(seq) + '_' + str(i + 1))
        sub_branches.append('scale_stage_' + str(stage)  + '_' + str(seq) + '_' + str(i + 1))
        sub_branches.append('res_stage_' + str(stage)    + '_' + str(seq) + '_' + str(i + 1) + '_relu')
                layer_names.append(sub_branches)        layer_names.append('res_%d_%d' % (stage, seq))            return layer_names
def generate_train_val():
    args = parse_args()
    stage_n = args.layer_number[0]
    stage_n = [int(n) for n in stage_n.split(',')]
    network_str = generate_data_layer(stage_n[0])

    '''before stage'''
    last_top = 'data'
    network_str += generate_conv1_layer(3, 16, 1, 1, 'conv1', last_top, 'conv1', 'msra')
    network_str += generate_bn_layer('bn_conv1', 'conv1', 'conv1')
    network_str += generate_scale_layer('scale_conv1', 'conv1', 'conv1')
    network_str += generate_activation_layer('conv1_relu', 'conv1', 'conv1', 'ReLU')
        '''stage 1'''    stage = 1
    last_top = 'conv1'            # branch1
    # def generate_conv_layer(kernel_size, kernel_num, stride, pad, layer_name, bottom, top, filler="msra"):
    network_str += generate_conv_layer(1, 16, 1, 0, 'res_1_branch1', last_top, 'res_1_branch1', 'msra')
    network_str += generate_bn_layer('bn_1_branch1', 'res_1_branch1', 'res_1_branch1')
    network_str += generate_scale_layer('scale_1_branch1', 'res_1_branch1', 'res_1_branch1')
    last_output = 'res_1_branch1'
    # branch2        for l in range(1, stage_n[0] + 1):
        branch2_layer_names = generate_state_layer_names(stage, l)
        print(branch2_layer_names)                        sub_branch1 = branch2_layer_names[0]
        network_str += generate_conv_layer(3, 16, 1, 1, sub_branch1[0], last_top, sub_branch1[0], 'msra')
        network_str += generate_bn_layer(sub_branch1[1], sub_branch1[0], sub_branch1[0])
        network_str += generate_scale_layer(sub_branch1[2], sub_branch1[0], sub_branch1[0])
        network_str += generate_activation_layer(sub_branch1[3], sub_branch1[0], sub_branch1[0], 'ReLU')
                sub_branch2 = branch2_layer_names[1]
        network_str += generate_conv_layer(3, 16, 1, 1, sub_branch2[0], sub_branch1[0], sub_branch2[0], 'msra')
        network_str += generate_bn_layer(sub_branch2[1], sub_branch2[0], sub_branch2[0])
        network_str += generate_scale_layer(sub_branch2[2], sub_branch2[0], sub_branch2[0])

        # merge(eltwise)
        elt_wise_layer_name = branch2_layer_names[2]
        network_str += generate_eltwise_layer(elt_wise_layer_name, last_output, sub_branch2[0], elt_wise_layer_name, 'SUM')
        network_str += generate_activation_layer(elt_wise_layer_name + '_relu', elt_wise_layer_name, elt_wise_layer_name, 'ReLU')
                last_top = elt_wise_layer_name
        last_output = elt_wise_layer_name

    '''stage 2'''
    stage = 2        # branch1
    network_str += generate_conv_layer(1, 32, 2, 0, 'res_2_branch1', last_top, 'res_2_branch1', 'msra')
    network_str += generate_bn_layer('bn_2_branch1', 'res_2_branch1', 'res_2_branch1')
    network_str += generate_scale_layer('scale_2_branch1', 'res_2_branch1', 'res_2_branch1')
    last_output = 'res_2_branch1'        # branch2
    for l in range(1, stage_n[1]+1):
        branch2_layer_names = generate_state_layer_names(stage, l)                         if l == 1:
            stride = 2
        else:
            stride = 1                    
        sub_branch1 = branch2_layer_names[0]
        network_str += generate_conv_layer(3, 32, stride, 1, sub_branch1[0], last_top, sub_branch1[0], 'msra')
        network_str += generate_bn_layer(sub_branch1[1], sub_branch1[0], sub_branch1[0])
        network_str += generate_scale_layer(sub_branch1[2], sub_branch1[0], sub_branch1[0])
        network_str += generate_activation_layer(sub_branch1[3], sub_branch1[0], sub_branch1[0], 'ReLU')
                sub_branch2 = branch2_layer_names[1]
        network_str += generate_conv_layer(3, 32, 1, 1, sub_branch2[0], sub_branch1[0], sub_branch2[0], 'msra')
        network_str += generate_bn_layer(sub_branch2[1], sub_branch2[0], sub_branch2[0])
        network_str += generate_scale_layer(sub_branch2[2], sub_branch2[0], sub_branch2[0])
                # merge(eltwise)
        elt_wise_layer_name = branch2_layer_names[2]
        network_str += generate_eltwise_layer(elt_wise_layer_name, last_output, sub_branch2[0], elt_wise_layer_name, 'SUM')
        network_str += generate_activation_layer(elt_wise_layer_name + '_relu', elt_wise_layer_name, elt_wise_layer_name , 'ReLU')


        last_top = elt_wise_layer_name
        last_output = elt_wise_layer_name           '''stage 3'''
    stage = 3    
    # branch1
    network_str += generate_conv_layer(1, 64, 2, 0, 'res_3_branch1', last_top, 'res_3_branch1', 'msra')
    network_str += generate_bn_layer('bn_3_branch1', 'res_3_branch1', 'res_3_branch1')
    network_str += generate_scale_layer('scale_3_branch1', 'res_3_branch1', 'res_3_branch1')
    last_output = 'res_3_branch1'    
    # branch2
    for l in range(1, stage_n[2]+1):
        branch2_layer_names = generate_state_layer_names(stage, l)
        if l == 1:
            stride = 2
        else:
            stride = 1        
        sub_branch1 = branch2_layer_names[0]
        network_str += generate_conv_layer(3, 64, stride, 1, sub_branch1[0], last_top, sub_branch1[0], 'msra')
        network_str += generate_bn_layer(sub_branch1[1], sub_branch1[0], sub_branch1[0])
        network_str += generate_scale_layer(sub_branch1[2], sub_branch1[0], sub_branch1[0])
        network_str += generate_activation_layer(sub_branch1[3], sub_branch1[0], sub_branch1[0], 'ReLU')

                sub_branch2 = branch2_layer_names[1]
        network_str += generate_conv_layer(3, 64, 1, 1, sub_branch2[0], sub_branch1[0], sub_branch2[0], 'msra')
        network_str += generate_bn_layer(sub_branch2[1], sub_branch2[0], sub_branch2[0])
        network_str += generate_scale_layer(sub_branch2[2], sub_branch2[0], sub_branch2[0])
                # merge(eltwise)
        elt_wise_layer_name = branch2_layer_names[2]
        network_str += generate_eltwise_layer(elt_wise_layer_name, last_output, sub_branch2[0], elt_wise_layer_name, 'SUM')
        network_str += generate_activation_layer(elt_wise_layer_name + '_relu', elt_wise_layer_name, elt_wise_layer_name, 'ReLU')

        last_top = elt_wise_layer_name
        last_output = elt_wise_layer_name 

    stage = 4
    # branch1
    network_str += generate_conv_layer(1, 64, 2, 0, 'res_4_branch1', last_top, 'res_4_branch1', 'msra')
    network_str += generate_bn_layer('bn_4_branch1', 'res_4_branch1', 'res_4_branch1')
    network_str += generate_scale_layer('scale_4_branch1', 'res_4_branch1', 'res_4_branch1')
    last_output = 'res_4_branch1'    
    # branch2
    for l in range(1, stage_n[1]+1):
        branch2_layer_names = generate_state_layer_names(stage, l)                         if l == 1:
            stride = 2
        else:
            stride = 1                            sub_branch1 = branch2_layer_names[0]
        network_str += generate_conv_layer(3, 64, stride, 1, sub_branch1[0], last_top, sub_branch1[0], 'msra')
        network_str += generate_bn_layer(sub_branch1[1], sub_branch1[0], sub_branch1[0])
        network_str += generate_scale_layer(sub_branch1[2], sub_branch1[0], sub_branch1[0])
        network_str += generate_activation_layer(sub_branch1[3], sub_branch1[0], sub_branch1[0], 'ReLU')
                sub_branch2 = branch2_layer_names[1]
        network_str += generate_conv_layer(3, 64, 1, 1, sub_branch2[0], sub_branch1[0], sub_branch2[0], 'msra')
        network_str += generate_bn_layer(sub_branch2[1], sub_branch2[0], sub_branch2[0])
        network_str += generate_scale_layer(sub_branch2[2], sub_branch2[0], sub_branch2[0])
                # merge(eltwise)
        elt_wise_layer_name = branch2_layer_names[2]
        network_str += generate_eltwise_layer(elt_wise_layer_name, last_output, sub_branch2[0], elt_wise_layer_name, 'SUM')
        network_str += generate_activation_layer(elt_wise_layer_name + '_ReLU', elt_wise_layer_name, elt_wise_layer_name , 'ReLU')

        last_top = elt_wise_layer_name
        last_output = elt_wise_layer_name                 network_str += generate_global_pooling_layer('AVE', 'pool5', last_top, 'pool5')
    network_str += generate_fc_layer(2, 'fc10', 'pool5', 'fc10', 'msra')
    network_str += generate_softmax_loss('fc10')
    return network_str

def generate_solver(train_val_name):
    solver_str = '''net: "examples/res_net_32/%s"
test_iter: 100
test_interval: 500
test_initialization: false
display: 100
base_lr: 0.1
gamma: 0.1
lr_policy: "multistep"
stepvalue: 32000
stepvalue: 48000
max_iter: 64000
momentum: 0.9
weight_decay: 0.0001
snapshot: 10000
snapshot_prefix: "examples/res_net_32/res_net"
solver_mode: GPU'''%(train_val_name)
    return solver_str

def main():
    args = parse_args()
    solver_str = generate_solver(args.train_val_file)
    network_str = generate_train_val()
    fp = open(args.solver_file, 'w')
    fp.write(solver_str)
    fp.close()
    fp = open(args.train_val_file, 'w')
    fp.write(network_str)
    fp.close()
if __name__ == '__main__':
    main()

路过

雷人

握手

鲜花

鸡蛋
我有话说......

TA还没有介绍自己。

电话咨询: 135xxxxxxx
关注微信