在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

電子發燒友App

硬聲App

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示
電子發燒友網>電子資料下載>電子資料>PyTorch教程15.4之預訓練word2vec

PyTorch教程15.4之預訓練word2vec

2023-06-05 | pdf | 0.14 MB | 次下載 | 免費

資料介紹

我們繼續實現 15.1 節中定義的 skip-gram 模型。然后我們將在 PTB 數據集上使用負采樣來預訓練 word2vec。首先,讓我們通過調用函數來獲取數據迭代器和這個數據集的詞匯表 ,這在第 15.3 節d2l.load_data_ptb中有描述

import math
import torch
from torch import nn
from d2l import torch as d2l

batch_size, max_window_size, num_noise_words = 512, 5, 5
data_iter, vocab = d2l.load_data_ptb(batch_size, max_window_size,
                   num_noise_words)
Downloading ../data/ptb.zip from http://d2l-data.s3-accelerate.amazonaws.com/ptb.zip...
import math
from mxnet import autograd, gluon, np, npx
from mxnet.gluon import nn
from d2l import mxnet as d2l

npx.set_np()

batch_size, max_window_size, num_noise_words = 512, 5, 5
data_iter, vocab = d2l.load_data_ptb(batch_size, max_window_size,
                   num_noise_words)

15.4.1。Skip-Gram 模型

我們通過使用嵌入層和批量矩陣乘法來實現 skip-gram 模型。首先,讓我們回顧一下嵌入層是如何工作的。

15.4.1.1。嵌入層

如第 10.7 節所述,嵌入層將標記的索引映射到其特征向量。該層的權重是一個矩陣,其行數等于字典大小 ( input_dim),列數等于每個標記的向量維數 ( output_dim)。一個詞嵌入模型訓練好之后,這個權重就是我們所需要的。

embed = nn.Embedding(num_embeddings=20, embedding_dim=4)
print(f'Parameter embedding_weight ({embed.weight.shape}, '
   f'dtype={embed.weight.dtype})')
Parameter embedding_weight (torch.Size([20, 4]), dtype=torch.float32)
embed = nn.Embedding(input_dim=20, output_dim=4)
embed.initialize()
embed.weight
Parameter embedding0_weight (shape=(20, 4), dtype=float32)

嵌入層的輸入是標記(單詞)的索引。對于任何令牌索引i,它的向量表示可以從ith嵌入層中權重矩陣的行。由于向量維度 ( output_dim) 設置為 4,因此嵌入層返回形狀為 (2, 3, 4) 的向量,用于形狀為 (2, 3) 的標記索引的小批量。

x = torch.tensor([[1, 2, 3], [4, 5, 6]])
embed(x)
tensor([[[-0.6501, 1.3547, 0.7968, 0.3916],
     [ 0.4739, -0.0944, 1.2308, 0.6457],
     [ 0.4539, 1.5194, 0.4377, -1.5122]],

    [[-0.7032, -0.1213, 0.2657, -0.6797],
     [ 0.2930, -0.6564, 0.8960, -0.5637],
     [-0.1815, 0.9487, 0.8482, 0.5486]]], grad_fn=<EmbeddingBackward0>)
x = np.array([[1, 2, 3], [4, 5, 6]])
embed(x)
array([[[ 0.01438687, 0.05011239, 0.00628365, 0.04861524],
    [-0.01068833, 0.01729892, 0.02042518, -0.01618656],
    [-0.00873779, -0.02834515, 0.05484822, -0.06206018]],

    [[ 0.06491279, -0.03182812, -0.01631819, -0.00312688],
    [ 0.0408415 , 0.04370362, 0.00404529, -0.0028032 ],
    [ 0.00952624, -0.01501013, 0.05958354, 0.04705103]]])

15.4.1.2。定義前向傳播

在正向傳播中,skip-gram 模型的輸入包括形狀為(批大小,1)的中心詞索引和 形狀為(批大小,center的連接上下文和噪聲詞索引,其中定義在 第 15.3.5 節. 這兩個變量首先通過嵌入層從標記索引轉換為向量,然后它們的批量矩陣乘法(在第 11.3.2.2 節中描述)返回形狀為(批量大小,1, )的輸出 。輸出中的每個元素都是中心詞向量與上下文或噪聲詞向量的點積。contexts_and_negativesmax_lenmax_lenmax_len

def skip_gram(center, contexts_and_negatives, embed_v, embed_u):
  v = embed_v(center)
  u = embed_u(contexts_and_negatives)
  pred = torch.bmm(v, u.permute(0, 2, 1))
  return pred
def skip_gram(center, contexts_and_negatives, embed_v, embed_u):
  v = embed_v(center)
  u = embed_u(contexts_and_negatives)
  pred = npx.batch_dot(v, u.swapaxes(1, 2))
  return pred

skip_gram讓我們為一些示例輸入打印此函數的輸出形狀。

skip_gram(torch.ones((2, 1), dtype=torch.long),
     torch.ones((2, 4), dtype=torch.long), embed, embed).shape
torch.Size([2, 1, 4])
skip_gram(np.ones((2, 1)), np.ones((2, 4)), embed, embed).shape
(2, 1, 4)

15.4.2。訓練

在用負采樣訓練skip-gram模型之前,我們先定義它的損失函數。

15.4.2.1。二元交叉熵損失

根據15.2.1節負采樣損失函數的定義,我們將使用二元交叉熵損失。

class SigmoidBCELoss(nn.Module):
  # Binary cross-entropy loss with masking
  def __init__(self):
    super().__init__()

  def forward(self, inputs, target, mask=None):
    out = nn.functional.binary_cross_entropy_with_logits(
      inputs, target, weight=mask, reduction="none")
    return out.mean(dim=1)

loss = SigmoidBCELoss()
loss = gluon.loss.SigmoidBCELoss()

回想我們在第 15.3.5 節中對掩碼變量和標簽變量的描述 下面計算給定變量的二元交叉熵損失。

pred = torch.tensor([[1.1, -2.2, 3.3, -4.4]] * 2)
label = torch.tensor([[1.0, 0.0, 0.0, 0.0], [0.0, 1.0, 0.0, 0.0]])
mask = torch.tensor([[1, 1, 1, 1], [1, 1, 0, 0]])
loss(pred, label, mask) * mask.shape[1] / mask.sum(axis=1)
tensor([0.9352, 1.8462])
pred = np.array([[1.1, -2.2, 3.3, -4.4]] * 2)
label = np.array([[1.0, 0.0, 0.0, 0.0], [0.0, 1.0, 0.0, 0.0]])
mask = np.array([[1,
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1九陽豆漿機高清原理圖
  2. 2.47 MB   |  12次下載  |  1 積分
  3. 2數能NU501系列恒流芯片型號選型表
  4. 0.04 MB   |  2次下載  |  免費
  5. 3AIWA J470維修手冊 (可直接打印)
  6. 3.16 MB   |  2次下載  |  10 積分
  7. 4基于51/32單片機按鍵控制步進電機正反轉,A4988驅動
  8. 2.05 MB   |  2次下載  |  1 積分
  9. 5STM32F10xxx單片機編程手冊
  10. 0.29 MB   |  2次下載  |  免費
  11. 6HR1124S/9110S單通道低壓H橋電機驅動芯片中文手冊
  12. 1.30 MB   |  1次下載  |  免費
  13. 7MOSFET講解-02(可下載)
  14. 263.46 KB  |  1次下載  |  免費
  15. 8MOSFET講解-03(可下載)
  16. 501.18 KB  |  1次下載  |  免費

本月

  1. 1晶體三極管的電流放大作用詳細說明
  2. 0.77 MB   |  30次下載  |  2 積分
  3. 2雙極型三極管放大電路的三種基本組態的學習課件免費下載
  4. 4.03 MB   |  23次下載  |  1 積分
  5. 3第十一屆 藍橋杯 單片機設計與開發項目 省賽 程序設計試題及源碼
  6. 90.88KB   |  23次下載  |  3 積分
  7. 4Python從入門到精通背記手冊
  8. 18.77 MB   |  22次下載  |  1 積分
  9. 5多級放大電路的學習課件免費下載
  10. 1.81 MB   |  20次下載  |  2 積分
  11. 6STM32F103C8T6開發板最小系統原理圖
  12. 0.78 MB   |  20次下載  |  免費
  13. 7九陽豆漿機高清原理圖
  14. 2.47 MB   |  12次下載  |  1 積分
  15. 81875功放原理圖
  16. 0.04 MB   |  11次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935127次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
  4. 1.48MB  |  420063次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233089次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191382次下載  |  10 積分
  9. 5十天學會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183337次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81585次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73814次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65988次下載  |  10 積分
主站蜘蛛池模板: 看毛片网站 | 亚洲线精品一区二区三区 | 五月天婷婷丁香中文在线观看 | 国产一级又色又爽又黄大片 | 亚洲嫩草影院在线观看 | 国产一级特黄一级毛片 | 免费日本黄色 | 欧美三级色图 | 免费看国产黄色片 | 美女黄色在线 | 日本黄色片视频 | 在线免费看片 | 超级香蕉97视频在线观看一区 | 黄色免费网站在线观看 | 天天性视频 | 四虎永久免费地址 | 成人看片在线观看 | 国产女在线 | 日韩乱轮 | 欧美爽爽 | 日韩精品系列产品 | 免费在线欧美 | www.毛片com| 日本一级成人毛片免费观看 | 人人九九精品 | 在线精品一区二区三区 | 免费一级大毛片a一观看不卡 | 亚洲区免费 | 国产在线视欧美亚综合 | 国产精品资源在线观看网站 | 亚洲美女视频在线观看 | 天堂资源地址在线 | 资源新版在线天堂 | 色老板在线视频一区二区 | 中文字幕在线永久在线视频2020 | 深夜视频在线观看免费 | 热久久影院 | 中文字幕色综合久久 | 1024国产手机视频基地 | 日日夜夜狠狠干 | 一级a毛片免费观看 |