TensoFlow解决过拟合问题:正则化、滑动平均模型、衰减率

对多层神经网络过拟合的总结

  1. 激活函数解决非线性问题

      神经网络解决非线性问题的方法是使用激活函数,TensorFlow中常用的激活函数有:tf.nn.relutf.sigmoidtf.tanh
      使用激活函数的前向传播算法:a = tf.nn.relu(tf.matmul(x, w1) + biases1
      

  2. 反向传播算法

       反向传播算法是训练神经网络的核心算法。它可以根据定义好的损失函数优化神经网络中参数的取值。

       (1)、学习率。TensorFlow提供了指数衰减法,tf.train.exponential_decay()函数实现指数衰减学习率。可以随着迭代的步骤,逐步减小学习率。
       (2)、正则化。为了避免过拟合问题,一个常用的方法是正则化。正则化的思想是在损失函数中加入正则项刻画模型。loss = tf.reduce_mean(tf.square(y_ - y)) + tf.contrib.layers.l2_regularizer(lambda)(w)。
       (3)、滑动平均模型。滑动平均模型是另外一个可以使模型在测试数据上更健壮的方法。TensorFlow中提供了tf.train.ExponentialMovingAverage来实现滑动平均模型。在初始化ExponentialMovingAverage时,需要提供一个衰减率(decay)。ExponentialMovingAverage会对每一个变量会维护一个影子

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值