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

走出趣网站怎么做今日重庆重要消息

走出趣网站怎么做,今日重庆重要消息,天津百度关键词推广公司,jsp servlet做博客网站1. BERT模型的输出 在BERT模型中,last_hidden_state和pooler_output是两个不同的输出。 (1) last_hidden_state: last_hidden_state是指BERT模型中最后一个隐藏层的隐藏状态。它是一个三维张量,其形状为[batch_size, sequence_length, hidden_size]。其…

1. BERT模型的输出

在BERT模型中,last_hidden_statepooler_output是两个不同的输出。

(1) last_hidden_state:

    last_hidden_state是指BERT模型中最后一个隐藏层的隐藏状态。它是一个三维张量,其形状为[batch_size, sequence_length, hidden_size]。其中,batch_size是输入序列的批量大小,sequence_length是输入序列的长度,hidden_size是BERT模型的隐藏层大小(通常为768)。
 last_hidden_state保存了输入序列中每个token对应的隐藏状态,这些隐藏状态经过多层的Transformer编码器处理得到。在多数任务中,可以直接使用这个张量进行下游任务的训练或者特征提取。

(2) pooler_output:
     pooler_output是指BERT模型中经过一个特殊的池化层后得到的句子级别表示。它是一个二维张量,其形状为[batch_size, hidden_size]。
pooler_output是通过对BERT模型最后一个隐藏层的第一个token([CLS] token)的隐藏状态应用一个全连接层得到的。这个全连接层的参数在预训练过程中被学习得到。pooler_output可以看作是整个输入序列的压缩表示,通常用于句子级别的任务,如文本分类。

       总的来说,last_hidden_state提供了序列中每个token的隐藏状态信息,而pooler_output提供了整个句子的语义表示。

2. last_hidden_state转换为pooler_output

     在BERT模型中,last_hidden_state是最后一个隐藏层的隐藏状态,而pooler_output是通过应用一个全连接层(通常是一个线性变换加上激活函数)到last_hidden_state中的特殊token([CLS] token)得到的。

      首先从last_hidden_state中提取出每个样本的第一个token(即[CLS] token)的隐藏状态。然后,我们定义了一个线性层pooler_layer,将隐藏状态映射到与BERT模型的隐藏大小相同的空间。最后,我们应用了tanh激活函数,得到 pooler_output,这是整个句子的语义表示。这个pooler_output可以用于句子级别的任务,例如文本分类。

      请确保poor_layer的权重是正确初始化的。通常情况下,应该使用预训练的BERT模型的权重来初始化它。可以在实例化poor_layer时进行这样的初始化。如果使用的是transformers库,它提供了加载预训练BERT模型并提取pooler_output的方法。要使用预训练的BERT模型的权重来初始化线性层 pooler_layer,可以从预训练的BERT模型中加载权重,并将这些权重用作 pooler_layer的初始权重。通常情况下,会使用Hugging Face的 transformers库来加载预训练的BERT模型。

       以下是一个示例代码,演示如何使用transformers库来加载预训练的BERT模型,并使用其中的权重来初始化 pooler_layer:

from transformers import BertModel, BertTokenizer#加载预训练的Bert模型和tokenizer
tokenizer = BertTokenizer.from_pretrained('bert-base-uncased')
extractor = BertModel.from_pretrained('bert-base-uncased')#text是原始文本数据
x = tokenizer(text, padding=True, truncation=True, max_length=256, return_tensors="pt").to(device)x = extractor(**x)#获取hidden_state
x1= x['last_hidden_state']# 定义一个线性层,将最后一个隐藏层的第一个token的隐藏状态映射到pooler_output
pooler_layer = nn.Linear(768, 768).to(device)# 使用BERT模型的权重来初始化pooler_layer的权重
with torch.no_grad():pooler_layer.weight.copy_(extractor.pooler.dense.weight)pooler_layer.bias.copy_(extractor.pooler.dense.bias)# 获取CLS token的隐藏状态(最后隐藏层的第一个token),取出每个样本的第一个token的隐藏状态
cls_token_state = x1[:, 0, :].to(device)## 应用线性层并使用激活函数
x1 = torch.tanh(pooler_layer(cls_token_state)).to(device)#直接获取pooler_output
x2=x['pooler_output'].to(device)

       在这个示例中,我们首先从预训练的BERT模型中加载了tokenizer和BERT模型。然后,我们创建了一个与BERT模型隐藏大小相同的线性层 pooler_layer。最后,我们使用`bert_model.pooler.dense`中的权重来初始化`pooler_layer`的权重。这样,`pooler_layer`就被正确初始化了,并可以用于将`last_hidden_state`变换为`pooler_output`。最后x1和x2的结果相同。

http://www.ds6.com.cn/news/3921.html

相关文章:

  • 网站开发实训心得800国外友链买卖平台
  • 专业定制网咖装修效果图网站性能优化方法
  • 我要自学网python怎么做优化关键词
  • o2o网站开发怎样建立网站平台
  • 画中画有哪些网站可以做网络营销知名企业
  • 长春做网站公司西安网络推广优化培训
  • 网站建设提供空间什么意思seo策划
  • 修复wordpress网站关键词优化培训
  • 室内设计考研北京网站快速排名优化
  • 网站设计原理新闻发稿平台有哪些?
  • wordpress 功能插件seo网站诊断文档案例
  • wap新闻网站源码百度推广退款电话
  • 2017网站建设前景百度推广助手下载
  • 敦煌网网站评价免费b站推广网站入口202
  • java做直播网站有哪些百度西安
  • 网站项目设计流程案例网络推广计划制定步骤
  • 企业网站分析快手推广网站
  • 网上做公益的网站互联网电商平台
  • 备案域名一定要建好网站吗专业北京网站建设公司
  • 大连哪有做网站的搜索引擎优化实训
  • 汕头做网站冯站长之家官网
  • 四川省营山县西城建筑公司网站人际网络营销2900
  • 做网站开发工资怎样搜索引擎的使用方法和技巧
  • flash 网站管理系统搜索数据
  • 电子商务网站建设与维护致谢词seo搜索引擎优化方案
  • 360网站做推广关键词优化排名要多少钱
  • 镇江做网站哪家公司好搜索引擎营销的特点包括
  • wordpress新建php页面模板陕西整站关键词自然排名优化
  • 我想弄个自己的卖货网站怎样做块链友情链接平台
  • wordpress分销平台seo网络培训