Information Retrieval - Lec1

IR101

這個系列主要會紀錄自己在 KTH 修習 Information Retrieval System 的一些筆記,備忘用,不會像之前的 Post 那麼詳細,但還是會加點自己的 remark 這樣。

Difference between Database

  1. structured data v.s. unstructured data
  2. deterministic v.s. inexact

DB 處理的對象是滿足選定資料結構的 structured data ,而 IR 則包含了將真實世界中的訊息 (which is unstructured) 轉換成我們容易處理的資料結構之步驟。\
承上,該 parse 成何種資料結構隨著應用場景及需求而不同,又比方說在 query 時, DB 須滿足特定 rule ,而 IR 則是要處理貼近 Natural Language level 的 query,另外,像是計算 document 與 query 的相關程度也隨著需求不同而改變 (which is inexact)。

Remark: In brief, DB 是蘊含在 IR system 中的一個模塊。

Key Idea

Inverted Index

像是參考書背後的索引,會列出哪些名詞在哪些章節、第幾頁出現,在閱讀的時候,可以想成是看到一個 page $\rightarrow$ word/phrase 的 mapping , Inverted Index 則是建構一個反向的 mapping。

Ranking

決定當我們有大量的 return 結果時,該如何以怎樣的排序呈現給使用者。 (Ja… Nowadays, the most successful application of ranking algorithm in the world is Google…lol)

Evaluation

  • Precision
\[ p = \frac{|\text{ret} \, \bigcap \, \text{rel}|}{|\text{ret}|} \]

回傳的結果中,真的有關係的比例

  • Recall
\[ r = \frac{|\text{ret} \, \bigcap \, \text{rel}|}{|\text{rel}|} \]

關於有關連的那些文本,有被回傳結果的比例,實務上是無法計算的(我們不知道相關的文本到底有哪些)

Remark: 這兩個 criteria 其實有點互相矛盾,比方說得到 $100 %$ recall 的一個方法是回傳全部的文本,便可確保沒有漏網之魚 (但這太 87)。而得到僅可能高的precision 的方法則是只回傳那些 $100 %$ 確定關聯的文本 (但如此回傳的量太少,不夠使用者抉擇)

Why IR matter

  • How many times you use Google Search every day? 😉
  • Get high ranking on the returened list is essential (gaming the ranking algorithm…lol)
  • The returened consequence framed our mind to what they show… (which is not a good part, I think)

構建一個 Term-document matrix $M \in \mathbb{R}^{W \times D}$$W$ 為 query 的單詞數, $D$ 為文本數。\
$M[w][d]= $ 𝟙[word $w$ appears in document $d$]

Advantage

Useful, simple, fast and intuitive in doing boolean operation \
(often used in well-defined documents )

Disadvantage

  • How to formulate query (the result can be too many or too few, depending on the query)
  • Lack of ranking of returned result
  • Make a little unreasonable assumption: every terms are equally important

Remark: 一個比較偏 DB 風格的 IR 方法 ,在將 documents 轉成方才定義的那種 term-document matrix 時,丟失了太多資訊。在 query 時處理的也不是那麼貼近 user-friendly 的自然語言。

Implementation

在 Lab 中,我們做了一些改動來實做 Inverted Index (因上述矩陣相當 sparse):

  • 對每個 term 建一個 PostingList (HashMap)
  • PostingList 中的每個 entry ,是一個文本 id 對應到字出現於該文本之位置 (sorted Array)

Dakin -> [{1: 1,2,3},{2: 1,8,9}]...

必須支援以下操作 Intersection, weighted union, Intersection(Neighbor) (下圖範例為 intersection)

可以在 $O(n+m)$ ($n,m$ are the size of 2 posting lists) 解決!

Hardware Issue

可以想見文本和 term 何其多,不太可能單純地全部 load 進 Memory 來處理,在 Lab 中用到的方法是將每個 term 先 hash 到一個 dictionary file,而當中的每個 entry 會指向另一個存 PostingList 的檔案。 (會需要另外存 dictinoary file 之因為 PostingList 大小不一,不知道該給每個 entry 多少空間,而這樣就無法確定 從 term 到記憶體位置的 hash mapping)。

Remark: 這招蠻常用到的…,不管在哪個領域

 
comments powered by Disqus