statistical methods in nlp course 8 diana trandab ă ț 2013-2014

54
Statistical Methods in NLP Course 8 Diana Trandabăț 2013-2014

Upload: emma-beasley

Post on 13-Jan-2016

215 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Statistical Methods in NLPCourse 8

Diana Trandabăț2013-2014

Page 2: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Roadmap Introduction to information retrieval

Basics of indexing and retrieval

Inverted indexing

Page 3: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

First, nomenclature… Information retrieval (IR)

Focus on textual information (= text/document retrieval) Other possibilities include image, video, music, …

What do we search? Generically, “collections” Less-frequently used, “corpora”

What do we find? Generically, “documents” Even though we may be referring to web pages, PDFs,

PowerPoint slides, paragraphs, etc.

Page 4: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Information Retrieval Cycle

SourceSelection

Search

Query

Selection

Results

Examination

Documents

Delivery

Information

QueryFormulation

Resource

source reselection

System discoveryVocabulary discoveryConcept discoveryDocument discovery

Page 5: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

The Central Problem in Search

SearcherAuthor

Concepts Concepts

Query Terms Document Terms

Do these represent the same concepts?

“tragic love story” “fateful star-crossed romance”

Page 6: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Abstract IR Architecture

DocumentsQuery

Hits

RepresentationFunction

RepresentationFunction

Query Representation Document Representation

ComparisonFunction Index

offlineonline

document acquisition

(e.g., web crawling)

Page 7: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

How do we represent text? Remember: computers don’t “understand” anything!

“Bag of words” Treat all the words in a document as index terms Assign a “weight” to each term based on “importance”

(or, in simplest case, presence/absence of word) Disregard order, structure, meaning, etc. of the words Simple, yet effective!

Assumptions Term occurrence is independent Document relevance is independent “Words” are well-defined

Page 8: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

What’s a word?

天主教教宗若望保祿二世因感冒再度住進醫院。 這是他今年第二度因同樣的病因住院。 باسم - الناطق ريجيف مارك وقال

قبل - شارون إن اإلسرائيلية الخارجيةبزيارة األولى للمرة وسيقوم الدعوة

المقر طويلة لفترة كانت التي تونس،لبنان من خروجها بعد الفلسطينية التحرير لمنظمة الرسمي

1982عام .

Выступая в Мещанском суде Москвы экс-глава ЮКОСа заявил не совершал ничего противозаконного, в чем обвиняет его генпрокуратура России.

भा�रत सरका�र ने� आर्थि��का सर्वे�क्षण में� विर्वेत्ती�य र्वेर्ष� 2005-06 में� स�त फ़ी�सदी� विर्वेका�स दीर हा�सिसल कारने� का� आकालने विकाय� हा और कार स"धा�र पर ज़ो&र दिदीय�

हा

… 日米連合で台頭中国に対処 アーミテージ前副長官提言

조재영 기자 = 서울시는 25 일 이명박 시장이 `행정중심복합도시 '' 건 설안에 대해 ` 군대라도 동원해 막고싶은 심정 '' 이라고 말했다는 일부 언론의 보도를 부인했다 .

Page 9: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Sample DocumentMcDonald's slims down spuds

Fast-food chain to reduce certain types of fat in its french fries with new cooking oil.

NEW YORK (CNN/Money) - McDonald's Corp. is cutting the amount of "bad" fat in its french fries nearly in half, the fast-food chain said Tuesday as it moves to make all its fried menu items healthier.

But does that mean the popular shoestring fries won't taste the same? The company says no. "It's a win-win for our customers because they are getting the same great french-fry taste along with an even healthier nutrition profile," said Mike Roberts, president of McDonald's USA.

But others are not so sure. McDonald's will not specifically discuss the kind of oil it plans to use, but at least one nutrition expert says playing with the formula could mean a different taste.

Shares of Oak Brook, Ill.-based McDonald's (MCD: down $0.54 to $23.22, Research, Estimates) were lower Tuesday afternoon. It was unclear Tuesday whether competitors Burger King and Wendy's International (WEN: down $0.80 to $34.91, Research, Estimates) would follow suit. Neither company could immediately be reached for comment.

14 × McDonalds

12 × fat

11 × fries

8 × new

7 × french

6 × company, said, nutrition

5 × food, oil, percent, reduce, taste, Tuesday

“Bag of Words”

Page 10: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Information retrieval models

An IR model governs how a document and a query are represented and how the relevance of a document to a user query is defined.

Main models: Boolean model Vector space model Statistical language model etc

10

Page 11: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Boolean model

Each document or query is treated as a “bag” of words or terms. Word sequence is not considered.

