TensorFlow教程 2 TensorFlow基础构架

本文介绍了TensorFlow的基础构架,包括处理结构、Session会话控制、Variable变量、Placeholder传入值和激活函数的概念。在TensorFlow中,数据流图用于定义计算,Session用于执行计算并获取结果。变量需要初始化,Placeholder用于接收外部数据,而激活函数在神经网络中激活神经元,促进信息传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2 TensorFlow基础构架

2.1 处理结构

Tensorflow的运算步骤是:

  1. 首先要定义神经网络的结构。
  2. 然后再把数据放入结构当中去运算和 training.

如图:
image

其中:Gradients是它的计算模块,上面的SGD是误差计算。

什么是TensorFlow?

TensorFlow是采用数据流图(data flow graphs)来计算, 所以首先我们得创建一个数据流流图, 然后再将我们的数据(数据以张量(tensor)的形式存在)放在数据流图中计算. 节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组, 即张量(tensor). 训练模型时tensor会不断的从数据流图中的一个节点flow到另一节点, 这就是TensorFlow名字的由来.

张量(tensor):
` 张量有多种. 零阶张量为 纯量或标量 (scalar) 也就是一个数值. 比如 [1]
` 一阶张量为 向量 (vector), 比如 一维的 [1, 2, 3]
` 二阶张量为 矩阵 (matrix), 比如 二维的 [[1, 2, 3],[4, 5, 6],[7, 8, 9]]
` 以此类推, 还有 三阶 三维的 …

2.2 例子2

import tensorflow as tf
import numpy as np

## 1.构造实验数据
x_data = np.random.rand(100).astype(np.float32)
y_data = x_data * 0.1 + 0.3 # y与x的关系:权重 偏置

## 2.创建tensorflow的结构
# 定义 权重变量(随机生成的)
Weights = tf.Variable(tf.random_uniform([1],-1.0,1.0))
# 定义 偏置
biases = tf.Variable(tf.zeros([1]))
# 定义 模型输出
y = x_data * Weights +biases

# 接着就是计算 y 和 y_data 的误差:
loss = tf.reduce_mean(tf.square(y - y_data))

# 定义优化器 optimizer:
optimizer = tf.train.GradientDescentOptimizer(0.5) # 我们使用的误差传递方法是梯度下降法
train = optimizer.minimize(loss)

## 3.激活刚才定义的神经网络结构
init = tf.global_variables_initializer()  # 激活器 初始化所有之前定义的Variable

sess = tf.Session() # 创建会话 Session
sess.run(init) # 用 Session 来 run 激活前面的变量.

## 4.训练模型
for step in range(201):
    sess.run(train)
    if step % 20 == 0:
        print("第",step,"次训练,参数为 : ",sess.run(Weights),sess.run(biases))

2.3 Session 会话控制

Session 是 Tensorflow 为了控制,和输出文件的执行的语句.

运行 session.run() 可以获得你要得知的运算结果, 或者是你所要运算的部分.

例子:建立两个 matrix ,输出两个 matrix 矩阵相乘的结果。

import tensorflow as tf

# create two matrixes

matrix1 = tf.constant([[3,3]])
matrix2 = tf.constant([[2],
                       [2]])
product = tf.matmul(matrix1,matrix2)

因为 product 不是直接计算的步骤, 所以我们会要使用 Session 来激活 product 并的到计算结果. 有两种形式使用会话控制 Session 。

# method 1
sess = tf.Session()
result = sess.run(product)
print(result)
sess.close()
# [[12]]

# method 2
with tf.Session() as sess:
    result2 = sess.run(product)
    print(result2)
# [[12]]

其中with的方法会帮助我们在必要的时候关闭session

2.4 Variable 变量

在 Tensorflow 中,用 ==定义语法: state = tf.Variable()== 定义了某字符串是变量,它才是变量,这一点是与 Python 所不同的。


import tensorflow as tf

# 这里定义变量!赋初值,名字
state = tf.Variable(0, name='counter')

# 定义常量 one
one = tf.constant(1)

# 定义加法步骤 (注: 此步并没有直接计算)
new_value = tf.add(state, one)

# 将 State 更新成 new_value,这一步也并没有真正计算
update = tf.assign(state, new_value)

如果你在 Tensorflow 中设定了变量,那么初始化变量是最重要的!!所以定义了变量以后, 一定要定义 ==init = tf.initialize_all_variables()==

到这里变量还是没有被激活,需要再在 sess 里, sess.run(init) , 激活 init 这一步.


# 如果定义 Variable, 就一定要 initialize
# init = tf.initialize_all_variables() # tf 马上就要废弃这种写法
init = tf.global_variables_initializer()  # 替换成这样就好

# 使用 Session
with tf.Session() as sess:
    sess.run(init)
    for _ in range(3):
        sess.run(update)
        print(sess.run(state))

注意:直接 print(state) 不起作用!!

一定要把 sess 的指针指向 state 再进行 print 才能得到想要的结果!

2.5 Placeholder 传入值

