国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

對預訓練模型在召回與排序部分的應用做一個總結

深度學習自然語言處理 ? 來源:NewBeeNLP ? 作者:Chilia ? 2022-09-06 10:17 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本文對預訓練模型在召回(retrieval), 排序(re-ranking),以及其他部分的應用做一個總結。

1. 背景

搜索任務就是給定一個query或者QA中的question,去大規模的文檔庫中找到相似度較高的文檔,并返回一個按相關度排序的ranked list。

由于待訓練的模型參數很多(增加model capacity),而專門針對檢索任務的有標注數據集較難獲取,所以要使用預訓練模型。

2. 檢索模型的分類

檢索的核心,在于計算query和document的 相似度 。依此可以把信息檢索模型分為如下三類:

基于統計的檢索模型

使用exact-match來衡量相似度,考慮的因素有query中的詞語在document中出現的詞頻TF、document長度(懲罰長文本,例如一個詞在300頁的文章中出現過2次遠遠不如一個詞在一小段微博動態里出現過兩次)、逆文檔詞頻IDF(懲罰在所有文檔中都出現過很多次的詞,例如“的”)。

代表性的模型是BM25,用來衡量一個term在doc中的重要程度,其公式如下:

82f8f35c-2d86-11ed-ba43-dac502259ad0.png懲罰長文本、對詞頻做飽和化處理

實際上,BM25是檢索模型的強baseline。基于exact-match的檢索模型是召回中必不可少的一路。

Learning-to-Rank模型

這類模型需要手動構造特征,包括

query端特征,如query類型、query長度(還可以加入意圖slot?);

document端特征(document長度,Pagerank值);

query-document匹配特征(BM25值,相似度,編輯距離等)。

其實,在現在常用的深度檢索模型中也經常增加這種人工構造的特征。根據損失函數又可分為pointwise(簡單的分類/回歸損失)、Pairwise(triplet hinge loss,cross-entropy loss)、Listwise。

深度模型

使用query和document的embedding進行端到端學習。可以分為

representation-focused models(用雙塔建模query和document,之后計算二者相似度,雙塔之間無交互,用于召回)

interaction-focused models(金字塔模型,計算每個query token和每個document token的相似度矩陣,用于精排。精排階段還可增加更多特征,如多模態特征、用戶行為特征、知識圖譜等)

3. 預訓練模型在倒排索引中的應用

基于倒排索引的召回方法仍是在第一步召回中必不可少的,因為在第一步召回的時候我們面對的是海量的文檔庫,基于exact-match召回速度很快。但是,其模型capacity不足,所以可以用預訓練模型來對其進行模型增強。

3.1 term re-weighting

代表論文: DeepCT (Deep Contextualized Term Weighting framework: Context-Aware Sentence/Passage Term Importance Estimation For First Stage Retrieval).

普通的exact-match中衡量一個詞在query/document中的重要程度就是通過詞頻(TF)或者TFIDF,或者TFIDF的改進版本--BM25,例如在建立倒排索引的時候,每個term在不同document的重要程度就是用TF來衡量的。

但是,一個詞在兩個document中出現頻率相同,就說明這個詞在兩個document中同樣重要嗎?其實詞的重要程度比詞頻要復雜的多。

所以,可以使用contextualized模型,例如BERT,Elmo等獲得每個詞的 上下文 表示,然后通過簡單的線性回歸模型得到每個詞在document中的重要程度。文檔真實詞語權重的估計如下,這個值作為我們訓練的label:

其中, 是與文檔 d 相關的查詢問題的集合; 是包含詞語 t 的查詢問題集合 的子集; 是文檔 d 中詞語 t 的權重。的取值范圍為,以此為label訓練。這樣,我們就得到了一個詞在document中的重要程度,可以替換原始TF-IDF或BM25的詞頻。對于query,也可以用同樣的方法得到每個詞的重要程度,用來替換TFIDF。

830cc8e6-2d86-11ed-ba43-dac502259ad0.png

