SelfAttenion自注意力机制

my-attention

考虑别的token对当前token的语义影响

第一种情况, 维度缩减

输入x= [4x6]

dk=3

wq = [6x3]

wk = [6x3]

wv = [6x3]

q = x@ wq = [4x6]*[6x3] = [4x3]

k = x@ wk = [4x6]*[6x3] = [4x3]

r=q@k.T = [4x3]*[3x4]=[4x4]

缩放

r = r/sqrt(dk)=[4x4]

a = softmax®=[4x4]

v = x@ wv = [4x6]*[6x3] = [4x3]

out = a@v = [4x4] * [4x3] = [4x3]

第二种情况, 维度不缩减

输入x= [4x6]

输出维度为6

dk=6

随机生成qkv

wq = [6x6]

wk = [6x6]

wv = [6x6]

q = x@ wq = [4x6]*[6x6] = [4x6]

k = x@ wk = [4x6]*[6x6] = [4x6]

r=q@k.T = [4x6]*[6x4]=[4x4]

缩放

r = r/sqrt(dk)=[4x4]

归一化

a = softmax®=[4x4]

原始值增加权重

v = x@ wv = [4x6]*[6x6] = [4x6]

out = a@v = [4x4] * [4x6] = [4x6]

保证输出结果的维度和要求要一致

下面是用代码实现了一下自注意力机制

复制代码
import math

import torch
from torch import nn

x = torch.randn(16, 64, 512)

d_model = 512
h_num = 8


class Self_Attention(nn.Module):
    def __init__(self, d_model, h_num):
        # 调用父类构造函数
        super(Self_Attention, self).__init__()

        self.d_model = d_model
        self.h_num = h_num
        self.softmax = nn.Softmax(dim=-1)
        self.w_q = nn.Linear(d_model, d_model)
        self.w_k = nn.Linear(d_model, d_model)
        self.w_v = nn.Linear(d_model, d_model)
        self.w_o = nn.Linear(d_model, d_model)

    def forward(self, x):
        B, L, D = x.shape

        h_d = self.d_model // self.h_num

        q, k, v = self.w_q(x), self.w_k(x), self.w_v(x)
        q = q.view(B, L, self.h_num, h_d).transpose(1, 2)
        k = k.view(B, L, self.h_num, h_d).transpose(1, 2)
        v = v.view(B, L, self.h_num, h_d).transpose(1, 2)

        r = q @ k.transpose(2, 3) / math.sqrt(h_d)

        mask = torch.tril(torch.ones(L, L, dtype=bool))

        r = r.masked_fill(~mask, -10000) 

        a = self.softmax(r)

        o = a @ v
        o = o.transpose(1, 2).contiguous().view(B, L, self.d_model)

        return self.w_o(o)


attention = Self_Attention(d_model, h_num)
y = attention(x)
print(y.shape)
print(y)
相关推荐
langzaibeijing16 分钟前
性价比高的AI应用厂家
大数据·人工智能·python
Gerardisite18 分钟前
企业微信 API 能做什么?
人工智能·python·自动化·企业微信
测试员周周24 分钟前
【Appium 系列】第09节-数据驱动测试 — YAML 数据 + parametrize
服务器·数据库·人工智能·python·测试工具·语言模型·appium
不能隔夜的咖喱25 分钟前
黑马ai大模型笔记(自用,比较粗糙)
linux·windows·python
周公26 分钟前
记一次在双 RTX 3090 工作站上部署 vLLM 与 Qwen3.6-35B-AWQ 的实战记录
python·ai·llama·vllm·ollama
cskywit28 分钟前
【BIBM2025】 MedMamba-YOLO:医疗目标检测,当 YOLO 遇见轻量级 Mamba
深度学习·yolo·目标检测
yexuhgu37 分钟前
html如何修改备注
jvm·数据库·python
AI技术控37 分钟前
Prompt Engineering 在企业大模型应用中的实践:从提示词模板到可控输出
人工智能·python·深度学习·语言模型·自然语言处理·prompt
Marry Andy40 分钟前
langgenius/dify-sandbox:0.2.12启动崩溃
人工智能·经验分享·python
被AI抢饭碗的人44 分钟前
C++过渡Python
开发语言·python