placeholder 是 Tensorflow 中的占位符,暂时储存变量.

Tensorflow 如果想要从外部传入data, 那就需要用到 tf.placeholder(), 然后以这种形式传输数据 sess.run(*, feed_dict={input: }).

示例:


import tensorflow as tf

#在 Tensorflow 中需要定义 placeholder 的 type ,一般为 float32 形式
input1 = tf.placeholder(tf.float32)
input2 = tf.placeholder(tf.float32)

# mul = multiply 是将input1和input2 做乘法运算,并输出为 output 
ouput = tf.multiply(input1, input2)

接下来, 传值的工作交给了 sess.run() , 需要传入的值放在了字典 feed_dict={} 中
并一一对应每一个 input.

placeholder 与 feed_dict={} 是绑定在一起出现的。

with tf.Session() as sess:
    print(sess.run(ouput, feed_dict={input1: [7.], input2: [2.]}))
# [ 14.]

2.6 激励函数 Activation Function

激励函数运行时激活神经网络中某一部分神经元,将激活信息向后传入下一层的神经系统。激励函数的实质是非线性方程。

Tensorflow 的神经网络 里面处理较为复杂的问题时都会需要运用激励函数 activation function 。

网络构架如下: 输入层 -> 卷积层1 -> 池化层1 -> 卷积层2 -> 池化层2 -> 卷积层3 -> 池化层3 -> 全连接层1 -> 输出层 其中,卷积层1、2、3的卷积核大小均为3x3,步长为1,padding为same,激活函数为ReLU;池化层1、2、3的池化大小均为2x2,步长为2;全连接层1的神经元个数为128,激活函数为ReLU;输出层为10个神经元,使用softmax激活函数。 完整代码如下: ```python import tensorflow as tf from tensorflow.keras import datasets, layers, models # 加载数据集 (train_images, train_labels), (test_images, test_labels) = datasets.cifar10.load_data() # 数据归一化 train_images, test_images = train_images / 255.0, test_images / 255.0 # 模型构建 model = models.Sequential() model.add(layers.Conv2D(32, (3, 3), activation='relu', padding='same', input_shape=(32, 32, 3))) model.add(layers.MaxPooling2D((2, 2))) model.add(layers.Conv2D(64, (3, 3), activation='relu', padding='same')) model.add(layers.MaxPooling2D((2, 2))) model.add(layers.Conv2D(128, (3, 3), activation='relu', padding='same')) model.add(layers.MaxPooling2D((2, 2))) model.add(layers.Flatten()) model.add(layers.Dense(128, activation='relu')) model.add(layers.Dense(10, activation='softmax')) # 编译模型 model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy']) # 训练模型 history = model.fit(train_images, train_labels, epochs=10, validation_data=(test_images, test_labels)) # 打印输出结果 test_loss, test_acc = model.evaluate(test_images, test_labels) print('Test accuracy:', test_acc) ``` 输出结果如下: ``` Epoch 1/10 1563/1563 [==============================] - 67s 43ms/step - loss: 1.4496 - accuracy: 0.4795 - val_loss: 1.1835 - val_accuracy: 0.5788 Epoch 2/10 1563/1563 [==============================] - 67s 43ms/step - loss: 1.0275 - accuracy: 0.6395 - val_loss: 0.9430 - val_accuracy: 0.6691 Epoch 3/10 1563/1563 [==============================] - 68s 43ms/step - loss: 0.8442 - accuracy: 0.7063 - val_loss: 0.8638 - val_accuracy: 0.6996 Epoch 4/10 1563/1563 [==============================] - 68s 43ms/step - loss: 0.7157 - accuracy: 0.7519 - val_loss: 0.8371 - val_accuracy: 0.7113 Epoch 5/10 1563/1563 [==============================] - 68s 43ms/step - loss: 0.6147 - accuracy: 0.7883 - val_loss: 0.8075 - val_accuracy: 0.7249 Epoch 6/10 1563/1563 [==============================] - 68s 44ms/step - loss: 0.5215 - accuracy: 0.8175 - val_loss: 0.8597 - val_accuracy: 0.7230 Epoch 7/10 1563/1563 [==============================] - 68s 44ms/step - loss: 0.4465 - accuracy: 0.8420 - val_loss: 0.8782 - val_accuracy: 0.7270 Epoch 8/10 1563/1563 [==============================] - 70s 45ms/step - loss: 0.3764 - accuracy: 0.8680 - val_loss: 0.9094 - val_accuracy: 0.7235 Epoch 9/10 1563/1563 [==============================] - 71s 45ms/step - loss: 0.3163 - accuracy: 0.8899 - val_loss: 0.9812 - val_accuracy: 0.7185 Epoch 10/10 1563/1563 [==============================] - 72s 46ms/step - loss: 0.2670 - accuracy: 0.9067 - val_loss: 1.0317 - val_accuracy: 0.7199 313/313 [==============================] - 3s 11ms/step - loss: 1.0317 - accuracy: 0.7199 Test accuracy: 0.7198999524116516 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值