深度学习(五)--常量与变量

简介: 深度学习(五)--常量与变量

概念:


  • 在运行过程中值不会改变的单元,在Tensorflow中不需要进行初始化操作


定义常量:


constant_name = tf.constant(value)

常量的运算代码示例:


import tensorflow as tf
# 一个简单的计算图
node1 = tf.constant(3.0, tf.float32, name="node1")
node2 = tf.constant(4.0, tf.float32, name="node1")
node3 = tf.add(node1, node2)
# 可以通过创建会话session来执行数据操作
sess = tf.Session()
print("node3的值:",sess.run(node3)


在这里进行的就是两个常量(node1, node2)的加法运算。

常量很简单,接下来看看变量!


2变量
  • 在运行中,值会改变的单元,在tensorflow中需要初始化操作


定义变量:

# 注意下面的Varible是大写开头
name_ariable = tf.Variable(value, name)

个别变量的初始化:

init_op = name_variable.initializer()

所有变量的初始化:

init_op = tf.global_variables_initializer()

变量的运算代码:

import tensorflow as tf
node1 = tf.Variable(3.0, tf.float32, name='node1')
node2 = tf.Variable(4.0, tf.float32, name='node2')
result = tf.add(node1, node2, name='result')
sess = tf.Session()
init = tf.global_variables_initializer()
sess.run(init)
print(sess.run(result))
sess.close()


在这里的 init 是初始化所有的变量,它自己本身也是一个节点,所以我们也要通过session的run()方法对它进行初始化,如果我们注释掉sess.run(init),程序会报错!


3变量的赋值


  • 与传统的编程语言不同,tensorflow中的变量定义之后,一般无需对变量进行人工赋值,系统会根据算法模型,训练优化过程中自动调整变量对应的数值


epoch = tf.Variable(0, name='epoch',trainable=False)


上面的代码把trainable参数设置为False,即取消了系统的自动赋值而是变为


人工赋值


• 特殊情况需要人工更新的,可用变量赋值语句


变量更新语句:


update_op = tf.assign(variable_to_be_updated, new_value)

说了这么多,我们来写个小案例:


import tensorflow as tf
node1 = tf.constant(1)
node2 = tf.Variable(0, name='node2')
# 实现加法操作
value = tf.add(node1, node2, name='value')
update_value = tf.assign(node2, value)
init = tf.global_variables_initializer()
with tf.Session() as sess:
   sess.run(init)
   for _ in range(10):
       sess.run(update_value)
       print(sess.run(node2))


分析一下这个小案例:首先我们定义了一个常量node1,然后我们定义一个变量node2, 然后我们将两者进行加法运算得到value,然后我们调用了tensorflow中的assign(),也就是变量更新的方法,我们将经过加法得到的结果赋给之前的变量node2,也就是实现了+1的操作。下一句就是初始化所有的变量,然后通过上下文的方法创建session,然后我们来初始化init,并且一个for循环,可以看出我们循环了10次,在这10次循环里,我们每次去运行了update_value,当我们去运行它时,就会牵涉到value,node2这些节点从而去运行这些节点,最后我们每次打印出变量node2的值。


运行输出后的结果:

1
2
3
4
5
6
7
8
9
10


4关于变量的一个小练习




最后给大家一个小练习:


如何通过tensorflow的变量赋值计算:1+2+3…+10?


关注“JAVAandPython君”公众号,在公众号回复 “练习1”,即可获取答案

相关文章
|
6月前
|
机器学习/深度学习 决策智能
**批量归一化(BN)**是2015年提出的深度学习优化技术,旨在解决**内部协变量偏移**和**梯度问题**。
【6月更文挑战第28天】**批量归一化(BN)**是2015年提出的深度学习优化技术,旨在解决**内部协变量偏移**和**梯度问题**。BN通过在每个小批量上执行**标准化**,然后应用学习到的γ和β参数,确保层间输入稳定性,加速训练,减少对超参数的敏感性,并作为隐含的正则化手段对抗过拟合。这提升了模型训练速度和性能,简化了初始化。
59 0
|
7月前
|
机器学习/深度学习 数据可视化 算法框架/工具
R语言深度学习KERAS循环神经网络(RNN)模型预测多输出变量时间序列
R语言深度学习KERAS循环神经网络(RNN)模型预测多输出变量时间序列
174 10
|
机器学习/深度学习 算法 数据可视化
【深度学习02】 多变量线性回归
为了节约训练的时间和数据,我们可以随机抽取 b 个样本
105 0
|
机器学习/深度学习
【深度学习】(问题记录)<对一个变量求梯度得到什么>-线性回归-小批量随机梯度下降
【深度学习】(问题记录)<对一个变量求梯度得到什么>-线性回归-小批量随机梯度下降
177 0
【深度学习】(问题记录)<对一个变量求梯度得到什么>-线性回归-小批量随机梯度下降
|
机器学习/深度学习 存储 数据可视化
深度学习:Tensorflow变量op和可视化TensorBoard
深度学习:Tensorflow变量op和可视化TensorBoard
253 0
|
9天前
|
机器学习/深度学习 传感器 数据采集
深度学习在故障检测中的应用:从理论到实践
深度学习在故障检测中的应用:从理论到实践
48 5
|
1天前
|
机器学习/深度学习 网络架构 计算机视觉
深度学习在图像识别中的应用与挑战
【10月更文挑战第21天】 本文探讨了深度学习技术在图像识别领域的应用,并分析了当前面临的主要挑战。通过研究卷积神经网络(CNN)的结构和原理,本文展示了深度学习如何提高图像识别的准确性和效率。同时,本文也讨论了数据不平衡、过拟合、计算资源限制等问题,并提出了相应的解决策略。
30 19
|
1天前
|
机器学习/深度学习 传感器 人工智能
探索深度学习在图像识别中的应用与挑战
【10月更文挑战第21天】 本文深入探讨了深度学习技术在图像识别领域的应用,并分析了当前面临的主要挑战。通过介绍卷积神经网络(CNN)的基本原理和架构设计,阐述了深度学习如何有效地从图像数据中提取特征,并在多个领域实现突破性进展。同时,文章也指出了训练深度模型时常见的过拟合问题、数据不平衡以及计算资源需求高等挑战,并提出了相应的解决策略。
28 7