Created
November 5, 2017 10:10
-
-
Save gaving/fc70eab810aa1812219e7038dd7bedc1 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: "VGG_FACE_16_layer" | |
layer { | |
name: "vgg_face" | |
type: "MemoryData" | |
top: "data" | |
top: "label" | |
memory_data_param { | |
batch_size: 10 | |
channels: 3 | |
height: 224 | |
width: 224 | |
} | |
} | |
layer { | |
bottom: "data" | |
top: "conv1_1" | |
name: "conv1_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 64 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv1_1" | |
top: "conv1_1" | |
name: "relu1_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv1_1" | |
top: "conv1_2" | |
name: "conv1_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 64 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv1_2" | |
top: "conv1_2" | |
name: "relu1_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv1_2" | |
top: "pool1" | |
name: "pool1" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool1" | |
top: "conv2_1" | |
name: "conv2_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 128 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv2_1" | |
top: "conv2_1" | |
name: "relu2_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv2_1" | |
top: "conv2_2" | |
name: "conv2_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 128 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv2_2" | |
top: "conv2_2" | |
name: "relu2_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv2_2" | |
top: "pool2" | |
name: "pool2" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool2" | |
top: "conv3_1" | |
name: "conv3_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 256 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv3_1" | |
top: "conv3_1" | |
name: "relu3_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv3_1" | |
top: "conv3_2" | |
name: "conv3_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 256 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv3_2" | |
top: "conv3_2" | |
name: "relu3_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv3_2" | |
top: "conv3_3" | |
name: "conv3_3" | |
type: "Convolution" | |
convolution_param { | |
num_output: 256 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv3_3" | |
top: "conv3_3" | |
name: "relu3_3" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv3_3" | |
top: "pool3" | |
name: "pool3" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool3" | |
top: "conv4_1" | |
name: "conv4_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv4_1" | |
top: "conv4_1" | |
name: "relu4_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv4_1" | |
top: "conv4_2" | |
name: "conv4_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv4_2" | |
top: "conv4_2" | |
name: "relu4_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv4_2" | |
top: "conv4_3" | |
name: "conv4_3" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv4_3" | |
top: "conv4_3" | |
name: "relu4_3" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv4_3" | |
top: "pool4" | |
name: "pool4" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool4" | |
top: "conv5_1" | |
name: "conv5_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv5_1" | |
top: "conv5_1" | |
name: "relu5_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv5_1" | |
top: "conv5_2" | |
name: "conv5_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv5_2" | |
top: "conv5_2" | |
name: "relu5_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv5_2" | |
top: "conv5_3" | |
name: "conv5_3" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv5_3" | |
top: "conv5_3" | |
name: "relu5_3" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv5_3" | |
top: "pool5" | |
name: "pool5" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool5" | |
top: "fc6" | |
name: "fc6" | |
type: "InnerProduct" | |
inner_product_param { | |
num_output: 4096 | |
} | |
} | |
layer { | |
bottom: "fc6" | |
top: "fc6" | |
name: "relu6" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "fc6" | |
top: "fc6" | |
name: "drop6" | |
type: "Dropout" | |
dropout_param { | |
dropout_ratio: 0.5 | |
} | |
} | |
layer { | |
bottom: "fc6" | |
top: "fc7" | |
name: "fc7" | |
type: "InnerProduct" | |
inner_product_param { | |
num_output: 4096 | |
} | |
} | |
layer { | |
bottom: "fc7" | |
top: "fc7" | |
name: "relu7" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "fc7" | |
top: "fc7" | |
name: "drop7" | |
type: "Dropout" | |
dropout_param { | |
dropout_ratio: 0.5 | |
} | |
} | |
layer { | |
bottom: "fc7" | |
top: "fc8" | |
name: "fc8" | |
type: "InnerProduct" | |
inner_product_param { | |
num_output: 2622 | |
} | |
} | |
layer { | |
bottom: "fc8" | |
top: "prob" | |
name: "prob" | |
type: "Softmax" | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
mbp:~/Sandbox/dd/vgg_face% lsa ツ 10:08 | |
total 554M | |
-rw-r--r-- 1 gavin 554M Nov 5 09:24 VGG_FACE.caffemodel | |
-rw-r--r-- 1 gavin 5.3K Nov 5 09:54 VGG_FACE.prototxt | |
-rw-r--r-- 1 gavin 294 Nov 5 09:55 VGG_FACE_solver.prototxt | |
-rw-r--r-- 1 gavin 4.8K Nov 5 09:25 deploy.prototxt | |
drwxr-xr-x 5 gavin 160 Nov 5 09:14 train/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: "VGG_ILSVRC_16_layers" | |
layer { | |
name: "data" | |
type: "Data" | |
top: "data" | |
top: "label" | |
include { | |
phase: TRAIN | |
} | |
transform_param { | |
mirror: true | |
crop_size: 224 | |
mean_file: "mean.binaryproto" | |
} | |
data_param { | |
source: "train.lmdb" | |
batch_size: 32 | |
backend: LMDB | |
} | |
} | |
layer { | |
name: "vgg16" | |
type: "MemoryData" | |
top: "data" | |
top: "label" | |
memory_data_param { | |
batch_size: 32 | |
channels: 3 | |
height: 224 | |
width: 224 | |
} | |
include { | |
phase: TEST | |
} | |
} | |
layer { | |
bottom: "data" | |
top: "conv1_1" | |
name: "conv1_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 64 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv1_1" | |
top: "conv1_1" | |
name: "relu1_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv1_1" | |
top: "conv1_2" | |
name: "conv1_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 64 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv1_2" | |
top: "conv1_2" | |
name: "relu1_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv1_2" | |
top: "pool1" | |
name: "pool1" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool1" | |
top: "conv2_1" | |
name: "conv2_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 128 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv2_1" | |
top: "conv2_1" | |
name: "relu2_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv2_1" | |
top: "conv2_2" | |
name: "conv2_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 128 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv2_2" | |
top: "conv2_2" | |
name: "relu2_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv2_2" | |
top: "pool2" | |
name: "pool2" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool2" | |
top: "conv3_1" | |
name: "conv3_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 256 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv3_1" | |
top: "conv3_1" | |
name: "relu3_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv3_1" | |
top: "conv3_2" | |
name: "conv3_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 256 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv3_2" | |
top: "conv3_2" | |
name: "relu3_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv3_2" | |
top: "conv3_3" | |
name: "conv3_3" | |
type: "Convolution" | |
convolution_param { | |
num_output: 256 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv3_3" | |
top: "conv3_3" | |
name: "relu3_3" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv3_3" | |
top: "pool3" | |
name: "pool3" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool3" | |
top: "conv4_1" | |
name: "conv4_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv4_1" | |
top: "conv4_1" | |
name: "relu4_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv4_1" | |
top: "conv4_2" | |
name: "conv4_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv4_2" | |
top: "conv4_2" | |
name: "relu4_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv4_2" | |
top: "conv4_3" | |
name: "conv4_3" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv4_3" | |
top: "conv4_3" | |
name: "relu4_3" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv4_3" | |
top: "pool4" | |
name: "pool4" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool4" | |
top: "conv5_1" | |
name: "conv5_1" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv5_1" | |
top: "conv5_1" | |
name: "relu5_1" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv5_1" | |
top: "conv5_2" | |
name: "conv5_2" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv5_2" | |
top: "conv5_2" | |
name: "relu5_2" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv5_2" | |
top: "conv5_3" | |
name: "conv5_3" | |
type: "Convolution" | |
convolution_param { | |
num_output: 512 | |
pad: 1 | |
kernel_size: 3 | |
} | |
} | |
layer { | |
bottom: "conv5_3" | |
top: "conv5_3" | |
name: "relu5_3" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "conv5_3" | |
top: "pool5" | |
name: "pool5" | |
type: "Pooling" | |
pooling_param { | |
pool: MAX | |
kernel_size: 2 | |
stride: 2 | |
} | |
} | |
layer { | |
bottom: "pool5" | |
top: "fc6" | |
name: "fc6" | |
type: "InnerProduct" | |
inner_product_param { | |
num_output: 4096 | |
} | |
} | |
layer { | |
bottom: "fc6" | |
top: "fc6" | |
name: "relu6" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "fc6" | |
top: "fc6" | |
name: "drop6" | |
type: "Dropout" | |
dropout_param { | |
dropout_ratio: 0.5 | |
} | |
} | |
layer { | |
bottom: "fc6" | |
top: "fc7" | |
name: "fc7" | |
type: "InnerProduct" | |
inner_product_param { | |
num_output: 4096 | |
} | |
} | |
layer { | |
bottom: "fc7" | |
top: "fc7" | |
name: "relu7" | |
type: "ReLU" | |
} | |
layer { | |
bottom: "fc7" | |
top: "fc7" | |
name: "drop7" | |
type: "Dropout" | |
dropout_param { | |
dropout_ratio: 0.5 | |
} | |
} | |
layer { | |
bottom: "fc7" | |
top: "fc8" | |
name: "fc8" | |
type: "InnerProduct" | |
inner_product_param { | |
num_output: 1000 | |
} | |
} | |
layer { | |
bottom: "fc8" | |
bottom: "label" | |
top: "prob" | |
name: "prob" | |
type: "SoftmaxWithLoss" | |
include { | |
phase: TRAIN | |
} | |
} | |
layer { | |
bottom: "fc8" | |
top: "probt" | |
name: "probt" | |
type: "Softmax" | |
include { | |
phase: TEST | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
net: "/opt/models/vgg_face/VGG_FACE.prototxt" | |
test_iter: 1000 | |
test_interval: 2500 | |
base_lr: 0.001 | |
lr_policy: "step" | |
gamma: 0.1 | |
stepsize: 50000 | |
display: 20 | |
max_iter: 200000 | |
momentum: 0.9 | |
weight_decay: 0.0005 | |
snapshot: 10000 | |
snapshot_prefix: "/opt/models/vgg_face/train_vgg_face" | |
solver_mode: CPU |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment