当前位置: 首页 > news >正文

网站开发小程序python 和php网站开发

网站开发小程序,python 和php网站开发,通辽做网站的公司,国外网站网址关于SAM中decomposed Relative Positional Embeddings的理解。 relative positional embedding的一种实现方式是:先计算q和k的相对位置坐标,然后依据相对位置坐标从给定的table中取值。以q和k都是77为例,每个相对位置有两个索引对应x和y两个…

关于SAM中decomposed Relative Positional Embeddings的理解。

relative positional embedding的一种实现方式是:先计算q和k的相对位置坐标,然后依据相对位置坐标从给定的table中取值。以q和k都是7×7为例,每个相对位置有两个索引对应x和y两个方向,每个索引值的取值范围是[-6,6]。(第0行相对第6行,x索引相对值为-6;第6行相对第0行,x索引相对值为6;所以索引取值范围是[-6,6])。这个时候可以构建一个shape为[13,13, head_dim]的table,则当相对位置为(i,j)时,position embedding=table[i, j]。(i,j的取值范围都是[0, 12])具体可参考:有关swin transformer相对位置编码的理解

decomposed Relative Positional Embeddings的思想在于,分别计算x和y两个方向上计算相对位置坐标,并分别从两个table中取出对应的位置编码,再将两个方向的编码相加作为最终的编码。

以q为4×4和k是4×4为例,在x和y方向上,每个索引值的取值范围是[-3,3],所以需要构建两个shape为[7, head_dim]的table:

if use_rel_pos:assert (input_size is not None), "Input size must be provided if using relative positional encoding."# initialize relative positional embeddingsrel_pos_h = nn.Parameter(torch.zeros(2 * input_size[0] - 1, head_dim))rel_pos_w = nn.Parameter(torch.zeros(2 * input_size[1] - 1, head_dim))

然后依据q和k的shape来计算每个方向上对应的相对位置编码:

def get_rel_pos(q_size: int, k_size: int, rel_pos: torch.Tensor) -> torch.Tensor:# q_size和k_size分别为当前方向上,q和k的个数, rel_pos为当前方向上定义的tableq_coords = torch.arange(q_size)[:, None] # shape: [4, 1],给当前方向上每个q编号k_coords = torch.arange(k_size)[None, :]  # shape:[1, 4],给当前方向上每个k编号relative_coords = (q_coords - k_coords) + (k_size - 1) # q_coords - k_coords就是当前方向上每个q相对于k的位置,加上k_size - 1是为了让相对位置非负return rel_pos[relative_coords.long()] # 依据相对位置从预定义好的table中取值

依据q和每个方向上对应的位置编码来计算最终的编码:

    q_h, q_w = q_sizek_h, k_w = k_sizeRh = get_rel_pos(q_h, k_h, rel_pos_h) # 获取h方向的位置编码,shape:[4, 4, head_dim]Rw = get_rel_pos(q_w, k_w, rel_pos_w) # 获取w方向的位置编码,shape:[4, 4, head_dim]B, _, dim = q.shaper_q = q.reshape(B, q_h, q_w, dim)rel_h = torch.einsum("bhwc,hkc->bhwk", r_q, Rh) # r_q与Rh在h方向矩阵乘rel_w = torch.einsum("bhwc,wkc->bhwk", r_q, Rw)# attn是自注意力机制计算得到的注意力图attn = attn.view(B, q_h, q_w, k_h, k_w) + rel_h[:, :, :, :, None] + rel_w[:, :, :, None, :]).view(B, q_h * q_w, k_h * k_w)return attn
http://www.yayakq.cn/news/332902/

相关文章:

  • 美橙互联同类型网站织梦唯美网站源码
  • 高端h5网站开发怎样做理财投资网站
  • 免费手机网站源码网上商店是指
  • 上海网站开发设计公司网页不能运行wordpress
  • 举报网站制度建设方面龙岩房地产信息网
  • 一个网站怎么做提现自动到账网站建设制作收费
  • 网站建设找哪家公司好手机网页制作软件
  • 个人网站首页布局设计专门做win7的网站
  • 乐清建设网站哪家好wordpress修改上传大小
  • 电子商务网站建设的流程图中启智联网站建设
  • 做外贸通常用哪些网站专业企业网站设计服务公司
  • 黄岛网站建设哪家好保险网站哪家好
  • 铜陵做网站的公司陕西城乡建设厅网站
  • 做婚礼请柬的网站有哪些为什么要立刻做网站
  • 建筑工人招聘网站怎么做哪里有免费招聘网站
  • 网站用什么语言编写重庆九度设计
  • wordpress 仿站命令wordpress拼团
  • 首码项目推广网站百度seo优化教程免费
  • 企业vi设计报价网站关键词优化价格
  • 乌市地区建设工程门户网站网站底部关键词指向
  • wordpress 升级 xampp 无法定义根目录苏州企业网站优化
  • 在线快速建站网页托管网站
  • 莆田外贸网站建设有哪些去掉wordpress分类
  • vs2010做网站公司创建网站要多少钱
  • 东莞网站建设公司apm搭建 wordpress
  • 做3d建模贴图找哪个网站郑州东区做网站的公司
  • wordpress seo 标题seo优化入门教程
  • 12306网站很难做吗国家企业信用信息公示系统官方
  • 网站做支付链接安全吗网站后台怎么做外部链接
  • 做第三方库网站一条龙网站建设哪家好