Python双向RNN和堆叠的双向RNN是什么意思
Admin 2022-08-03 群英技术资讯 704 次浏览
双向RNN(Bidirectional RNN)的结构如下图所示。
双向的 RNN 是同时考虑“过去”和“未来”的信息。上图是一个序列长度为 4 的双向RNN 结构。
双向RNN就像是我们做阅读理解的时候从头向后读一遍文章,然后又从后往前读一遍文章,然后再做题。有可能从后往前再读一遍文章的时候会有新的不一样的理解,最后模型可能会得到更好的结果。
堆叠的双向RNN(Stacked Bidirectional RNN)的结构如上图所示。上图是一个堆叠了3个隐藏层的RNN网络。
注意,这里的堆叠的双向RNN并不是只有双向的RNN才可以堆叠,其实任意的RNN都可以堆叠,如SimpleRNN、LSTM和GRU这些循环神经网络也可以进行堆叠。
堆叠指的是在RNN的结构中叠加多层,类似于BP神经网络中可以叠加多层,增加网络的非线性。
import tensorflow as tf from tensorflow.keras.models import Sequential from tensorflow.keras.layers import Dense from tensorflow.keras.layers import LSTM,Dropout,Bidirectional from tensorflow.keras.optimizers import Adam import matplotlib.pyplot as plt # 载入数据集 mnist = tf.keras.datasets.mnist # 载入数据,数据载入的时候就已经划分好训练集和测试集 # 训练集数据x_train的数据形状为(60000,28,28) # 训练集标签y_train的数据形状为(60000) # 测试集数据x_test的数据形状为(10000,28,28) # 测试集标签y_test的数据形状为(10000) (x_train, y_train), (x_test, y_test) = mnist.load_data() # 对训练集和测试集的数据进行归一化处理,有助于提升模型训练速度 x_train, x_test = x_train / 255.0, x_test / 255.0 # 把训练集和测试集的标签转为独热编码 y_train = tf.keras.utils.to_categorical(y_train,num_classes=10) y_test = tf.keras.utils.to_categorical(y_test,num_classes=10) # 数据大小-一行有28个像素 input_size = 28 # 序列长度-一共有28行 time_steps = 28 # 隐藏层memory block个数 cell_size = 50 # 创建模型 # 循环神经网络的数据输入必须是3维数据 # 数据格式为(数据数量,序列长度,数据大小) # 载入的mnist数据的格式刚好符合要求 # 注意这里的input_shape设置模型数据输入时不需要设置数据的数量 model = Sequential([ Bidirectional(LSTM(units=cell_size,input_shape=(time_steps,input_size),return_sequences=True)), Dropout(0.2), Bidirectional(LSTM(cell_size)), Dropout(0.2), # 50个memory block输出的50个值跟输出层10个神经元全连接 Dense(10,activation=tf.keras.activations.softmax) ]) # 循环神经网络的数据输入必须是3维数据 # 数据格式为(数据数量,序列长度,数据大小) # 载入的mnist数据的格式刚好符合要求 # 注意这里的input_shape设置模型数据输入时不需要设置数据的数量 # model.add(LSTM( # units = cell_size, # input_shape = (time_steps,input_size), # )) # 50个memory block输出的50个值跟输出层10个神经元全连接 # model.add(Dense(10,activation='softmax')) # 定义优化器 adam = Adam(lr=1e-3) # 定义优化器,loss function,训练过程中计算准确率 使用交叉熵损失函数 model.compile(optimizer=adam,loss='categorical_crossentropy',metrics=['accuracy']) # 训练模型 history=model.fit(x_train,y_train,batch_size=64,epochs=10,validation_data=(x_test,y_test)) #打印模型摘要 model.summary() loss=history.history['loss'] val_loss=history.history['val_loss'] accuracy=history.history['accuracy'] val_accuracy=history.history['val_accuracy'] # 绘制loss曲线 plt.plot(loss, label='Training Loss') plt.plot(val_loss, label='Validation Loss') plt.title('Training and Validation Loss') plt.legend() plt.show() # 绘制acc曲线 plt.plot(accuracy, label='Training accuracy') plt.plot(val_accuracy, label='Validation accuracy') plt.title('Training and Validation Loss') plt.legend() plt.show()
这个可能对文本数据比较容易处理,这里用这个模型有点勉强,只是简单测试下。
模型摘要:
acc曲线:
loss曲线:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了Python数据结构列表,本文重点内容主要是对列表数据结构的使用,在Python中,序列是一组按顺序排列的值。Python 有 3 种内置的序列类型:字符串、 元组和列表,下面一起进入文章了解更详细内容吧,需要的小伙伴可以参考一下</P><P>
缺失值是指粗糙数据中由于缺少信息而造成的数据的聚类、分组、删失或截断,下面这篇文章主要给大家介绍了关于Python处理缺失值的8种不同方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
在python中用于生成随机数的模块是random,在使用前需要import, 下面看下它的用法。random randomrandom random()用于生成一个0到1的随机符
这篇文章给大家分享是关于python 怎样实现json文件保存内容,小编觉得比较有趣,因此分享给大家作参考。接下来我们会使用到json.dump()和递归思想,感兴趣的朋友往下看。
这篇文章主要介绍了python爬虫请求库httpx和parsel解析库的使用测评,帮助大家更好的理解和学习使用python,感兴趣的朋友可以了解下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008