3.2 Document expansion

除了去估計不同term在document中的重要程度,還可以直接顯式地擴增document,這樣一來提升了重要詞語的權重,二來也能夠召回"詞不同意同"的文檔(解決lexical-mismatch問題)。

例如,可以對T5在query-document對上做微調,然后對每個document做文本生成,來生成對應的query,再加到document中。之后,照常對這個擴增好的document建倒排索引,用BM25做召回。代表工作:docTTTTTquery[3]

同樣地,也可以對query進行擴增。例如對于QA中的question,可以把訓練目標定為包含答案的句子、或者包含答案的文章title,然后用seq2seq模型訓練,再把模型生成的文本加到query后面,形成擴增的query。

3.3 term reweighting + document expansion

那么,我們可不可以同時做term reweighting和document expansion呢?這方面的代表工作是Sparterm[4]

此模型分為兩部分:重要度預測模塊(用來得到 整個vocab上 的重要程度)和門控模塊(得到二進制的門控信號,以此來得到最終保留的稀疏token,最終只能保留 個token)。由于重要度是針對整個vocab而言的,所以可以同時實現重要度評估+詞語擴增。

8329f038-2d86-11ed-ba43-dac502259ad0.png


重要度預測模塊采用了類似MLM的思想,即先用BERT對句子做好contextualized embedding,然后乘上vocab embedding 矩陣 E ,得到這個詞對應的重要度分布:

這句話整體的重要度分布就是所有詞對應的重要度分布取relu(重要度不能是負數),然后加起來的和:

門控模塊和重要度評估模塊的計算方法類似,只是參數不再是 E , 而是另外的變換矩陣。得到gating distribution G 之后,先將其0/1化為 G' (如果G中元素>threshold則取1,否則取0);然后得到我們需要保留的詞語(exact-match必須保留,還增加一些擴增的token)。

通過端到端的方式訓練,訓練的損失函數有兩個,其中一個就是我們常見的ranking loss,即取 三元組,然后求對比cross-entropy loss。這里的q', p'都是經過重要度評估模塊+門控模塊之后得到的句子表征,因此loss反傳可以對重要度評估模塊和門控模塊進行更新。

8342d22e-2d86-11ed-ba43-dac502259ad0.png

另一個loss專門對門控模塊做更新,訓練數據是對,對于一個document,先得到其門控向量G, 然后去和實際的query進行對比:

836164d2-2d86-11ed-ba43-dac502259ad0.jpg


T為真實query的bag of words




審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 矩陣
    +關注

    關注

    1

    文章

    448

    瀏覽量

    36094
  • 機器學習算法

    關注

    2

    文章

    47

    瀏覽量

    6844

原文標題:總結!語義信息檢索中的預訓練模型

文章出處:【微信號:zenRRan,微信公眾號:深度學習自然語言處理】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    訓練到推理:大模型算力需求的新拐點已至

    模型產業發展的早期階段,行業焦點主要集中模型訓練所需的算力投入。
    的頭像 發表于 02-05 16:07 ?809次閱讀
    從<b class='flag-5'>訓練</b>到推理:大<b class='flag-5'>模型</b>算力需求的新拐點已至

    什么是大模型,智能體...?大模型100問,快速全面了解!

    ,LLM)是大模型中最主要的類,專門用于處理和生成人類語言。大語言模型通過“閱讀”海量的文本數據(如書籍、網頁、文章等)進行訓練,學會語
    的頭像 發表于 02-02 16:36 ?902次閱讀
    什么是大<b class='flag-5'>模型</b>,智能體...?大<b class='flag-5'>模型</b>100問,快速全面了解!

    C語言插入排序算法和代碼

    插入排序排序算法的種,它不改變原有的序列(數組),而是創建新的序列,新序列上進行操作。
    發表于 01-15 06:44

    Ubuntu20.04系統中訓練神經網絡模型些經驗

    本帖欲分享Ubuntu20.04系統中訓練神經網絡模型些經驗。我們采用jupyter notebook作為開發IDE,以TensorFlow2為
    發表于 10-22 07:03

    基于神經網絡的數字失真模型解決方案

    基于神經網絡的數字失真(DPD)模型中,使用不同的激活函數對整個系統性能和能效有何影響?
    的頭像 發表于 08-29 14:01 ?3472次閱讀

    基于大規模人類操作數據訓練的VLA模型H-RDT

    近年來,機器人操作領域的VLA模型普遍基于跨本體機器人數據集訓練,這類方法存在兩大局限:不同機器人本體和動作空間的差異導致統訓練困難;現
    的頭像 發表于 08-21 09:56 ?1102次閱讀
    基于大規模人類操作數據<b class='flag-5'>預</b><b class='flag-5'>訓練</b>的VLA<b class='flag-5'>模型</b>H-RDT

    運行kmodel模型驗證直報錯怎么解決?

    我這運行kmodel模型驗證直報錯,所以沒法做kmodel模型好壞驗證,不知道怎么解決這個問題,重新訓練
    發表于 06-10 08:02

    海思SD3403邊緣計算AI數據訓練概述

    模型,將模型轉化為嵌入式AI模型模型升級AI攝像機,進行AI識別應用。 AI訓練模型是不斷迭
    發表于 04-28 11:11

    模型時代的深度學習框架

    量是約為 25.63M,ImageNet1K數據集上,使用單張消費類顯卡 RTX-4090只需大約35~40小時 ,即可完成ResNet50模型
    的頭像 發表于 04-25 11:43 ?843次閱讀
    大<b class='flag-5'>模型</b>時代的深度學習框架

    恩智浦eIQ Time Series Studio工具使用教程之模型訓練

    大家好,eIQ Time SeriesStudio又和大家見面啦!本章為大家帶來工具核心部分-模型訓練
    的頭像 發表于 03-25 15:25 ?1715次閱讀
    恩智浦eIQ Time Series Studio工具使用教程之<b class='flag-5'>模型</b><b class='flag-5'>訓練</b>

    請問如何在imx8mplus上部署和運行YOLOv5訓練模型

    我正在從事 imx8mplus yocto 項目。我已經自定義數據集上的 YOLOv5 上訓練了對象檢測模型。它在 ubuntu 電腦上運行良好。現在我想在我的 imx8mplus 板上運行該
    發表于 03-25 07:23

    用PaddleNLP為GPT-2模型制作FineWeb二進制訓練數據集

    作者:算力魔方創始人/英特爾創新大使劉力 《用PaddleNLP4060單卡上實踐大模型訓練技術》發布后收到讀者熱烈反響,很多讀者要求進
    的頭像 發表于 03-21 18:24 ?4315次閱讀
    用PaddleNLP為GPT-2<b class='flag-5'>模型</b>制作FineWeb二進制<b class='flag-5'>預</b><b class='flag-5'>訓練</b>數據集

    數據標注服務—奠定大模型訓練的數據基石

    數據標注是大模型訓練過程中不可或缺的基礎環節,其質量直接影響著模型的性能表現。模型訓練中,數
    的頭像 發表于 03-21 10:30 ?3297次閱讀

    憶聯PCIe 5.0 SSD支撐大模型全流程訓練

    到高頻參數迭代,從模型微調到實時推理,大模型運行的每一個環節都需存儲設備“硬指標”與“軟實力”間達成平衡。從產品可靠性視角出發,憶聯新
    的頭像 發表于 03-11 10:26 ?1155次閱讀
    憶聯PCIe 5.0 SSD支撐大<b class='flag-5'>模型</b>全流程<b class='flag-5'>訓練</b>

    訓練好的ai模型導入cubemx不成功怎么處理?

    訓練好的ai模型導入cubemx不成功咋辦,試了好幾個模型壓縮了也不行,ram占用過大,有無解決方案?
    發表于 03-11 07:18