pytorch中的embedding词向量的使用方法


Posted in Python onAugust 18, 2019

Embedding

词嵌入在 pytorch 中非常简单,只需要调用 torch.nn.Embedding(m, n) 就可以了,m 表示单词的总数目,n 表示词嵌入的维度,其实词嵌入就相当于是一个大矩阵,矩阵的每一行表示一个单词。

emdedding初始化

默认是随机初始化的

import torch
from torch import nn
from torch.autograd import Variable
# 定义词嵌入
embeds = nn.Embedding(2, 5) # 2 个单词,维度 5
# 得到词嵌入矩阵,开始是随机初始化的
torch.manual_seed(1)
embeds.weight
# 输出结果:
Parameter containing:
-0.8923 -0.0583 -0.1955 -0.9656 0.4224
 0.2673 -0.4212 -0.5107 -1.5727 -0.1232
[torch.FloatTensor of size 2x5]

如果从使用已经训练好的词向量,则采用

pretrained_weight = np.array(args.pretrained_weight) # 已有词向量的numpy
self.embed.weight.data.copy_(torch.from_numpy(pretrained_weight))

embed的读取

读取一个向量。

注意参数只能是LongTensor型的

# 访问第 50 个词的词向量
embeds = nn.Embedding(100, 10)
embeds(Variable(torch.LongTensor([50])))
# 输出:
Variable containing:
 0.6353 1.0526 1.2452 -1.8745 -0.1069 0.1979 0.4298 -0.3652 -0.7078 0.2642
[torch.FloatTensor of size 1x10]

读取多个向量。

输入为两个维度(batch的大小,每个batch的单词个数),输出则在两个维度上加上词向量的大小。

Input: LongTensor (N, W), N = mini-batch, W = number of indices to extract per mini-batch
Output: (N, W, embedding_dim)

见代码

# an Embedding module containing 10 tensors of size 3
embedding = nn.Embedding(10, 3)
# 每批取两组,每组四个单词
input = Variable(torch.LongTensor([[1,2,4,5],[4,3,2,9]]))
a = embedding(input) # 输出2*4*3
a[0],a[1]

输出为:

(Variable containing:
 -1.2603 0.4337 0.4181
 0.4458 -0.1987 0.4971
 -0.5783 1.3640 0.7588
 0.4956 -0.2379 -0.7678
 [torch.FloatTensor of size 4x3], Variable containing:
 -0.5783 1.3640 0.7588
 -0.5313 -0.3886 -0.6110
 0.4458 -0.1987 0.4971
 -1.3768 1.7323 0.4816
 [torch.FloatTensor of size 4x3])

以上这篇pytorch中的embedding词向量的使用方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python库urllib与urllib2主要区别分析
Jul 13 Python
python编写的最短路径算法
Mar 25 Python
Python实现自动添加脚本头信息的示例代码
Sep 02 Python
python cx_Oracle的基础使用方法(连接和增删改查)
Nov 19 Python
NumPy 如何生成多维数组的方法
Feb 05 Python
对python文件读写的缓冲行为详解
Feb 13 Python
django搭建项目配置环境和创建表过程详解
Jul 22 Python
基于Tensorflow批量数据的输入实现方式
Feb 05 Python
python encrypt 实现AES加密的实例详解
Feb 20 Python
python简单实现最大似然估计&scipy库的使用详解
Apr 15 Python
如何使用 Python 读取文件和照片的创建日期
Sep 05 Python
python实现二分查找算法
Sep 18 Python
Pytorch加载部分预训练模型的参数实例
Aug 18 #Python
在pytorch中查看可训练参数的例子
Aug 18 #Python
浅析PyTorch中nn.Module的使用
Aug 18 #Python
关于PyTorch 自动求导机制详解
Aug 18 #Python
pytorch神经网络之卷积层与全连接层参数的设置方法
Aug 18 #Python
pytorch numpy list类型之间的相互转换实例
Aug 18 #Python
对Pytorch中nn.ModuleList 和 nn.Sequential详解
Aug 18 #Python
You might like
php2html php生成静态页函数
2008/12/08 PHP
Apache中php.ini的设置方法
2013/02/28 PHP
详解WordPress中的头像缓存和代理中的缓存更新方法
2016/03/01 PHP
thinkPHP订单数字提醒功能的实现方法
2016/12/01 PHP
yii2实现分页,带搜索的分页功能示例
2017/01/07 PHP
PHP读取并输出XML文件数据的简单实现方法
2017/12/22 PHP
PHP7创建销毁session的实例方法
2020/02/03 PHP
jQuery 判断元素上是否绑定了事件
2009/10/28 Javascript
javscript对象原型的一些看法
2010/09/19 Javascript
如何让easyui gridview 宽度自适应窗口改变及fitColumns应用
2013/01/25 Javascript
页面元素绑定jquery toggle后元素隐藏的解决方法
2014/03/27 Javascript
javascript替换已有元素replaceChild()使用介绍
2014/04/03 Javascript
jQuery中的height innerHeight outerHeight区别示例介绍
2014/06/15 Javascript
js实现点击链接后延迟3秒再跳转的方法
2015/06/05 Javascript
基于JS实现仿京东搜索栏随滑动透明度渐变效果
2017/07/10 Javascript
nodejs中安装ghost出错的原因及解决方法
2017/10/23 NodeJs
angularjs 页面自适应高度的方法
2018/01/17 Javascript
Vue 组件传值几种常用方法【总结】
2018/05/28 Javascript
js中null与空字符串""的区别讲解
2019/01/17 Javascript
element-ui tooltip修改背景颜色和箭头颜色的实现
2019/12/16 Javascript
jQuery实现移动端下拉展现新的内容回弹动画
2020/06/24 jQuery
vue+echarts实现动态折线图的方法与注意
2020/09/01 Javascript
js+h5 canvas实现图片验证码
2020/10/11 Javascript
[06:33]DOTA2亚洲邀请赛小组赛第二日 TOP10精彩集锦
2015/01/31 DOTA
[47:42]完美世界DOTA2联赛PWL S2 GXR vs Ink 第一场 11.19
2020/11/20 DOTA
用Python的Django框架完成视频处理任务的教程
2015/04/02 Python
为Python的web框架编写前端模版的教程
2015/04/30 Python
Python中列表list以及list与数组array的相互转换实现方法
2017/09/22 Python
Python批量发送post请求的实现代码
2018/05/05 Python
Python 编码规范(Google Python Style Guide)
2018/05/05 Python
在python带权重的列表中随机取值的方法
2019/01/23 Python
Python datetime 格式化 明天,昨天实例
2020/03/02 Python
个人党性剖析材料
2014/02/03 职场文书
学生违反校规检讨书
2014/10/28 职场文书
会计入职心得体会
2016/01/22 职场文书
python实现网络五子棋
2021/04/11 Python