0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何對typo 進行檢測和糾正

深度學(xué)習(xí)自然語言處理 ? 來源:瀾舟科技 ? 作者:瀾舟科技 ? 2022-07-13 14:38 ? 次閱讀

寫在前面

自然語言文本中經(jīng)常會出現(xiàn)一些拼寫錯誤(typo),在中文文本里即所謂的錯別字,中文拼寫糾錯(Chinese Spelling Correction,CSC)可以對中文文本中的 typo 進行檢測和糾正。拼寫糾錯在諸多 NLP 任務(wù)和應(yīng)用中都有重要作用,如 OCR、語音識別和搜索引擎等。在 NLP 任務(wù)和日常工作生活場景中,中文文本中的 typo 主要是拼音和字形相似導(dǎo)致的,示例如表 1 所示。

c7507018-01c9-11ed-ba43-dac502259ad0.png

表 1

一般 CSC 系統(tǒng)的輸入和輸出序列長度相同,所以現(xiàn)在 CSC 系統(tǒng)主要采用基于 BERT 的非自回歸生成模型,這些模型依據(jù)輸入序列中的所有字符來平行生成每個位置的字符,而隨著 BERT 等預(yù)訓(xùn)練模型的成功,CSC 模型的性能也有了極大的提升。

雖然 BERT 模型很強大,但其在解決 CSC 任務(wù)時也會遇到一些問題。

首先,基于 BERT 的 CSC 模型根據(jù) typo 本身及其上下文對該處 typo 進行檢測和糾正,但當(dāng)一個句子中有多處拼寫錯誤(multi-typo)時,則句子中每個字符的上下文都至少包含一處 typo,這導(dǎo)致其信息中含有噪聲,從而影響模型的效果。論文統(tǒng)計了中文拼寫糾錯任務(wù) SIGHAN13、14、15 的測試集中的 multi-typo 數(shù)據(jù),如表 2 所示,并且把這些數(shù)據(jù)抽出做成測試集,測試模型對 multi-typo 文本的糾錯能力,結(jié)果如表 3 所示(character-level),結(jié)果證實了上述結(jié)論。

其次,BERT 是掩碼語言模型,其從大規(guī)模語料中學(xué)習(xí)怎樣根據(jù)上下文恢復(fù)被遮掩的 token,但對于一個被遮掩的位置可能有多個有效的字符,這時候 BERT 模型則會傾向于恢復(fù)成最常見的那一個,而在 CSC 任務(wù)中,則表現(xiàn)為模型可能會把一個有效的表述改成另外一種更常見的表述,比如將“這并非是說……”改成“這并不是說……”。

c76ce52c-01c9-11ed-ba43-dac502259ad0.png

表 2

c79924de-01c9-11ed-ba43-dac502259ad0.png

表 3

針對上述的兩個問題,來自騰訊 AI 平臺部門和北京大學(xué)的研究人員提出了一種名為 CRASpell 的解決方法,讓我們一起來看看吧。

論文標(biāo)題

CRASpell: A Contextual Typo Robust Approach to Improve Chinese Spelling Correction

論文作者

Shulin Liu, Shengkang Song, Tianchi Yue, Tao Yang, Huihui Cai, Tinghao Yu, Shengli Sun

作者單位

Tencent AI Platform Department, China

Peking University, China

論文鏈接

https://aclanthology.org/2022.findings-acl.237/

項目代碼

https://github.com/liushulinle/CRASpell

CRASpell 介紹

該論文將 multi-typo 降低模型性能的問題稱作 Contextual Typo Disturbance,將模型對文本不必要的糾正稱為 Overcorrection,并針對這兩個問題提出了 CRASpell 模型,其結(jié)構(gòu)如圖 1 所示:

c7cf88a8-01c9-11ed-ba43-dac502259ad0.png

圖 1

由圖 1 我們可以看到,CRASpell 主要分為兩部分,左邊為 Correction Module,右邊為 Noise Modeling Module。

1. Correction Module

Correction Module 中,Transformer Encoder 加 Generative Block 就是一個基本的 CSC 模型,Generative Block 計算并輸出一個 generative distribution,其過程可以描述為:

(1)

論文中使用 copy mechanism [1-2] 來解決 Overcorrection 的問題,其對于輸入序列中的每一個 token,都有一個 one-shot 向量的 copy distribution,其形式可以描述為:

(2)

Copy Block 則是用來輸出一個 copy probability,計算過程如下:

(3)

然后以 copy probability 為權(quán)重,將 copy distribution 和 generative distribution 相加作為最后輸出,這樣相當(dāng)于給輸入的 token 額外加上了一個偏重,讓模型更加傾向于保留原來的 token:

(4)

2. Noise Modeling Module

針對 Contextual Typo Disturbance 問題,CRASpell 提出了 Noise Modeling Module,其思想是訓(xùn)練模型在原始上下文和有噪聲的上下文中輸出相似的概率分布。

Noise Modeling Module 的結(jié)構(gòu)也是 Transformer Encoder 加 Generative Block,不同的是其前面還有一個 Noisy Block,其通過替換的方式在 typo 的上下文中插入噪聲,而噪聲上下文的質(zhì)量又受到兩個因素的影響:

a. 插入噪聲的位置

作者根據(jù)表 3 的實驗結(jié)果,決定在 typo 周圍 個字符內(nèi)選擇, 時如圖 2 所示,如果句子中沒有錯誤或者選擇的位置正好是一處 typo,則不插入噪聲。

c7ff6dde-01c9-11ed-ba43-dac502259ad0.png

圖 2

b. 應(yīng)該替換成什么字符

論文中使用公開的混淆集(confusion set)[3],將選擇位置上的字符替換成其相似字符,這也是 CSC 任務(wù)中制作偽數(shù)據(jù)的常用方法,不同類型字符的替換比例為:70%近音字、15%近形字以及 15%隨機選擇的字符。

原始輸入經(jīng)過 Noisy Block 插入噪聲后得到新的輸入,經(jīng)過 Noise Modeling Module 后的輸出為 , 最后將其與 Correction Module 中的 generative distribution 共同計算 KL 散度損失:

(5)

在 Correction Module 中,給定訓(xùn)練樣本 (X, Y),對于式 (4) 中的 ,其每個位置的 token 的 loss 為:

(6)

結(jié)合式 (5) 和式 (6),得到整個模型訓(xùn)練的損失函數(shù)為:

(7)

(8)

這里我們可以看到,Noise Modeling Module 只在訓(xùn)練時被用到,而插入噪聲的位置沒有計算在 loss 內(nèi),這樣做是為了不改變訓(xùn)練過程中數(shù)據(jù)里 typo 的數(shù)量,讓插入的噪聲只起到改變上下文信息的作用。

實驗設(shè)置和結(jié)果

數(shù)據(jù)集方面,論文中的訓(xùn)練集包括 10K 人工標(biāo)注的 SIGHAN 數(shù)據(jù) [3-5],加上 271K 的自動生成的數(shù)據(jù) [6],測試集使用的是 SIGHAN15 的測試集,另外作者還抽取了 SIGHAN15 測試集中所有的 multi-typo 數(shù)據(jù)以及相同數(shù)量的 negative(不含 typo)數(shù)據(jù),組成了 multi-typo 測試集,如表 4 所示。指標(biāo)采用了 character-level 的 precision、recall 和 F1 分?jǐn)?shù),即預(yù)測對一個 typo 標(biāo)簽算一個正確的預(yù)測結(jié)果,這樣更能體現(xiàn)論文提出的方法對 multi-typo 的提升效果。

c81e0848-01c9-11ed-ba43-dac502259ad0.png

表 4

基線模型:

SoftMask:提出 soft-masking 策略提升 BERT 的錯誤檢測性能;

SpellGCN:將 GCN 與 BERT 結(jié)合對字符間的關(guān)系進行建模;

Tail2Tail:基于 BERT 的模型,但把解碼器換成了 CRF;

cBERT:論文作者發(fā)表于 2021 年的工作,用 CSC 數(shù)據(jù)進行預(yù)訓(xùn)練的 BERT,論文提出的 CRASpell 模型也用 cBERT 進行初始化;

PLOME:與 cBERT 相同,但另外融合了從拼音和筆畫獲取的發(fā)音和字形特征;

cBERTCopy:將 copy mechanism 應(yīng)用在 cBERT 上;

cBERTNoise:將 Noise Modeling Module 應(yīng)用在 cBERT 上;

cBERTRdrop:基于 cBERT 實現(xiàn)的 Rdrop 方法 [7]。

1. Main Results

c843c0c4-01c9-11ed-ba43-dac502259ad0.png

表 5

我們可以從表 5 中看到,Noise Modeling Module 和 copy mechanism 都能提升模型性能,使用了 Noise Modeling Module 的 cBERTNoise 和 CRASpell 在 multi-typo 測試集上均取得了優(yōu)于其他方法的結(jié)果(Correction-level 的 Precision 高于 Detection-level,是因為其分母是在 ground-truth 范圍內(nèi)的預(yù)測標(biāo)簽的數(shù)量,而不是所有預(yù)測標(biāo)簽的數(shù)量),而另外還使用了 copy mechanism 的 CRASpell 則在兩個測試集都取得了最好結(jié)果。作者也從 SIGHAN14 的測試集中篩選出了一個 multi-typo 測試集,結(jié)果如表 6 所示。

c8829eac-01c9-11ed-ba43-dac502259ad0.png

表6

2. Effects of Different Replaced Positions

論文中對比了 Noisy Block 在輸入句子中選擇插入噪聲位置的兩種方式:

在整個句子中隨機選擇

在 typo 附近選擇結(jié)果如表 7 所示,作者還在測試集的數(shù)據(jù)中插入噪聲,測試噪聲與 typo 的距離對結(jié)果的影響,結(jié)果如圖 3 所示,兩組實驗的結(jié)果都表明距離 typo 較近的噪聲對模型的性能影響較大。

c8ad8f2c-01c9-11ed-ba43-dac502259ad0.png

表 7

c8cc35a8-01c9-11ed-ba43-dac502259ad0.png

圖 3

3. Effects of Different Replaced Characters & the Copy Block

表 8 展示了插入噪聲的兩種方法:隨機從詞典中選取和從 confusion set 中選取的結(jié)果,可以看出 confusion set 的效果更好,因為從 confusion set 中選取的近音、近形字更接近實際場景下的 typo。Copy Block 被用來減少 BERT 模型對有效字符的修改,從表 9 可以看出其對 BERT 模型性能的提升,cBERT 因為在 CSC 數(shù)據(jù)上預(yù)訓(xùn)練過,所以 Copy Block 對其提升幅度較小。

c90c9c92-01c9-11ed-ba43-dac502259ad0.png

表 8

c92efb20-01c9-11ed-ba43-dac502259ad0.png

表 9

4. Comparison of Different Methods for Multi-typo Texts

作者為了展示 Noise Modeling Module 對模型的提升,另外實現(xiàn)了兩種基于 cBERT 的方法:

MultiRound:用 cBERT 對輸入進行多輪預(yù)測,直至不再修改;

NoiseTrain:用 Noise Block 生成的數(shù)據(jù)訓(xùn)練 cBERT,插入噪聲的位置也參與 loss 計算。結(jié)果如表 10 所示,可以看出 NoiseTrain 提升效果最差,作者猜測是因為插入的噪聲使訓(xùn)練數(shù)據(jù)中 typo 數(shù)量增加,且質(zhì)量偏低,從而導(dǎo)致模型在 single-typo 和 zero-typo 的數(shù)據(jù)上的效果變差,而 Noise Modeling Module 中插入的噪聲只作為上下文,不參與 loss 計算,作者認(rèn)為這是導(dǎo)致結(jié)果差別巨大的關(guān)鍵所在。

c9534aac-01c9-11ed-ba43-dac502259ad0.png

表 10

總結(jié)

