attention_mask矩阵应用

本文演示了如何在PyTorch中使用Attention Mask来筛选有效的slot_logits,通过实例展示了如何将mask应用于logits张量,以实现对序列中有效元素的保留。

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

第一例

import torch

attention_mask = [[1,0,0],
                  [1,1,0],
                  [1,1,1]]
attention_mask = torch.tensor(attention_mask)
3个槽值
slot_logits = [[1,2,3],
               [4,5,6],
               [7,8,9]]
slot_logits = torch.tensor(slot_logits)

active_loss = attention_mask.view(-1) == 1
active_logits = slot_logits.view(-1)[active_loss]
print(active_loss)
print(active_logits)
输出:
D:\ProgramData\Anaconda3\envs\jointBert\python.exe E:/github/2020.03/JointBERT-master/test.py
tensor([1, 0, 0, 1, 1, 0, 1, 1, 1], dtype=torch.uint8)
tensor([1, 4, 5, 7, 8, 9])

Process finished with exit code 0
import torch

attention_mask = [[1,0,0],
                  [1,1,0],
                  [1,1,1]]
attention_mask = torch.tensor(attention_mask)
# 3个槽值
slot_logits = [[1,2,3,4,5,6,7,8,9],
               [11,12,13,14,15,16,17,18,19],
               [21,22,23,24,25,26,27,28,29]]
slot_logits = torch.tensor(slot_logits)

active_loss = attention_mask.view(-1) == 1
active_logits = slot_logits.view(-1,3)[active_loss]
print(active_loss)
print(active_logits)

第二例

输出:
D:\ProgramData\Anaconda3\envs\jointBert\python.exe E:/github/2020.03/JointBERT-master/test.py
tensor([1, 0, 0, 1, 1, 0, 1, 1, 1], dtype=torch.uint8)
tensor([[ 1,  2,  3],
        [11, 12, 13],
        [14, 15, 16],
        [21, 22, 23],
        [24, 25, 26],
        [27, 28, 29]])

Process finished with exit code 0
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值