- PyTorch 教程
- PyTorch - 主頁
- PyTorch - 簡介
- PyTorch - 安裝
- 神經網路的數學基礎
- PyTorch - 神經網路基礎
- 機器學習的通用工作流程
- 機器學習與深度學習
- 實現第一個神經網路
- 將神經網路轉換為功能模組
- PyTorch - 術語
- PyTorch - 載入資料
- PyTorch - 線性迴歸
- PyTorch - 卷積神經網路
- PyTorch - 遞迴神經網路
- PyTorch - 資料集
- PyTorch - 卷積簡介
- 從頭開始訓練卷積
- PyTorch - 卷積中的特徵提取
- PyTorch - 卷積視覺化
- 使用卷積進行序列處理
- PyTorch - 詞嵌入
- PyTorch - 遞迴神經網路
- PyTorch 有用資源
- PyTorch - 快速指南
- PyTorch - 有用資源
- PyTorch - 討論
PyTorch - 詞嵌入
在本章節,我們將瞭解著名的詞嵌入模型,即 word2vec。Word2vec 模型用於利用一組相關模型生成詞嵌入。Word2vec 模型是用純 C 程式碼實現的,梯度是手動計算的。
如下步驟介紹了在 PyTorch 中實現 word2vec 模型 −
步驟 1
在詞嵌入中實現如下所述的庫 −
import torch from torch.autograd import Variable import torch.nn as nn import torch.nn.functional as F
步驟 2
使用名為 word2vec 的類實現詞嵌入的 Skip Gram 模型。其中包括型別為 emb_size、emb_dimension、u_embedding、v_embedding 的屬性。
class SkipGramModel(nn.Module):
def __init__(self, emb_size, emb_dimension):
super(SkipGramModel, self).__init__()
self.emb_size = emb_size
self.emb_dimension = emb_dimension
self.u_embeddings = nn.Embedding(emb_size, emb_dimension, sparse=True)
self.v_embeddings = nn.Embedding(emb_size, emb_dimension, sparse = True)
self.init_emb()
def init_emb(self):
initrange = 0.5 / self.emb_dimension
self.u_embeddings.weight.data.uniform_(-initrange, initrange)
self.v_embeddings.weight.data.uniform_(-0, 0)
def forward(self, pos_u, pos_v, neg_v):
emb_u = self.u_embeddings(pos_u)
emb_v = self.v_embeddings(pos_v)
score = torch.mul(emb_u, emb_v).squeeze()
score = torch.sum(score, dim = 1)
score = F.logsigmoid(score)
neg_emb_v = self.v_embeddings(neg_v)
neg_score = torch.bmm(neg_emb_v, emb_u.unsqueeze(2)).squeeze()
neg_score = F.logsigmoid(-1 * neg_score)
return -1 * (torch.sum(score)+torch.sum(neg_score))
def save_embedding(self, id2word, file_name, use_cuda):
if use_cuda:
embedding = self.u_embeddings.weight.cpu().data.numpy()
else:
embedding = self.u_embeddings.weight.data.numpy()
fout = open(file_name, 'w')
fout.write('%d %d\n' % (len(id2word), self.emb_dimension))
for wid, w in id2word.items():
e = embedding[wid]
e = ' '.join(map(lambda x: str(x), e))
fout.write('%s %s\n' % (w, e))
def test():
model = SkipGramModel(100, 100)
id2word = dict()
for i in range(100):
id2word[i] = str(i)
model.save_embedding(id2word)
步驟 3
實現主要方法以使詞嵌入模型正確顯示。
if __name__ == '__main__': test()
廣告