針對之前 CSC 模型的兩個限制:Contextual Typo Disturbance 和 Overcorrection,這篇論文提出了一種新的拼寫糾錯模型。針對第一個問題,論文提出了 Noise Modeling Module,在訓(xùn)練過程中生成含噪聲的上下文,該方法有效地提升了模型在 multi-typo 文本上的糾錯效果。針對 Overcorrection 問題,論文將 Copy Block 與 CSC 模型結(jié)合,訓(xùn)練模型在原字符有效的情況下盡量不進行修改。最終,該方法也是在 SIGHAN15 任務(wù)上取得了新的 SOTA。

原文標(biāo)題:文本糾錯 | 怎樣改善模型對 multi-typo 的糾正效果?

文章出處:【微信公眾號:深度學(xué)習(xí)自然語言處理】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

審核編輯:彭靜
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    6808

    瀏覽量

    88743
  • 模型
    +關(guān)注

    關(guān)注

    1

    文章

    3112

    瀏覽量

    48658
  • 自然語言
    +關(guān)注

    關(guān)注

    1

    文章

    285

    瀏覽量

    13320

原文標(biāo)題:文本糾錯 | 怎樣改善模型對 multi-typo 的糾正效果?

文章出處:【微信號:zenRRan,微信公眾號:深度學(xué)習(xí)自然語言處理】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    針對雷擊浪涌可采用哪些元器件進行檢測

    針對雷擊浪涌,可采用的檢測元器件多種多樣,這些元器件在電子設(shè)備防雷保護中扮演著關(guān)鍵角色。以下是對幾種主要元器件的介紹: 1. 氣體放電管(GDT) 定義與特性 : 氣體放電管是一種用于防雷擊的高性能
    的頭像 發(fā)表于 10-06 16:31 ?224次閱讀

    使用OPA2846運放進行檢波遇到的疑問求解

    使用OPA2846進行檢波的時候,仿真輸出檢波信號噪聲峰峰值約為不到1mV,實際電路信號噪聲峰峰值在200mV內(nèi);把該電路的運放換為LF412進行檢波,仿真輸出信號噪聲峰峰值約為250mV,實際電路信號噪聲
    發(fā)表于 08-30 07:53

    如何進行IP檢測

    如何避免網(wǎng)絡(luò)出現(xiàn)故障,增強網(wǎng)絡(luò)安全性?又如何更加合理的規(guī)劃分配網(wǎng)絡(luò)資源?這就不得的提到我們需要定期給自家或企業(yè)中的IP進行檢測了。IP 地址就像是網(wǎng)絡(luò)世界中設(shè)備的“身份證號碼”,定時進行檢測,能夠
    的頭像 發(fā)表于 07-26 14:09 ?428次閱讀
    如何<b class='flag-5'>進行</b>IP<b class='flag-5'>檢測</b>

    沖壓模具如何實現(xiàn)視覺在線檢測?

    視覺檢測系統(tǒng)是一種利用機器視覺技術(shù)對沖壓模具和沖壓件進行檢測的方法。通過使用高精度的相機和光源,對沖壓件進行拍攝,然后通過圖像處理和算法分析,對沖壓件的質(zhì)量進行檢測和評估。對沖壓件
    的頭像 發(fā)表于 06-03 17:43 ?631次閱讀

    微波檢測的原理是什么 微波檢測的特點

    微波檢測是一種利用微波技術(shù)對物體進行檢測的方法。它在許多領(lǐng)域,如通信、遙感、工業(yè)過程控制等具有廣泛的應(yīng)用。本文將詳細(xì)介紹微波檢測的原理、特點以及應(yīng)用。 微波檢測的原理 微波
    的頭像 發(fā)表于 05-28 14:42 ?1318次閱讀

    為什么說“AOI檢測”是SMT焊接質(zhì)量的把關(guān)者?

    是在SMT生產(chǎn)線上的板子經(jīng)過AOI設(shè)備時,對板子進行實時檢測,以便及時發(fā)現(xiàn)和糾正問題;而離線AOI檢測則是對已經(jīng)下線的板子進行檢測,發(fā)現(xiàn)問題
    發(fā)表于 04-25 11:56

    基于糾正措施系統(tǒng)(FRACAS)的關(guān)鍵技術(shù)

    故障報告,分析和糾正措施系統(tǒng)是一種系統(tǒng)的方法,用于從一個或多個來源收集失效數(shù)據(jù),針對根本原因?qū)?shù)據(jù)進行匯編和分析以及識別糾正措施。
    的頭像 發(fā)表于 02-20 10:34 ?1330次閱讀

    如何檢測變頻器中電容好壞

    檢測變頻器中電容好壞時,常用的檢測方法有三種:一種是采用電容表進行檢測;二是采用指針萬用表進行檢測;三是采用電橋進行檢測。
    發(fā)表于 02-06 11:22 ?1039次閱讀

    安泰ATA-2082高壓放大器如何驅(qū)動超聲探頭進行無損檢測

    無損檢測技術(shù)是一種在不破壞或影響被檢測物體性能的前提下,通過物理或化學(xué)方法對其內(nèi)部或表面的缺陷進行檢測的技術(shù)。在無損檢測領(lǐng)域,超聲檢測是一種
    的頭像 發(fā)表于 01-24 17:29 ?411次閱讀
    安泰ATA-2082高壓放大器如何驅(qū)動超聲探頭<b class='flag-5'>進行</b>無損<b class='flag-5'>檢測</b>

    高壓氣密性檢測儀的檢測步驟

    高壓氣密性檢測儀是一種用于檢測容器、管道等設(shè)備氣密性和壓力的設(shè)備。它可以在不破壞設(shè)備的情況下進行檢測,具有高效、準(zhǔn)確的特點。下面介紹高壓氣密性檢測儀的
    的頭像 發(fā)表于 01-10 10:50 ?697次閱讀
    高壓氣密性<b class='flag-5'>檢測</b>儀的<b class='flag-5'>檢測</b>步驟

    如何糾正三相電源相序

    。下面將通過詳細(xì)討論相序錯誤的原因、檢測糾正方法,以及在實際應(yīng)用中的注意事項,來幫助讀者深入了解如何糾正相序錯誤。 首先,我們需要明確相序錯誤的原因。相序錯誤通常發(fā)生在電氣系統(tǒng)中的三相電源供電電纜的接線錯誤或者設(shè)
    的頭像 發(fā)表于 01-04 14:30 ?5304次閱讀

    ADAS1000-3導(dǎo)聯(lián)脫落的時候是如何被各個通道中的比較器檢測到的?

    ADAS1000-3集成芯片,在導(dǎo)聯(lián)脫落檢測的時候有些不太明白。我們用的是直流導(dǎo)聯(lián)脫落檢測。當(dāng)導(dǎo)聯(lián)脫落的時候是如何被各個通道中的比較器檢測到的?以及在軟件上面如何進行檢測方面不是很明白
    發(fā)表于 12-19 07:11

    如何使用示波器探頭對被測電路進行檢測

    對電路信號進行檢測之前首先要知道被測電路是什么電路,被測信號是什么信號。盲目地測試或者使用不正確的測量方法,有可能得到錯誤的波形甚至損壞儀器危及安全。1什么是差分信號?什么是單端信號?差分傳輸是一種
    的頭像 發(fā)表于 12-08 16:14 ?843次閱讀
    如何使用示波器探頭對被測電路<b class='flag-5'>進行檢測</b>

    使用AD9914進行相位糾正功能的疑惑求解答

    最近使用AD9914進行相位糾正功能實現(xiàn)。存在一些疑惑: 對于預(yù)設(shè)的16位相位偏移字(POW)在送入AD9914執(zhí)行后,對于輸出的波形,請問是會出現(xiàn) 相位截斷類型的波形(我在示波器上沒能捕捉到)(圖1),還是產(chǎn)生類似頻率增長(相位累加器斜率增加)的波形(圖2)快速追到補償
    發(fā)表于 12-05 08:26

    AD8495能對E型和J型熱電偶進行檢測嗎?

    大家好! 本人正在使用AD8495對熱電偶溫度進行檢測。 由于項目要求能夠檢測電路能夠在K、J、E的熱電偶中通用,并且考慮到目前一級代理E絡(luò)盟不再繼續(xù)采購AD8496(針對J型)使得AD8496價格
    發(fā)表于 11-21 07:21