码迷,mamicode.com
首页 > 其他好文 > 详细

损失函数

时间:2018-06-04 20:12:45      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:SQ   oat   http   loss   for   numpy   输入   lob   variables   

来源:中国大学MOOC

 

损失函数有三种:均方误差、自定义、交叉熵

 

均方误差:

#coding:utf-8
#预测多或预测少的影响一样
#0导入模块,生成数据集
import tensorflow as tf
import numpy as np
BATCH_SIZE = 8
SEED = 23455

rdm = np.random.RandomState(SEED)
X = rdm.rand(32,2)
Y_= [[x1+x2+(rdm.rand()/10.0-0.05)] for (x1,x2) in X]

#1定义神经网络的输入、参数和输出,定义前向传播过程
x = tf.placeholder(tf.float32, shape=(None, 2))
y_= tf.placeholder(tf.float32, shape=(None, 1))
w1 = tf.Variable(tf.random_normal([2,1], stddev=1, seed=1))
y = tf.matmul(x,w1)

#2定义损失函数及反向传播方法
#定义损失函数为MSE,反向传播方法为梯度下降
loss_mse = tf.reduce_mean(tf.square(y-y_))
train_step = tf.train.GradientDescentOptimizer(0.001).minimize(loss_mse)

#3生成会话,训练STEPS轮
with tf.Session() as sess:
    init_op = tf.global_variables_initializer()
    sess.run(init_op)
    STEPS = 20000
    for i in range(STEPS):
        start = (i*BATCH_SIZE) % 32
        end = (i*BATCH_SIZE) % 32 + BATCH_SIZE
        sess.run(train_step, feed_dict={x:X[start:end], y_:Y_[start:end]})
        if i % 500 == 0:
            print "After %d training steps, w1 is:" % (i)
            print sess.run(w1)
    print "Final w1 is: \n",sess.run(w1)

 

技术分享图片

 

损失函数

标签:SQ   oat   http   loss   for   numpy   输入   lob   variables   

原文地址:https://www.cnblogs.com/144823836yj/p/9135121.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!