论文地址:Efficient Estimation of Word Representations in Vector Space
个人认为,word2vec主要解决的问题是one-hot中维度过高并且稀疏的问题。word2vec是Google团队在2013年发表的一篇paper,当时一经问世直接将NLP领域带到了一个新的高度,在2018年bert被提出之前,word2vec一直是NLP算法工程师追捧的预训练词向量模型。
Word2Vec是轻量级的神经网络,其模型仅仅包括输入层、隐藏层和输出层,模型框架根据输入输出的不同,主要包括CBOW和Skip-gram模型。CBOW是知道
w
t
−
2
w_{t-2}
wt−2,
w
t
−
1
w_{t-1}
wt−1,
w
t
+
1
w_{t+1}
wt+1,
w
t
+
2
w_{t+2}
wt+2,预测
w
t
w_t
wt.而Skip-gram是知道
w
t
w_t
wt,预测
w
t
−
2
w_{t-2}
wt−2,
w
t
−
1
w_{t-1}
wt−1,
w
t
+
1
w_{t+1}
wt+1,
w
t
+
2
w_{t+2}
wt+2
首先,输入层是一个one-hot向量,具体细节请看前面的博客。例如
w
t
−
2
=
[
0
,
0
,
1
,
0
,
0
,
0
]
w_{t-2}=[0,0,1,0,0,0]
wt−2=[0,0,1,0,0,0] 经过一个矩阵
[
0
1
1
1
1
0
3
5
6
1
1
0
1
0
1
]
参考: