Word2Vec模型总结
1.Huffman树的构造
解析:给定n个权值作为n个叶子节点,构造一棵二叉树,若它的带权路径长度达到最小,则称这样的二叉树为最优二叉树,也称Huffman树。数的带权路径长度规定为所有叶子节点的带权路径长度之和。Huffman树构造,如下所示:
(1)将看成是有n颗树的森林;
(2)在森林中选出两个根节点的权值最小的树合并,作为一棵新树的左、右子树,且新树的根节点权值为其左、右子树根节点权值之和;
(3)从森林中删除选取的两颗树,并将新树加入森林;
(4)重复(2)(3)步,直到森林中只剩一棵树为止,该树即为所求的Huffman树。
说明:利用Huffman树设计的二进制前缀编码,称为Huffman编码,它既能满足前缀编码条件,又能保证报文编码总长最短。
2.基于Hierarchical Softmax的模型(CBOW模型)
解析:

其中参数的物理意义,如下所示:
(1)
(2)表示路径中第结点对应的编码(根结点不对应编码)
(3)表示路径中第非叶子结点对应的向量
(4)表示从根结点出发到达对应叶子结点的路径。
(5)表示路径中包含结点的个数。
Hierarchical Softmax基本思想,如下所示:
对于word2vec中基于Hierarchical Softmax的CBOW模型,优化的目标函数,如下所示:
这样得到对数似然函数,如下所示:
将花括号中的内容简记为,如下所示:
使用随机梯度上升法对求偏导,如下所示:
的更新方程,如下所示:
使用随机梯度上升法对求偏导,如下所示:
对于词典中每个词的词向量更新方程,如下所示:
3.基于Hierarchical Softmax的模型(Skip-Gram模型)
解析:
其中,表示当前样本的中心词的词向量。
对于word2vec中基于Hierarchical Softmax的Skip-Gram模型,优化的目标函数,如下所示:
Skip-Gram模型中条件概率函数,如下所示:
这样得到对数似然函数,如下所示:
将花括号中的内容简记为,如下所示:
4.基于Negative Sampling的模型(CBOW模型)
Negative Sampling不再使用Huffman树,而是使用随机负采样,能大幅度提高性能。假定已经选好的负样本子集,定义词的标签[正样本为1,负样本为0],如下所示:
对于给定的正样本,最大化,如下所示:
其中,表示中各词的词向量之和,表示词对应的一个辅助向量,为待训练的参数。简化方程,如下所示:
其中,表示当上下文为时,预测中心词为的概率,同样表示当上下文为时,预测中心词为的概率。
对于给定的语料库,目标函数如下所示:
记,使用随机梯度上升法对求偏导,如下所示:
参数的更新方程,如下所示:
使用随机梯度上升法对求偏导,如下所示:
参数的更新方程,如下所示:
5.基于Negative Sampling的模型(Skip-Gram模型)
对于给定的语料库,目标函数如下所示:
对每一个样本,需要针对中的每一个词进行负采样,但是word2vec源码中只是针对进行了次负采样。它本质上用的还是CBOW模型,只是将原来通过求和累加做整体用的上下文拆成一个一个来考虑。对于给定的语料库,目标函数如下所示:
记。使用随机梯度上升法,对求偏导,如下所示:
的更新方程,如下所示:
使用随机梯度上升法,对求偏导,如下所示:
参数的更新,如下所示:
其中,表示处理词时生成的负样本子集。
6.Negative Sampling算法
(1)带权采样原理
设词典中的每一个词对应一个线段,长度如下所示:
这里表示一个词在语料中出现的次数。现在将这些线段首尾相连地拼接在一起,形成一个长度为1的单位线段。如果随机地往这个单位线段上打点,那么其中长度越长的线段(对应高频词)被打中的概率就越大。
(2)word2vec负采样
记,,这里表示词典中第个词,则以为剖分结点可得到区间上的一个非等距剖分,为其个剖分区间。进一步引入区间上的一个等距离剖分,剖分结点为,其中,具体示意图如下所示:

将内部剖分结点投影到非等距剖分上,则可建立与区间(或)的映射关系,如下所示:
根据映射每次生成一个间的随机整数,就是一个样本。当对进行负采样时,如果采样为,那么就跳过去。
参考文献:
[1]word2vec中的数学原理详解
Word2Vec模型总结的更多相关文章
- word2vec模型原理与实现
word2vec是Google在2013年开源的一款将词表征为实数值向量的高效工具. gensim包提供了word2vec的python接口. word2vec采用了CBOW(Continuous B ...
- wiki中文语料的word2vec模型构建
一.利用wiki中文语料进行word2vec模型构建 1)数据获取 到wiki官网下载中文语料,下载完成后会得到命名为zhwiki-latest-pages-articles.xml.bz2的文件,里 ...
- word2vec模型评估方案
1.word2vec参数详解 · sentences:可以是一个·ist,对于大语料集,建议使用BrownCorpus,Text8Corpus或·ineSentence构建.· sg: 用于设置训练算 ...
- Word2Vec模型参数 详解
用gensim函数库训练Word2Vec模型有很多配置参数.这里对gensim文档的Word2Vec函数的参数说明进行翻译,以便不时之需. class gensim.models.word2vec.W ...
- 【新人赛】阿里云恶意程序检测 -- 实践记录 11.24 - word2vec模型 + xgboost
使用word2vec训练词向量 使用word2vec无监督学习训练词向量,输入的是训练数据和测试数据,输出的是每个词的词向量,总共三百个词左右. 求和:然后再将每行数据中的每个词的词向量加和,得到每行 ...
- 无所不能的Embedding 1 - Word2vec模型详解&代码实现
word2vec是google 2013年提出的,从大规模语料中训练词向量的模型,在许多场景中都有应用,信息提取相似度计算等等.也是从word2vec开始,embedding在各个领域的应用开始流行, ...
- NLP学习(4)----word2vec模型
一. 原理 哈弗曼树推导: https://www.cnblogs.com/peghoty/p/3857839.html 负采样推导: http://www.hankcs.com/nlp/word2v ...
- Word2vec 模型载入(tensorflow)
opts = Options() with tf.Graph().as_default(), tf.Session() as session: model = Word2Vec(opts, sessi ...
- word2vec模型cbow与skip-gram的比较
cbow和skip-gram都是在word2vec中用于将文本进行向量表示的实现方法,具体的算法实现细节可以去看word2vec的原理介绍文章.我们这里大体讲下两者的区别,尤其注意在使用当中的不同特点 ...
- word2vec + transE 知识表示模型
本文主要工作是将文本方法 (word2vec) 和知识库方法 (transE) 相融合作知识表示,即将外部知识库信息(三元组)加入word2vec语言模型,作为正则项指导词向量的学习,将得到的词向量用 ...
随机推荐
- Android应用中对于微信分享的实例及问题
源码地址 如何分享 分享无相应 分享结果如何接收响应 微信 分享回调 (提示几点关键问题: debug_key 一定要获得对应的签名码 然后和weixin官网的appid对应 ) 几点注意 ...
- docker入门加实战—网络
docker入门加实战-网络 我们运行了一些容器,但是这些容器是否能够进行连通呢?那我们就来试一下. 我们查看一下MySQL容器的详细信息: 主要关注,Networks.bridge.IPAddres ...
- King's Tour 题解
King's Tour 题面大意 在 \(n\times m\) 的网格中构造一种从 \((1,1)\) 走到 \((a,b)\) 的方案,要求经过所有格子恰好一次,格子之间八联通. 思路分析 模拟赛 ...
- Emit 实体绑定源码开源,支持类以及匿名类绑定(原创)
动态实体绑定 主要有以下两种 1.表达式树构建委托 2.Emit构建委托 根据我的经验 Emit 代码量可以更少可以很好实现代码复用 Emit实践开源项目地址跳转 https://www.cnblog ...
- LangChain实战
1.概述 最近,在研究LangChain时,发现一些比较有意思的点,今天笔者将给大家分享关于LangChain的一些内容. 2.内容 2.1 什么是LangChain? LangChain是一项旨在赋 ...
- [C++]二叉链-二叉树存储
二叉链存二叉树 预备知识 指针的熟练掌握 Bolg template模板的知识 Bolg 二叉树的基本知识 感谢: 代码参考:CSDN博主「云雨澄枫」的原创文章 链接 代码解析 结构体 BiNode ...
- Java技术_基础技术(0003)_类执行顺序详解+实例(阿里面试题)+详细讲解+流程图
类加载机制 加载.验证.准备.初始化和卸载这5个阶段的顺序是确定的,类的加载过程必须按照这种顺序按部就班地开始,而解析阶段则不一定:它在某些情况下可以在初始化阶段之后再开始,这是为了支持Java语言的 ...
- Altium Designer中'=SheetNumber'和'=SheetTotal'参数无效的解决方法
出现的问题 图纸没有被自动编号 在Altium中该显示区域被称为Title Block.[这里使用了图纸模板]. 当使用层次化的设计方式时,往往一个工程中若干幅原理图.这时我们需要为原理图进行编号. ...
- [数据校验/数据质量] 数据校验框架:hibernate-validation
0 前言 其一,项目中普遍遇到了此问题,故近两天深入地研究了一下. 其二,能够自信地说,仔细看完本篇,就无需再看其他的Java数据校验框架的文章了. 1 数据校验框架概述 1.0 数据校验框架的产生背 ...
- 题解 CF690C2
题目大意: 给你一棵树,求一下直径 题目分析: emm,怎么说吧,就是树的直径的裸板子. 可能有人不大理解,明明是图,你为什么要说是给定一棵树. 大家可以自行验证一下,满足如下两个性质的是否是一棵树: ...