Tensorflow小小小白学习随想(一) 手动更新学习率的几种写法

Tensorflow小小小白学习随想(一)
手动更新学习率的几种写法@TOC

在会话中也可以创建op

#今天看别人的代码时看到更新学习率是这样写的:
	for epoch in range(51):
		sess.run(tf.assign(lr,0.01*(0.95**epoch))
#刚开始看到有点不太明白这个是什么操作,最后我把它理解为在会话中也可以创建op.(要注意tf.assign的返回值是一个op,不run它的话没有办法真正赋值).
#具体的对于这一句的理解是:在会话中先创建了一个赋值的op,再run这个op,完成真正的赋值

第一种等价写法

等价于在计算图中设置epo占位符:

epo=tf.placeholder(tf.float32)

创建赋值op:

lr_new=tf.assign(lr,0.001*(0.95**epo))

然后在会话中的epoch循环中:

sess.run(lr_new,feed_dict={epo:epoch})

第二种等价写法

还等价于在计算图中只需创建赋值op

lr_new=tf.assign(lr,lr*0,95)

然后在会话中的epoch循环中:

sess.run(lr_new)

注意

当然了这几种方法都不要忘记的是lr在计算图中设置为Variable类型

lr=tf.Variable(0.001,tf.float32)

这三种方法具体形式是次要,但是研究明白这几种方法会对op,variable,run这些概念有更好的理解~

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值