計算語言學

跨学科研究领域

計算語言學,亦稱電腦語言學(英語:computational linguistics)是一門跨學科的研究領域,試圖找出自然語言的規律,建立運算模型,最終讓電腦能夠像人類般分析,理解和處理自然語言。

過去,計算語言學的研究一般由專門負責利用電腦處理自然語言的計算機科學家進行。由於近年的研究顯示人類語言是超乎想像的複雜,現在的計算語言學研究多由來自不同學科的專家共同進行。一般來說,研究隊伍的成員有電腦學家、語言學家、語言專家(熟悉有關研究項目所要處理的語言的人),以至研究人工智慧認知心理學數學邏輯學等的專家。

計算語言學具有理論和應用的成分。理論計算語言學聚焦於理論語言學與認知科學;應用計算語言學聚焦於模擬人類使用語言的實用成果。[1]

計算語言學協會對於計算語言學的定義是:……從計算的觀點,以科學方法研究語言的學問。計算語言學家關注於提供各種語言學現象的計算模型[2]

起源

計算語言學始於一九五零年代的美國,是人工智慧研究的開端。當時,美國希望能夠利用運算又快又準確的電腦,將大量外語材料瞬間翻譯成英語;研究重點特別放在翻譯俄文寫成的科學技術刊物上,以窺探蘇聯的科技發展。[3]電腦既然比人類運算更快、更準確,當初認為電腦很快就可以開始處理語言。[4]計算與計量方法也曾經用於重建現代語言的早先形式以及將現代語言組成語群。早期的方法例如詞彙統計學語言年代學都證實未成熟、不準確。不過近年來跨領域研究借用生物學,尤其是基因作圖,產生了更精密的分析工具與更可靠的結果。[5]

機器翻譯無法立即產生精確的翻譯,人類語言的自動處理被視為遠比當初所設想的複雜。計算語言學這個新領域於是誕生,從而發展能夠智慧處理語言資料的演算法與軟體。「計算語言學」這個術語是由計算語言學協會計算語言學國際委員會英語International Committee on Computational Linguistics的起始成員大衛•海斯(David G. Hays英語David G. Hays)所創。[6]1960年代,人工智慧出現,計算語言學這個領域成為人工智慧的分支,處理人類層次的理解與自然語言的產出。

為了翻譯一種語言成為另一種語言,發覺必須理解兩種語言的語法,包括詞法句法。為了理解句法,又必須理解語義詞彙表,甚至語用學。因此本來只是兩種語言之間的翻譯,演變成探究如何使用電腦去表述與處理自然語言。[7]

門徑

正如計算語言學可以由不同領域、各個系所的專家進行研究,研究的領域也可以劃分成各樣的主題。下面各節探討橫跨整個領域的一些現有文獻,分為四個區塊:發展語言學,結構語言學,語言產出,以及語言理解。

發展門徑

語言是個人一生中發展出來的認知能力。這個發展過程已有一些檢視的技巧,運用計算是其中一種方法。人類的語言發展英語language development對於計算方法造成一些限制,增加了以其理解語言發展的難度。例如兒童在語言習得期間,大體上只遭逢正面例證,[8]亦即在個人語言發展期間,只接觸到語言正確的形式,而無不正確的形式,這對於做簡單的假說檢定而言資料不足,[9]因此造成了使用計算方法去模擬個人語言發展與習得的界限。

從計算的觀點去模擬語言習得的過程導致了統計語法英語stochastic grammar聯結模型[10]這方面的成果被提議用來作為解釋語言的起源之方法。利用模型已顯示,語言的學習可以隨著兒童發展出更佳的記憶力與更長的注意期間,經由漸進地提供簡單的輸入組合而達成。這同時也解釋了為什麼人類幼兒發展期之長。[11]以上兩個結論都因為該計劃創建的人工神經網絡之優點而得以達成。

嬰兒的語言發展能力也已利用機器人去模擬,[12]以便檢定語言學理論。一個可以如孩童般學習的模型,根據直觀功能的概念而建,映射行動、知覺、與效應,並且連結到口語。重要的是,這些機器人不需要語法結構,而能夠習得字詞與意義之間的關聯,大大地簡化了學習過程。這個模型揭示的訊息,增進了對於語言學發展的理解,必須注意的是,這些訊息只能使用計算方法進行經驗測試。

結構門徑

為了建立更佳語言的計算模型,理解語言的結構至關重要。這個目標,英語已利用計算方法周密地進行研究,以便更佳理解英語在結構層次如何運行。研究語言結構的要件之一是具備大型的語料庫或樣本,計算語言學家才能有足夠的原始資料進行模擬,並且在大量的資料裡,更佳理解任一語言的內在結構。最常引用的語料庫之一是賓大結構樹庫英語Treebank[13]這個語料庫來源多元廣泛,例如IBM的電腦手冊和轉寫的電話談話,包含超過四百五十萬個美式英文字。這個語料庫主要以詞類標記與句法加括(syntactic bracketing)來註釋,並且已產生關於結構的大量實證觀察。

語言結構的理論也已發展,讓計算語言學家能在架構內運用多種方法發展假說,從而增進對語言的理解。關於語法的內化與語言結構,一個原創理論提出了兩種模型,其中學習到的規則與模式,會隨著接觸的頻率而增強。[9]這種模型也留下一個問題有待計算語言學家解答:嬰兒如何能在未學習簡單化語法的情況下,學習特定與異常的語法(喬姆斯基範式)。[9]在這個領域的早期,此類理論的成果設定了研究的方向,對於其茁壯至關重要。

語言結構的資訊可以用於認定兩個類似的語句, 例如近來已證實,根據人類言談模式之中的語言結構,概念的遞歸圖英語recurrence plots可以用來模擬資料並使其圖像化,對於自然語句的相似性,建立起可靠的測量方法。[14]這種技巧對於更進一步探究人類言談的結構,是有力的工具。這個問題不用計算的方法,科學家無法獲得言談資料之中巨量複雜的資訊。

產出門徑

語言產出有兩個同樣複雜的成分:語言內含的資訊,以及流利的產出者所需的技巧。亦即理解只是通訊問題的一半,另一半是系統如何產出語言,計算語言學家在這方面已有非常令人關注的發現。

 
艾倫•圖靈:電腦科學家,提議以圖靈測試測量機器的智慧。

1950年艾倫·圖靈在一篇現在著名的論文裡,提出機器或許有能夠思考的一天。他提議一種「模擬測試」,用來定義機器思考的概念,其中受試者以文字進行兩場談話,一次與真人,一次與模仿人的機器。圖靈提議,如果受試者無法分辨真人與機器之別,或許可以斷定該機器能夠思考。[15]這種測試現今稱為圖靈測試,在人工智慧領域仍是重要概念。

最早期著名的自然交談程式之一是ELIZA,1966年由約瑟夫·維森鮑姆在麻省理工學院發展而成。該程式回答使用者提出的文字陳述或問題時,模擬一位羅傑斯式心理治療師。它看似能夠理解他人輸入的談話並且智慧地回應,但實際上只是執行句型對比的程序,只認得句子裡的幾個關鍵字。其回答是由未知的部分圍繞著轉化的已知單字而組成。以「你似乎厭惡我」舉例而言,ELIZA理解「你」和「我」 ,因而找出「你…我」的基本句型,再把「你」和「我」轉成「我」和「你」,然後回答「為什麼你會認為我厭惡你?」在這個例子裡,ELIZA並不理解「厭惡」這個詞,但不妨礙在這種心理分析的情境下形成一個合理的回答。[16]

文字互動門徑

許多最早期像ELIZA這種簡單的人機互動模式,電腦接受使用者的文字輸入然後產生回答。這種方法使用「關鍵詞擷取英語keyword spotting」:電腦識別使用者打入詞句的類型,再據以回答。

語音互動門徑

最近的科技比較重視語音互動系統。這些系統,例如iOS作業系統的Siri,運用的技巧類似文字系統的句型辨識,只不過使用者的輸入是經由語音辨識。這個語言學的分支,把使用者的語音當作音波來處理,並解釋音質與語言的形式,讓電腦得以辨識使用者的輸入。[17]

理解門徑

現代計算語言學多著重於語言理解。隨著網際網路的擴張,人寫的文字隨處可見,如果有程式能夠理解自然語言,會帶來廣泛、令人振奮的機會,包括改良的搜尋引擎、自動化客服、以及線上教育。

語言理解的早期成果包括應用貝氏統計進行光學字符識別。[18]其它貝氏統計的語言分析應用包括分析《聯邦黨人文集》以決定作者是誰。[19]

理解口語方面,最初是奠基於1960、1970年代信號模擬的成果——分析未知的信號,從中找尋類型,並且根據歷史做出預測。這種信號模擬應用於語言,最早、還算成功的一例是在1989年利用隱馬爾可夫模型達成。[20]這些統計方法更近期被應用在較難的任務,例如主題識別——估計貝氏參數以推斷文件主題為何的機率。[21]

應用

現代計算語言學是門混合的學問,包括計算機科學與程序設計、數學(尤其是統計學)、語言結構、以及自然語言處理。這些領域的結合,發展出辨認語音然後據以執行任務的系統。例如語音識別軟體(蘋果的Siri)、拼字檢查工具、語音合成程式(示範發音或輔助語言障礙者)、以及機器翻譯(谷歌翻譯、WordReference) 。[22]

計算語言學在社交媒體與網際網絡的場域可能特別有助益。例如過濾聊天室與網站的內容必須利用計算語言學,也有許多程序讓家長使用「家長控制英語Parental controls」。計算語言學家也能利用「社交媒體挖掘英語Social media mining」發展出分類與組織內容的程式。例如推特,程式可以根據主題或關鍵字去分類「推文」。[23]計算語言學也能應用於文件檢索與分類。當你在線上搜尋時,出現的文件與網站取決於你鍵入的文字相應的獨特標示。[24]

次領域

計算語言學可以根據語言的媒介與執行的任務區分:語音或文字;分析(識別)或合成(生成)。

語音合成、語音識別

主要包括以下幾個方面:語音編碼(speech coding)、語音識別(speech recognition)、語種識別(language identification)、說話人識別(speaker recognition)或說話人確認(speaker verification)、語義理解(semantics understanding)、語音合成(speech synthesis)等。

在人機互動過程中,經常用到語音識別技術和語音合成技術。

訊息檢索

訊息抽取

問答系統

機器翻譯

機器翻譯的主要方法包括規則機器翻譯實例機器翻譯統計機器翻譯

參考文獻

  1. ^ HANS USZKOREIT. WHAT IS COMPUTATIONALLINGUISTICS?. Computational Linguistics and Phonetics. [2022-01-13]. (原始內容存檔於2022-01-21). 
  2. ^ What is Computational Linguistics?. The Association for Computational Linguistics. [2022-01-13]. (原始內容存檔於2022-01-26). 
  3. ^ John Hutchins. Retrospect and prospect in computer-based translation (PDF). 1999-09-17 [2008-07-04]. (原始內容 (PDF)存檔於2008-04-14) (英語). 
  4. ^ Bostrom, Derrick, 1975: And the Changes To Come, 2007-12-31 [2022-01-13], (原始內容存檔於2022-01-13) 
  5. ^ T. Crowley., C. Bowern. An Introduction to Historical Linguistics. Auckland, N.Z.: Oxford UP, 1992. Print.
  6. ^ Deceased members. ICCL members. [15 November 2017]. (原始內容存檔於2017-05-17). 
  7. ^ Natural Language Processing by Liz Liddy, Eduard Hovy, Jimmy Lin, John Prager, Dragomir Radev, Lucy Vanderwende, Ralph Weischedel (PDF). [2017-12-13]. (原始內容 (PDF)存檔於2017-08-10). 
  8. ^ Bowerman, M. (1988). The "no negative evidence" problem: How do children avoid constructing an overly general grammar. Explaining language universals頁面存檔備份,存於網際網路檔案館).
  9. ^ 9.0 9.1 9.2 Braine, M.D.S. (1971). On two types of models of the internalization of grammars. In D.I. Slobin (Ed.), The ontogenesis of grammar: A theoretical perspective. New York: Academic Press.
  10. ^ Powers, D.M.W. & Turk, C.C.R. (1989). Machine Learning of Natural Language. Springer-Verlag. ISBN 978-0-387-19557-5.
  11. ^ Elman, Jeffrey L. Learning and development in neural networks: the importance of starting small. Cognition. 1993-07, 48 (1): 71–99 [2022-01-13]. doi:10.1016/0010-0277(93)90058-4. (原始內容存檔於2022-03-02) (英語). 
  12. ^ Salvi, G.; Montesano, L.; Bernardino, A.; Santos-Victor, J. Language Bootstrapping: Learning Word Meanings From Perception–Action Association. IEEE Transactions on Systems, Man, and Cybernetics, Part B (Cybernetics). 2012-06, 42 (3): 660–671 [2022-01-13]. ISSN 1083-4419. doi:10.1109/TSMCB.2011.2172420. (原始內容存檔於2022-03-07). 
  13. ^ Marcus, M. & Marcinkiewicz, M. Building a large annotated corpus of English: The Penn Treebank (PDF). Computational linguistics. 1993, 19 (2): 313–330 [2017-12-16]. (原始內容 (PDF)存檔於2017-08-14). 
  14. ^ Angus, D.; Smith, A.; Wiles, J. Conceptual Recurrence Plots: Revealing Patterns in Human Discourse. IEEE Transactions on Visualization and Computer Graphics. 2012-06, 18 (6): 988–997 [2022-01-13]. ISSN 1077-2626. doi:10.1109/TVCG.2011.100. (原始內容存檔於2022-03-08). 
  15. ^ Turing, A. M. I.—COMPUTING MACHINERY AND INTELLIGENCE. Mind. 1950-10-01, LIX (236): 433–460 [2022-01-13]. ISSN 1460-2113. doi:10.1093/mind/LIX.236.433. (原始內容存檔於2020-09-08) (英語). 
  16. ^ Weizenbaum, Joseph. ELIZA—a computer program for the study of natural language communication between man and machine. Communications of the ACM. 1966-01, 9 (1): 36–45 [2022-01-13]. ISSN 0001-0782. doi:10.1145/365153.365168. (原始內容存檔於2022-03-21) (英語). 
  17. ^ Language Files. The Ohio State University Department of Linguistics. 2011: 624–634. ISBN 9780814251799. 
  18. ^ Bledsoe, W. W.; Browning, I. Pattern recognition and reading by machine. Papers presented at the December 1-3, 1959, eastern joint IRE-AIEE-ACM computer conference on - IRE-AIEE-ACM '59 (Eastern) (Boston, Massachusetts: ACM Press). 1959: 225–232. doi:10.1145/1460299.1460326 (英語). 
  19. ^ Mosteller, Frederick; Wallace, David L. Inference in an Authorship Problem. Journal of the American Statistical Association. 1963-06, 58 (302): 275 [2022-01-13]. doi:10.2307/2283270. (原始內容存檔於2022-02-12). 
  20. ^ Rabiner, L. A tutorial on hidden Markov models and selected applications in speech recognition. Proceedings of the IEEE. 1989. doi:10.1109/5.18626. 
  21. ^ Blei, David M.; Ng, Andrew Y.; Jordan, Michael I. Latent dirichlet allocation. The Journal of Machine Learning Research. 2003-03-01, 3 (null): 993–1022 [2022-01-13]. ISSN 1532-4435. doi:10.5555/944919.944937. (原始內容存檔於2022-03-21). 
  22. ^ Careers in Computational Linguistics. California State University. [19 September 2016]. (原始內容存檔於2017-12-21). 
  23. ^ Marujo, Lu s et al. "Automatic Keyword Extraction on Twitter." Language Technologies Institute, Carnegie Melon University, n.d. Web. 19 Sept. 2016.
  24. ^ Computational Linguistics. Stanford Encyclopedia of Philosophy. Feb 26, 2014 [Apr 19, 2017]. (原始內容存檔於2018-04-22). 

延伸閱讀

  • Bates, M. Models of natural language understanding. Proceedings of the National Academy of Sciences of the United States of America. 1995, 92 (22): 9977–9982. doi:10.1073/pnas.92.22.9977. 
  • Steven Bird, Ewan Klein, and Edward Loper (2009). Natural Language Processing with Python. O'Reilly Media. ISBN 978-0-596-51649-9.
  • Daniel Jurafsky and James H. Martin (2008). Speech and Language Processing, 2nd edition. Pearson Prentice Hall. ISBN 978-0-13-187321-6.
  • Mohamed Zakaria KURDI (2016). Natural Language Processing and Computational Linguistics: speech, morphology, and syntax, Volume 1. ISTE-Wiley. ISBN 978-1848218482.
  • Mohamed Zakaria KURDI (2017). Natural Language Processing and Computational Linguistics: semantics, discourse, and applications, Volume 2. ISTE-Wiley. ISBN 978-1848219212.

參見

外部連結