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

大访问量的网站怎么做优化视频素材库

大访问量的网站怎么做优化,视频素材库,互联网保险公司排行榜,万网域名证书大模型基础——从零实现一个Transformer(1)-CSDN博客 一、前言 之前两篇文章已经讲了Transformer的Embedding,Tokenizer,Attention,Position Encoding, 本文我们继续了解Transformer中剩下的其他组件. 二、归一化 2.1 Layer Normalization layerNorm是针对序列数据提出的一种… 大模型基础——从零实现一个Transformer(1)-CSDN博客 一、前言 之前两篇文章已经讲了Transformer的Embedding,Tokenizer,Attention,Position Encoding, 本文我们继续了解Transformer中剩下的其他组件. 二、归一化 2.1 Layer Normalization layerNorm是针对序列数据提出的一种归一化方法主要在layer维度进行归一化即对整个序列进行归一化。 layerNorm会计算一个layer的所有activation的均值和方差利用均值和方差进行归一化。 ∑1 1∑1(−)2 归一化后的激活值如下 − 其中  和  是可训练的模型参数。  是缩放参数新分布的方差 2   是平移系数新分布的均值为  。  为一个小数添加到方差上避免分母为0。 2.2 LayerNormalization 代码实现 import torch import torch.nn as nnclass LayerNorm(nn.Module):def __init__(self,num_features,eps1e-6):super().__init__()self.gamma nn.Parameter(torch.ones(num_features))self.beta nn.Parameter(torch.zeros(num_features))self.eps epsdef forward(self,x):Args:x (Tensor): (batch_size, seq_length, d_model)Returns:Tensor: (batch_size, seq_length, d_model)mean x.mean(dim-1,keepdimTrue)std x.std(dim-1,keepdimTrue,unbiasedFalse)normalized_x (x - mean) / (std self.eps)return self.gamma * normalized_x self.betaif __name__ __main__:batch_size 2seqlen 3hidden_dim 4# 初始化一个随机tensorx torch.randn(batch_size,seqlen,hidden_dim)print(x)# 初始化LayerNormlayer_norm LayerNorm(num_featureshidden_dim)output_tensor layer_norm(x)print(output after layer norm:\n,,output_tensor)torch_layer_norm torch.nn.LayerNorm(normalized_shapehidden_dim)torch_output_tensor torch_layer_norm(x)print(output after torch layer norm:\n,torch_output_tensor) 三、残差连接 残差连接(residual connection,skip residual也称为残差块)其实很简单 x为网络层的输入该网络层包含非线性激活函数记为F(x)用公式描述的话就是 代码简单实现 x x layer(x) 四、前馈神经网络 4.1 Position-wise Feed Forward Position-wise Feed Forward(FFN)逐位置的前馈网络其实就是一个全连接前馈网络。目的是为了增加非线性增强模型的表示能力。 它一个简单的两层全连接神经网络不是将整个嵌入序列处理成单个向量而是独立地处理每个位置的嵌入。所以称为position-wise前馈网络层。也可以看为核大小为1的一维卷积。 目的是把输入投影到特定的空间再投影回输入维度。 FFN具体的公式如下 ()(11)22 上述公式对应FFN中的向量变换操作其中f为非线性激活函数。 4.2 FFN代码实现 from torch import nn,Tensor from torch.nn import functional as Fclass PositonWiseFeedForward(nn.Module):def __init__(self,d_model:int ,d_ff: int ,dropout: float0.1) - None::param d_model: dimension of embeddings:param d_ff: dimension of feed-forward network:param dropout: dropout ratiosuper().__init__()self.ff1 nn.Linear(d_model,d_ff)self.ff2 nn.Linear(d_ff,d_model)self.dropout nn.Dropout(dropout)def forward(self,x: Tensor) - Tensor::param x: (batch_size, seq_length, d_model) output from attention:return: (batch_size, seq_length, d_model)return self.ff2(self.dropout(F.relu(self.ff1(x)))) 五、Transformer Encoder Block 如图所示编码器(Encoder)由N个编码器块(Encoder Block)堆叠而成我们依次实现。 from torch import nn,Tensor ## 之前实现的函数引入 from llm_base.attention.MultiHeadAttention1 import MultiHeadAttention from llm_base.layer_norm.normal_layernorm import LayerNorm from llm_base.ffn.PositionWiseFeedForward import PositonWiseFeedForwardfrom typing import *class EncoderBlock(nn.Module):def __init__(self,d_model: int,n_heads: int,d_ff: int,dropout: float,norm_first: bool False)::param d_model: dimension of embeddings:param n_heads: number of heads:param d_ff: dimension of inner feed-forward network:param dropout:dropout ratio:param norm_first : if True, layer norm is done prior to attention and feedforward operations(Pre-Norm).Otherwise its done after(Post-Norm). Default to False.super().__init__()self.norm_first norm_firstself.attention MultiHeadAttention(d_model,n_heads,dropout)self.norm1 LayerNorm(d_model)self.ff PositonWiseFeedForward(d_model,d_ff,dropout)self.norm2 LayerNorm(d_model)self.dropout1 nn.Dropout(dropout)self.dropout2 nn.Dropout(dropout)# self attention sub layerdef _self_attention_sub_layer(self,x: Tensor, attn_mask: Tensor, keep_attentions: bool) - Tensor:x self.attention(x,x,x,attn_mask,keep_attentions)return self.dropout1(x)# ffn sub layerdef _ffn_sub_layer(self,x: Tensor) - Tensor:x self.ff(x)return self.dropout2(x)def forward(self,src: Tensor,src_mask: Tensor None,keep_attentions: bool False) - Tuple[Tensor,Tensor]::param src: (batch_size, seq_length, d_model):param src_mask: (batch_size, 1, seq_length):param keep_attentions:whether keep attention weigths or not. Defaults to False.:return:(batch_size, seq_length, d_model) output of encoder block# pass througth multi-head attention# src (batch_size, seq_length, d_model)# attn_score (batch_size, n_heads, seq_length, k_length)x src# post LN or pre LNif self.norm_first:# pre LNx x self._self_attention_sub_layer(self.norm1(x),src_mask,keep_attentions)x x self._ffn_sub_layer(self.norm2(x))else:x self.norm1(x self._self_attention_sub_layer(x,src_mask,keep_attentions))x self.norm2(x self._ffn_sub_layer(x))return x ​ 5.1 Post Norm Vs Pre Norm 公式区别 Pre Norm 和 Post Norm 的式子分别如下 在大模型的区别 Post-LN :是在 Transformer 的原始版本中使用的归一化方案。在此方案中每个子层例如自注意力机制或前馈网络的输出先通过子层自身的操作然后再通过层归一化Layer Normalization Pre-LN:是先对输入进行层归一化然后再传递到子层操作中。这样的顺序对于训练更深的网络可能更稳定因为归一化的输入可以帮助缓解训练过程中的梯度消失和梯度爆炸问题。 ​ 5.2为什么Pre效果弱于Post
http://www.hkea.cn/news/14588564/

