tensorflow 的 Batch Normalization 实现 tf nn moments tf nn batc

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.youkuaiyun.com/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

                       

tensorflow 在实现 Batch Normalization(各个网络层输出的归一化)时,主要用到以下两个 api:

  • tf.nn.moments(x, axes, name=None, keep_dims=False) ⇒ mean, variance:
    • 统计矩,mean 是一阶矩,variance 则是二阶中心矩
  • tf.nn.batch_normalization(x, mean, variance, offset, scale, variance_epsilon, name=None)
    • https://www.tensorflow.org/api_docs/python/tf/nn/batch_normalization
      γ ⋅ x − μ σ + β γ⋅x−μσ+β γxμσ+ββ 表示偏移量;
    • tf.nn.batch_norm_with_global_normalization(t, m, v, beta, gamma, variance_epsilon, scale_after_normalization, name=None)
    • 由函数接口可知,tf.nn.moments 计算返回的 mean 和 variance 作为 tf.nn.batch_normalization 参数进一步调用;

1. tf.nn.moments,矩

tf.nn.moments 返回的 mean 表示一阶矩,variance 则是二阶中心矩;

如我们需计算的 tensor 的 shape 为一个四元组 [batch_size, height, width, kernels],一个示例程序如下:

import tensorflow as tfshape = [128, 32, 32, 64]a = tf.Variable(tf.random_normal(shape))  # a:activationsaxis = list(range(len(shape)-1))    # len(x.get_shape())a_mean, a_var = tf.nn.moments(a, axis)
  
  • 1
  • 2
  • 3
  • 4
  • 5

这里我们仅给出 a_mean, a_var 的维度信息,

sess = tf.Session()sess.run(tf.global_variables_initalizer())sess.run(a_mean).shape  # (64, ) sess.run(a_var).shape  # (64, ) ⇒ 也即是以 kernels 为单位,batch 中的全部样本的均值与方差
  
  • 1
  • 2
  • 3
  • 4
  • 5

2. demo

def batch_norm(x): epsilon = 1e-3 batch_mean, batch_var = tf.nn.moments(x, [0]) return tf.nn.batch_normalization(x, batch_mean, batch_var,      offset=None, scale=None,     variance_epsilon=epsilon)
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

references

  • <a href=“http://www.jianshu.com/p/0312e04e4e83”, target="_blank">谈谈Tensorflow的Batch Normalization
           

给我老师的人工智能教程打call!http://blog.youkuaiyun.com/jiangjunshow
这里写图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值