Given a collection of documents D, let V = {t1, t2, ..., t|V|} be the set of distinctive words/terms in the collection. V is called the vocabulary.

A weight wij > 0 is associated with each term ti of a document dj ∈ D. For a term that does not appear in document dj, wij = 0.

dj = (w1j, w2j, ..., w|V|j),

11

Page 12: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Boolean model (contd)

Query terms are combined logically using the Boolean operators AND, OR, and NOT. E.g., ((data AND mining) AND (NOT text))

Retrieval Given a Boolean query, the system retrieves every document that

makes the query logically true. Called exact match.

The retrieval results are usually quite poor because term frequency is not considered.

12

Page 13: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Boolean queries: Exact match

• The Boolean retrieval model is being able to ask a query that is a Boolean expression:

– Boolean Queries are queries using AND, OR and NOT to join query terms

• Views each document as a set of words

• Is precise: document matches condition or not.– Perhaps the simplest model to build an IR system on

• Primary commercial retrieval tool for 3 decades. • Many search systems you still use are Boolean:

– Email, library catalog, Mac OS X Spotlight

13

Sec. 1.3

Page 14: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Strengths and Weaknesses Strengths

Precise, if you know the right strategies Precise, if you have an idea of what you’re looking for Implementations are fast and efficient

Weaknesses Users must learn Boolean logic Boolean logic insufficient to capture the richness of language No control over size of result set: either too many hits or none When do you stop reading? All documents in the result set are

considered “equally good” What about partial matches? Documents that “don’t quite match”

the query may be useful also

Page 15: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Vector Space Model

Assumption: Documents that are “close together” in vector space “talk about” the same things

t1

d2

d1

d3

d4

d5

t3

t2

θ

φ

Therefore, retrieve documents based on how close the document is to the query (i.e., similarity ~ “closeness”)

Page 16: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Similarity Metric Use “angle” between the vectors:

Or, more generally, inner products:

n

i ki

n

i ji

n

i kiji

kj

kjkj

ww

ww

dd

ddddsim

1

2,1

2,