相关文章:

  • 网站建设分工说明项目网站制作
  • 学做网站需要潍坊 网站
  • 大淘客网站免费空间厦门网站设计个人
  • wordpress网站图片加载速度慢如何提高网站点击率
  • php 开源cms 企业网站辽宁手机响应式网站建设
  • 好的网站开发校园网站方案
  • dedecms免费网站模板wordpress用户修改头像
  • 做游戏网站要通过什么审核网络规划设计师证书样本
  • 北京电子商务网站建设建设银行网站首页下载
  • 检察内网门户网站建设做设计的兼职网站有哪些
  • 海外网站营销百度百家模板wordpress
  • 十堰高端网站建设国家反诈中心app下载流程
  • 适合推广的网站有哪些网站新功能演示用什么技术做的
  • 做体育最好的网站建网站前途
  • 临沂网站制作学大教育培训机构怎么样
  • 有什么网站做可以国外的生意做音乐网站的目的
  • 建设一个网站主要受哪些因素的影响深圳网络有限公司
  • 上海市网站建设公叿网络营销sem培训
  • 网站制作公透明清晰网络营销服务工具
  • 吉林建设厅网站制作企业网站与app有什么不同
  • 导购网站做基础销量网站开发蓝云
  • 网站备案加速中国建筑企业排名
  • 网站成功案例设计包装设计公司排行榜
  • 现在帮人做网站赚钱吗企业网站建设的一般要素有
  • 凡科建设网站步骤无锡全网营销方案
  • 网站建设自学视频网站可以用什么语言开发做
  • 北京建设网官方网站适合大学生创业的网站建设类型
  • 网站维护主要是做哪些呼和浩特网络推广公司
  • 浙江网站建设服务专业网页美工招聘
  • 东营网站建设制作最新cms