深入解析TensorFlow中滑动平均模型与代码实现

滑动平均模型与代码实现

import tensorflow as tf
import numpy as np

# 定义变量及滑动平均类

# 定义一个32位浮点变量,初始值为0.0  这个代码就是不断更新w1参数,优化w1参数,滑动平均做了>个weight 的影子

Global_step = tf.Variable(0, trainable=False)
w1 = tf.Variable(0, dtype=tf.float32)
MOVING_AVERAGE_DECAY = 0.99  # 滑动衰减率
# 定义了一个滑动平均衰减类, 初始化给了滑动平均衰减率0.99和  控制衰减的变量0
ema = tf.train.ExponentialMovingAverage(MOVING_AVERAGE_DECAY, Global_step)

# 3、用tf.trainable_variable()获取所有可以训练的变量列表,也就是所有的w和b
# 全部指定为使用滑动平均模型
ema_op = ema.apply(tf.trainable_variables())

init = tf.global_variables_initializer()
with tf.Session() as sess:
    sess.run(init)
    # 通过 ema.average(w1) 获取滑动平均后的w1 的值
    sess.run(ema_op)
    # 求滑动平均值  衰减率=min{0.99, (1 + global_step) / (10 + global_step)} = 0.1
    # (1 + global_step) / (10 + global_step) 是 偏差修正
    # w1 = 衰减率 * 滑动平均值 + (1 - 衰减率) * 当前参数值
    # w1 = 0.1 * 0 + (1 - 0.1) * 0=0
    print('w1: ', sess.run(w1), 'huadong:', sess.run(ema.average(w1)))

    # 将 w1 赋值 3
    sess.run(tf.assign(w1, 3))
    sess.run(ema_op)
    # 求滑动平均值  衰减率=min{0.99, (1 + Global_step) / (10 + Global_step} = 0.1
    # (1 + global_step) / (10 + global_step) 是 偏差修正
    # w1 = 衰减率 * 滑动平均值 + (1 - 衰减率) * 当前参数值
    # w1 = 0.1 * 0 + (1 - 0.1) * 3 = 2.7
    print('w1: ', sess.run(w1), 'huadong:', sess.run(ema.average(w1)))

    # 将 Global_step 赋值 1000
    sess.run(tf.assign(Global_step, 1000))
    sess.run(ema_op)
    # 求滑动平均值  衰减率=min{0.99, (1 + Global_step) / (10 + Global_step} = 0.99
    # (1 + global_step) / (10 + global_step) 是 偏差修正
    # w1 = 衰减率 * 滑动平均值 + (1 - 衰减率) * 当前参数值
    # w1 = 0.99 * 2.7 + (1 - 0.99) * 3 = 2.703
    print('w1: ', sess.run(w1), 'huadong:', sess.run(ema.average(w1)))

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值