1 ,,),(

kj

kj

dd

dd

)cos(

n

i kijikjkj wwddddsim1 ,,),(

Page 17: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Other similarity metrics

i i ikikikiji

ikiji

kj

i ikiji

ikiji

kj

wwww

wwddSim

ww

wwddSim

Dice

) * (

) (),(

similarity Jaccard

) (2),(

similarity

,,2

,2

,

,,

2,

2,

,,

Page 18: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Vector space model

Documents are treated as a “bag” of words or terms.

Each document is represented as a vector.

However, the term weights are no longer 0 or 1. Each term weight is computed based on some variations of TF or TF-IDF scheme.

18

Page 19: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Term Weighting Term weights consist of two components

Local: how important is the term in this document? Global: how important is the term in the collection?

Here’s the intuition: Terms that appear often in a document should get high weights Terms that appear in many documents should get low weights

How do we capture this mathematically? Term frequency (local) Inverse document frequency (global)

Page 20: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

TF - IDF TF-IDF: term frequency-inverse document frequency

weight(t,d) = tf(t,d) * idf(t,D) a numerical statistic that reflects how important a word is to a document

in a corpus. used as a weighting factor in information retrieval and text mining.

Variations of the TF-IDF weighting scheme are often used by search engines as a central tool in scoring and ranking a document's relevance given a user query.

TF-IDF can be successfully used for stop-words filtering in various subject fields including text summarization and classification.

Page 21: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

TF - IDF

Page 22: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

TF - IDF

Page 23: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Retrieval in vector space model

Query q is represented in the same way or slightly differently.

Relevance of di to q: Compare the similarity of query q and document di.

Cosine similarity (the cosine of the angle between the two vectors)

Cosine is also commonly used in text clustering23

Page 24: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

An Example

A document space is defined by three terms: hardware, software, users the vocabulary

A set of documents are defined as: A1=(1, 0, 0), A2=(0, 1, 0), A3=(0, 0, 1) A4=(1, 1, 0), A5=(1, 0, 1), A6=(0, 1, 1) A7=(1, 1, 1) A8=(1, 0, 1). A9=(0, 1, 1)

If the Query is “hardware and software”

what documents should be retrieved?

24

Page 25: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

An Example (cont.)

In Boolean query matching: document A4, A7 will be retrieved (“AND”) retrieved: A1, A2, A4, A5, A6, A7, A8, A9 (“OR”)

In similarity matching (cosine): q=(1, 1, 0) S(q, A1)=0.71, S(q, A2)=0.71, S(q, A3)=0 S(q, A4)=1, S(q, A5)=0.5, S(q, A6)=0.5 S(q, A7)=0.82, S(q, A8)=0.5, S(q, A9)=0.5 Document retrieved set (with ranking)=

• {A4, A7, A1, A2, A5, A6, A8, A9}

25

Page 26: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Constructing Inverted Index (Word Counting)

Documents

InvertedIndex

Bag of Words

case folding, tokenization, stopword removal, stemming

syntax, semantics, word knowledge, etc.

Page 27: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Stopwords removal

• Many of the most frequently used words in a language are useless in IR and text mining – these words are called stop words.– the, of, and, to, ….– Typically about 400 to 500 such words– For an application, an additional domain specific stopwords list may

be constructed• Why do we need to remove stopwords?

– Reduce indexing (or data) file size• stopwords accounts 20-30% of total word counts.

– Improve efficiency and effectiveness• stopwords are not useful for searching or text mining• they may also confuse the retrieval system.

27

Page 28: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Stemming• Techniques used to find out the root/stem of a word.

E.g.,– user engineering – users engineered – used engineer – using

• stem: use engineer

Usefulness:• improving effectiveness of IR and text mining

– matching similar words– Mainly improve recall

• reducing indexing size– combing words with same roots may reduce indexing size as

much as 40-50%.

28

Page 29: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Basic stemming methods

Using a set of rules. E.g., • remove ending

– if a word ends with a consonant other than s, followed by an s, then delete s.– if a word ends in es, drop the s.– if a word ends in ing, delete the ing unless the remaining word

consists only of one letter or of th.– If a word ends with ed, preceded by a consonant, delete the ed

unless this leaves only a single letter.– …...

• transform words– if a word ends with “ies” but not “eies” or “aies” then “ies --> y.”

29

Page 30: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Inverted index

The inverted index of a document collection is basically a data structure that attaches each distinctive term with a list of all documents that

contains the term.

Thus, in retrieval, it takes constant time to find the documents that contains a query term. multiple query terms are also easy handle as we will see soon.

30

Page 31: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

An example

31

Page 32: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Search using inverted index

Given a query q, search has the following steps:• Step 1 (vocabulary search): find each term/word in q in

the inverted index.• Step 2 (results merging): Merge results to find

documents that contain all or some of the words/terms in q.

• Step 3 (Rank score computation): To rank the resulting documents/pages, using,

– content-based ranking– link-based ranking

32

Page 33: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Inverted Index: Boolean Retrieval

one fish, two fishDoc 1

red fish, blue fishDoc 2

cat in the hatDoc 3

11

11

11

11

11

11

1 2 3

11

11

11

4

blueblue

catcat

eggegg

fishfish

greengreen

hamham

hathat

oneone

3

4

1

4

4

3

2

1

blue

cat

egg

fish

green

ham

hat

one

2

green eggs and hamDoc 4

11redred

11twotwo

2red

1two

Page 34: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Boolean Retrieval To execute a Boolean query:

Build query syntax tree

For each clause, look up postings

Traverse postings and apply Boolean operator

Efficiency analysis Postings traversal is linear (assuming sorted postings) Start with shortest posting first

( blue AND fish ) OR ham

blue fish

ANDham

OR

1

2blue

fish 2

Page 35: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Query processing: AND

• Consider processing the query:Brutus AND Caesar– Locate Brutus in the Dictionary;

• Retrieve its postings.

– Locate Caesar in the Dictionary;• Retrieve its postings.

– “Merge” the two postings:

35

128

34

2 4 8 16 32 64

1 2 3 5 8 13

21

Brutus

Caesar

Sec. 1.3

Page 36: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

The merge

• Walk through the two postings simultaneously, in time linear in the total number of postings entries

36

34

1282 4 8 16 32 64

1 2 3 5 8 13 21

128

34

2 4 8 16 32 64

1 2 3 5 8 13 21

Brutus

Caesar2 8

If the list lengths are x and y, the merge takes O(x+y)operations.Crucial: postings sorted by docID.

Sec. 1.3

Page 37: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Intersecting two postings lists(a “merge” algorithm)

37

Page 38: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

2

1

1

2

1

1

1

1

1

1

1

Inverted Index: TF.IDF

22

11

22

11

11

11

1 2 3

11

11

11

4

11

11

11

11

11

11

22

11

tfdf

blueblue

catcat

eggegg

fishfish

greengreen

hamham

hathat

oneone

1

1

1

1

1

1

2

1

blue

cat

egg

fish

green

ham

hat

one

11 11redred

11 11twotwo

1red

1two

one fish, two fishDoc 1

red fish, blue fishDoc 2

cat in the hatDoc 3

green eggs and hamDoc 4

3

4

1

4

4

3

2

1

2

2

1

Page 39: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Positional Indexes Store term position in postings

Supports richer queries (e.g., proximity)

Naturally, leads to larger indexes…

Page 40: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

[2,4]

[3]

[2,4]

[2]

[1]

[1]

[3]

[2]

[1]

[1]

[3]

2

1

1

2

1

1

1

1

1

1

1

Inverted Index: Positional Information

22

11

22

11

11

11

1 2 3

11

11

11

4

11

11

11

11

11

11

22

11

tfdf

blueblue

catcat

eggegg

fishfish

greengreen

hamham

hathat

oneone

1

1

1

1

1

1

2

1

blue

cat

egg

fish

green

ham

hat

one

11 11redred

11 11twotwo

1red

1two

one fish, two fishDoc 1

red fish, blue fishDoc 2

cat in the hatDoc 3

green eggs and hamDoc 4

3

4

1

4

4

3

2

1

2

2

1

Page 41: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Retrieval in a Nutshell Look up postings lists corresponding to query terms

Traverse postings for each query term

Store partial query-document scores

Select top k results to return

Page 42: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

MapReduce The indexing problem

Scalability is critical Must be relatively fast, but need not be real time Fundamentally a batch operation Incremental updates may or may not be important For the web, crawling is a challenge in itself

The retrieval problem Must have sub-second response time For the web, only need relatively few results

Page 43: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

MapReduce: Index Construction Map over all documents

Emit term as key, (docno, tf) as value Emit other information as necessary (e.g., term position)

Sort/shuffle: group postings by term

Reduce Gather and sort the postings (e.g., by docno or tf) Write postings to disk

Page 44: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

1

1

2

1

1

2 2

11

1

11

1

1

1

2

Inverted Indexing with MapReduce

1one

1two

1fish

one fish, two fishDoc 1

2red

2blue

2fish

red fish, blue fishDoc 2

3cat

3hat

cat in the hatDoc 3

1fish 2

1one1two

2red

3cat

2blue

3hat

Shuffle and Sort: aggregate values by keys

Map

Reduce

Page 45: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Inverted Indexing: Pseudo-Code

Page 46: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

[2,4]

[1]

[3]

[1]

[2]

[1]

[1]

[3]

[2]

[3]

[2,4]

[1]

[2,4]

[2,4]

[1]

[3]

1

1

2

1

1

2

1

1

2 2

11

1

11

1

Positional Indexes

1one

1two

1fish

2red

2blue

2fish

3cat

3hat

1fish 2

1one1two

2red

3cat2blue

3hat

Shuffle and Sort: aggregate values by keys

Map

Reduce

one fish, two fishDoc 1

red fish, blue fishDoc 2

cat in the hatDoc 3

Page 47: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Scalability Bottleneck Initial implementation: terms as keys, postings as values

Reducers must buffer all postings associated with key (to sort) What if we run out of memory to buffer postings?

Page 48: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

[2,4]

[9]

[1,8,22]

[23]

[8,41]

[2,9,76]

[2,4]

[9]

[1,8,22]

[23]

[8,41]

[2,9,76]

2

1

3

1

2

3

Another Try…

1fish

9

21

(values)(key)

34

35

80

1fish

9

21

(values)(keys)

34

35

80

fish

fish

fish

fish

fish

How is this different?• Let the framework do the sorting• Term frequency implicitly stored• Directly write postings to disk!

Page 49: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Reachability Query and Transitive Closure Representation

1 2

3 4

6 7 8

5

9

13 10

11

12

14

15

?Query(1,11)

Yes

?Query(3,9)

No

The problem: Given two vertices u and v in a directed graph G, is there a path from u to v ?

Directed Graph DAG (directed acyclic graph) by coalescing the strongly connected components

Page 50: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

MapReduce it? The indexing problem

Scalability is paramount Must be relatively fast, but need not be real time Fundamentally a batch operation Incremental updates may or may not be important For the web, crawling is a challenge in itself

The retrieval problem Must have sub-second response time For the web, only need relatively few results

Just covered

Now

Page 51: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Retrieval with MapReduce? MapReduce is fundamentally batch-oriented

Optimized for throughput, not latency Startup of mappers and reducers is expensive

MapReduce is not suitable for real-time queries! Use separate infrastructure for retrieval…

Page 52: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Term vs. Document Partitioning

T

D

T1

T2

T3

D

T…

D1 D2 D3

Term Partitioning

DocumentPartitioning

Page 53: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Katta Architecture(Distributed Lucene)

http://katta.sourceforge.net/

Page 54: Statistical Methods in NLP Course 8 Diana Trandab ă ț 2013-2014

Great!

See you tomorrow!