zoukankan      html  css  js  c++  java
  • 神经网络总结(tensorflow)

    import tensorflow as tf      
    from tensorflow.examples.tutorials.mnist import input_data #导入mnist数据集
    minst=input_data.read_data_sets('MNIST_data',one_hot=True)

    def add_layer(inputs,in_size,out_size,activation_function=None):#添加一层隐藏层
    #with tf.name_scope('layer'):
    # with tf.name_scope('Weights'):
    Weights=tf.Variable(tf.random_normal([in_size,out_size]))#定义变量weights
    #with tf.name_scope('biase'):
    biases=tf.Variable(tf.zeros([1,out_size])+0.1,name='b')#定义变量biases
    Wx_plus_b=tf.matmul(inputs,Weights)+biases#运算WX+b
    if activation_function is None:
    outputs=Wx_plus_b
    else:
    outputs=activation_function(Wx_plus_b)
    return outputs
    xs=tf.placeholder(tf.float32,[None,784])#placeholder在后面输入
    ys=tf.placeholder(tf.float32,[None,10])

    prediction=add_layer(xs,784,10,activation_function=tf.nn.softmax)#调用函数,激励函数是softmax

    cross_entropy=tf.reduce_mean(-tf.reduce_sum(ys*tf.log(prediction),reduction_indices=[1]))#交叉熵运算,相当于loss 下面还会有介绍
    train_step=tf.train.GradientDescentOptimizer(0.5).minimize(cross_entropy)#定义优化器来优化loss


    sess=tf.Session()#实例化Session
    sess.run(tf.initialize_all_variables())#只有进行这一步所有的变量才会起作用

    def compute_accuracy(v_xs,v_ys):#计算准确率的函数
    global prediction
    y_pre=sess.run(prediction,feed_dict={xs:v_xs})#对应上边的palceholder
    correct_prediction=tf.equal(tf.argmax(y_pre,1),tf.argmax(v_ys,1))#比较你预测的y和真实y那个1所在的位置。是一个布尔型量
    print(sess.run(correct_prediction))
    float=tf.cast(correct_prediction,tf.float32)#转化为float32类型
    print(sess.run(float))
    accuracy=tf.reduce_mean(tf.cast(correct_prediction,tf.float32))#转化为float32格式然后求其正确率 tf.cast转换格式
    result=sess.run(accuracy,feed_dict={xs:v_xs,ys:v_ys})
    return result



    for i in range(1000):
    batch_xs,batch_ys=minst.train.next_batch(100)
    sess.run(train_step,feed_dict={xs:batch_xs,ys:batch_ys})
    if i %100==0:
    print(compute_accuracy(
    minst.test.images,minst.test.labels
    ))


    tensorflow定义一个变量的函数Varible
    tf.Variable.init(initial_value, trainable=True, collections=None, validate_shape=True, name=None)

     Weights=tf.Variable(tf.random_normal([in_size,out_size]))   tf.random_normal正态分布
    e.g. weights=tf.Varible(tf.random_normal([2,3],stddev=2,mean=0,seed=1)) 服从正态分布的 2×3的矩阵 标准差为2 均值为0 ,随机种子为1
    tf.zeros全0数组 tf.ones全1数组 tf.constant 直接给值 tf.truncated_normal()去掉过大偏离点的正态分布
    tf.random_uniform()平均分布

    tf.placeholder(dtype, shape=None, name=None)

    此函数可以理解为形参,用于定义过程,在执行的时候再赋具体的值

     激活函数:

    交叉熵:

    学习率

     

    滑动平均







  • 相关阅读:
    两个问题解答、opencv、tensorflow、numpy、matplotlib的基本使用
    图像处理之几何变换
    anaconda一站式环境的搭建(anaconda、tensorflow、opencv)
    python基础--自定义模块、import、from......import......
    python基础--闭包、装饰器
    python基础--迭代器、生成器
    python基础--函数全解析(2)
    CSS弹性布局
    CSS定位布局
    仿写博客园主页
  • 原文地址:https://www.cnblogs.com/libin123/p/10022614.html
Copyright © 2011-2022 走看看