Keras Self-Attention

1、处理顺序数据

处理顺序数据时考虑每个时间戳的上下文
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

安装命令:pip install keras-self-attention

2、基本用法

默认情况下,注意力层使用附加注意力,并在计算相关性时考虑整个上下文。下面创建一个attention层,它遵循1中的方程(attention_activation是et,t`的激活功能)

import keras
from keras_self_attention import SeqSelfAttention

model = keras.models.Sequential()
model.add(keras.layers.Embedding(input_dim=10000, output_dim=300, mask_zero=True))
model.add(keras.layers.Bidirectional(keras.layers.LSTM(units=128, return_sequences=True)))
model.add(SeqSelfAttention(attention_activation=‘sigmoid’))
model.add(keras.layers.Dense(units=5))

model.compile(
optimizer=‘adam’,
loss=‘categorical_crossentropy’,
metrics=[‘categorical_accuracy’],
)

model.summary()

3、局部注意力机制对于一条数据,

全局背景过于宽泛,通过设置attention_width能够控制本地上下文的宽度
model.add(SeqSelfAttention(attention_width=15,
attention_activation=‘sigmoid’,
name=’Attention’
))

4、多头注意力机制

可以通过设置attention_type来使用多头注意力
此时et,t`的公式变:
在这里插入图片描述
from keras_self_attention import SeqSelfAttention

SeqSelfAttention(
attention_width=15,
attention_type=SeqSelfAttention.ATTENTION_TYPE_MUL,
attention_activation=None,
kernel_regularizer=keras.regularizers.l2(1e-6),
use_attention_bias=False,
name=‘Attention’,
)

  • 2
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值