2018-04-05CNN
2018-04-05 本文已影响0人
DIO哒
我认为这篇博客讲的很详细也很直观。
https://www.cnblogs.com/flippedkiki/p/7765667.html
def compute_accuracy(v_xs,v_ys):
global prediction
y_pre=sess.run(prediction,feed_dict={xs:v_xs,keep_prob:1})
correct_prediction = tf.equal(tf.arg_max(y_pre,1),tf.arg_max(v_ys,1))
accuracy=tf.reduce_mean(tf.cast(correct_prediction,tf.float32))
result=sess.run(accuracy,feed_dict={xs:v_xs,ys:v_ys,keep_prob:1})
return result
def weight_variable(shape):
initial=tf.truncated_normal(shape,stddev=0.1)
return tf.Variable(initial)
def bias_variable(shape):
initial=tf.constant(0.1,shape=shape)
return tf.Variable(initial)
def conv2d(x,W):
#stride[1,x_movement,y_movement,1]
#[0] and [3] must be 1
return tf.nn.conv2d(x,W,strides=[1,1,1,1],padding='SAME')
def max_pool_2x2(x):
xs=tf.placeholder(tf.float32,[None,784])#28 x 28
ys = tf.placeholder(tf.float32,[None,10])#predict 10 numbers
keep_prob = tf.placeholder(tf.float32)
第一篇教程主要是写了这几个函数
第一个compute accuracy之前在classification里也有用到,但貌似只是用在检测里,并没有和训练过程有太多瓜葛。
第二个和第三个看上去只是把add layer里初始化权重和bias的内容单独写成了一个函数,并且权重初始化由正态分布改成了部分的正态分布的值。
第三个conv2d应该就是计算卷积的函数了,也只是把tf.nn.conv2d简化了一下,第四个池化层也是同样,可能这样写起来会方便一点。池化层主要的作用是增加不变性,防止过拟合。
xs=tf.placeholder(tf.float32,[None,784])#28 x 28
ys = tf.placeholder(tf.float32,[None,10])#predict 10 numbers
keep_prob = tf.placeholder(tf.float32)
x_image = tf.reshape(xs,[-1,28,28,1])
#conv layer1
W_conv1 = weight_variable([5,5,1,32])#patch 5x5 in_size1 out_size32
b_conv1 = bias_variable([32])
h_conv1 = tf.nn.relu(conv2d(x_image,W_conv1)+b_conv1)#output size = 28x28x32
h_pool1 = max_pool_2x2(h_conv1) #output size = 14x14x32
#conv_layer2
W_conv2 = weight_variable([5,5,32,64])#patch 5x5 in_size32 out_size64
b_conv2 = bias_variable([64])
h_conv2 = tf.nn.relu(conv2d(h_pool1,W_conv2)+b_conv2)#output size = 14x14x64
h_pool2 = max_pool_2x2(h_conv2) #output size = 7x7x64
#fc1 layer
W_fc1 = weight_variable([7*7*64,1024])
b_fc1 = bias_variable([1024])
h_pool2_flat = tf.reshape(h_pool2,[-1,7*7*64])
h_fc1 = tf.nn.relu(tf.matmul(h_pool2_flat,W_fc1)+b_fc1)
h_fc1_drop=tf.nn.dropout(h_fc1,keep_prob)
#fc2 layer
W_fc2 = weight_variable([1024,10])
b_fc2 = bias_variable([10])
prediction = tf.nn.softmax(tf.matmul(h_fc1_drop,W_fc2)+b_fc2)
搭建神经网络的过程是这样的
一共两层卷积神经网络
两层普通神经网络
唯一的区别在于预测函数不同,一个使用conv2d,一个单纯地矩阵相乘,当然都是要用激活函数的。