Search Engine Technology (1) Prof. Dragomir R. Radev radev@cs.columbia.edu.

Post on 31-Mar-2015

220 views 1 download

Tags:

Transcript of Search Engine Technology (1) Prof. Dragomir R. Radev radev@cs.columbia.edu.

Search Engine Technology(1)

Prof. Dragomir R. Radev

radev@cs.columbia.edu

SET FALL 2013

…1.Introduction…………

Examples of search engines

• Conventional (library catalog). Search by keyword, title, author, etc.

• Text-based (Lexis-Nexis, Google, Yahoo!).Search by keywords. Limited search using queries in natural language.

• Multimedia (QBIC, WebSeek, SaFe)Search by visual appearance (shapes, colors,… ).

• Question answering systems (Ask, NSIR, Answerbus)Search in (restricted) natural language

• Clustering systems (Vivísimo, Clusty)• Research systems (Lemur, Nutch)

What does it take to build a search engine?

• Decide what to index

• Collect it

• Index it (efficiently)

• Keep the index up to date

• Provide user-friendly query facilities

What else?

• Understand the structure of the web for efficient crawling

• Understand user information needs

• Preprocess text and other unstructured data

• Cluster data

• Classify data

• Evaluate performance

Goals of the course• Understand how search engines work

• Understand the limits of existing search technology

• Learn to appreciate the sheer size of the Web

• Learn to write code for text indexing and retrieval

• Learn about the state of the art in IR research

• Learn to analyze textual and semi-structured data sets

• Learn to appreciate the diversity of texts on the Web

• Learn to evaluate information retrieval

• Learn about standardized document collections

• Learn about text similarity measures

• Learn about semantic dimensionality reduction

• Learn about the idiosyncracies of hyperlinked document collections

• Learn about web crawling

• Learn to use existing software

• Understand the dynamics of the Web by building appropriate mathematical models

• Build working systems that assist users in finding useful information on the Web

Course logistics

• Wednesdays 6:10-7:55 in 410 IAB• Dates:

– Sep 4, 11, 18, 25– Oct 2, 9, 16, 23, 30– Nov 6, 13, 20, 27– Dec 4 + final in mid-December, date TBA

• URL: http://www1.cs.columbia.edu/~cs6998/

• Instructor: Dragomir Radev– Email: radev@cs.columbia.edu – Office hours: TBA

• TAs: Amit Ruparel and Ashlesha Shirbhate– {ar3202, ass2167}@columbia.edu– set_ta@lists.cs.columbia.edu

Course outline

• Classic document retrieval: storing, indexing, retrieval

• Web retrieval: crawling, query processing.

• Text and web mining: classification, clustering

• Network analysis: random graph models, centrality, diameter and clustering coefficient

Syllabus• Introduction. • Queries and Documents. Models of Information retrieval. The

Boolean model. The Vector model. • Document preprocessing. Tokenization. Stemming. The Porter

algorithm. Storing, indexing and searching text. Inverted indexes. • Word distributions. The Zipf distribution. The Benford distribution.

Heap's law. TF*IDF. Vector space similarity and ranking. • Retrieval evaluation. Precision and Recall. F-measure. Reference

collections. The TREC conferences. • Automated indexing/labeling. Compression and coding. Optimal

codes. • String matching. Approximate matching. • Query expansion. Relevance feedback. • Text classification. Naive Bayes. Feature selection. Decision

trees.

Syllabus• Linear classifiers. k-nearest neighbors. Perceptron. Kernel

methods. Maximum-margin classifiers. Support vector machines. Semi-supervised learning.

• Lexical semantics and Wordnet. • Latent semantic indexing. Singular value decomposition. • Vector space clustering. k-means clustering. EM clustering. • Random graph models. Properties of random graphs: clustering

coefficient, betweenness, diameter, giant connected component, degree distribution.

• Social network analysis. Small worlds and scale-free networks. Power law distributions. Centrality.

• Graph-based methods. Harmonic functions. Random walks. • PageRank. Hubs and authorities. Bipartite graphs. HITS. • Models of the Web.

Syllabus• Crawling the web. Webometrics. Measuring the size of the web. The Bow-

tie-method. • Hypertext retrieval. Web-based IR. Document closures. Focused crawling. • Question answering • Burstiness. Self-triggerability • Information extraction • Adversarial IR. Human behavior on the web. • Text summarization

POSSIBLE TOPICS

• Discovering communities, spectral clustering

• Semi-supervised retrieval

• Natural language processing. XML retrieval. Text tiling. Human behavior on the web.

Readings

• required: Information Retrieval by Manning, Schuetze, and Raghavan (http://nlp.stanford.edu/IR-book/information-retrieval-book.html), freely available, hard copy for sale

• optional: Modeling the Internet and the Web: Probabilistic Methods and Algorithms by Pierre Baldi, Paolo Frasconi, Padhraic Smyth, Wiley, 2003, ISBN: 0-470-84906-1 (http://ibook.ics.uci.edu).

• papers from SIGIR, WWW and journals (to be announced in class).

Prerequisites

• Linear algebra: vectors and matrices.• Calculus: Finding extrema of functions.• Probabilities: random variables, discrete and

continuous distributions, Bayes theorem.• Programming: experience with at least one web-

aware programming language such as Perl (highly recommended) or Java in a UNIX environment.

• Required CS account

Course requirements

• Three assignments (30%)– Some of them will be in Perl. The rest can be done in

any appropriate language (e.g. Python or Java). All will involve some data analysis and evaluation.

• Final project (30%)– Research paper or software system.

• Class participation (10%)• Final exam (30%)

Final project format

• Research paper - using the SIGIR format. Students will be in charge of problem formulation, literature survey, hypothesis formulation, experimental design, implementation, and possibly submission to a conference like SIGIR or WWW.

• Software system - develop a working system or API. Students will be responsible for identifying a niche problem, implementing it and deploying it, either on the Web or as an open-source downloadable tool. The system can be either stand alone or an extension to an existing one.

Active research projects

• Scientific paper analysis, bibliometrics• Citation analysis• Question answering• Social media• Political debates• Blogs and rumors• IR for the humanities• Health IR• Collective intelligence• Sentiment analysis and word polarity• Cartoons• Social networks

More project ideas

• Shingling• Build a language identification system.• Participate in the Netflix challenge.• Query log analysis.• Build models of Web evolution.• Information diffusion in blogs or web.• Author-topic models of web pages.• Using the web for machine translation.• News recommendation system.• Compress the text of Wikipedia (losslessly).• Spelling correction using query logs.• Automatic query expansion.

List of projects from the past• Document Closures for Indexing• Tibet - Table Structure Recognition Library• Ruby Blog Memetracker• Sentence decomposition for more accurate information retrieval• Extracting Social Networks from LiveJournal• Google Suggest Programming Project (Java Swing Client and Luce

ne Back-End)• Leveraging Social Networks for Organizing and Browsing Shared P

hotographs• Media Bias and the Political Blogosphere• Measuring Similarity between search queries• Extracting Social Networks and Information about the people within t

hem from Text• LSI + dependency trees

Available corpora• Netflix challenge • AOL query logs • Blogs • Bio papers • AAN • Email • Generifs • Web pages • Political science corpus • VAST • del.icio.us • SMS • News data: aquaint, tdt, nantc, reuters,

setimes, trec, tipster • Europarl multilingual • US congressional data • DMOZ • Pubmedcentral • DUC/TAC

• Timebank• Wikipedia • wt2g/wt10g/wt100g • dotgov • RTE • Paraphrases • GENIA • Generifs • Hansards • IMDB • MTA/MTC • nie • cnnsumm • Poliblog • Sentiment • xml • epinions • Enron

Related courses elsewhere

• Stanford (Chris Manning, Prabhakar Raghavan, and Hinrich Schuetze)

• Cornell (Jon Kleinberg)• CMU (Yiming Yang and Jamie Callan)• UMass (James Allan)• UTexas (Ray Mooney)• Illinois (Chengxiang Zhai)• Johns Hopkins (David Yarowsky)• UNT (Rada Mihalcea)

The size of the World Wide Web

• The size of the indexed world wide web pages (By Sep.4, 2012)– Indexed by Google: about 40 billion pages– Indexed by Bing: about 16.5 billion pages– Indexed by Yahoo: about 4.8 billion pages

http://www.worldwidewebsize.com/

• Twitter hits 400 million tweets per day (June, 2012. Dick Costolo, CEO at Twitter)

• Over 2.5 billion photos uploaded to Facebook each month (2010. blog.facebook.com)

• Google’s clusters process a total of more than 20 petabytes of data per day. (2008. Jeffrey Dean from Google [link])

• 55 Million WordPress Sites in the World

• WordPress.com users produce about 500,000 new posts and 400,000 new comments on an average day

http://en.wordpress.com/stats/

• Dynamically generated content

• New pages get added all the time

• The size of the blogosphere doubles every 6 months

• Yahoo deals with 12TB of data per day (according to Ron Brachman)

SET FALL 2013

…2. Models of Information retrieval The Vector model The Boolean model……

Sample queries (from Excite)In what year did baseball become an offical sport?play station codes . combirth control and depressiongovernment"WorkAbility I"+conferencekitchen applianceswhere can I find a chines rosewoodtiger electronics58 Plymouth FuryHow does the character Seyavash in Ferdowsi's Shahnameh exhibit characteristics of a

hero?emeril LagasseHubbleM.S Subalaksmirunning

Key Terms Used in IR

• QUERY: a representation of what the user is looking for - can be a list of words or a phrase.

• DOCUMENT: an information entity that the user wants to retrieve

• COLLECTION: a set of documents• INDEX: a representation of information that makes

querying easier• TERM: word or concept that appears in a document

or a query

Mappings and abstractions

Reality Data

Information need Query

From Robert Korfhage’s book

Documents

• Not just printed paper

• Can be records, pages, sites, images, people, movies

• Document encoding (Unicode)

• Document representation

• Document preprocessing (e.g., removing metadata)

• Words, terms, types, tokens

Sample query sessions (from AOL)

• toley spies gramestolley spies gamestotally spies games

• tajmahal restaurant brooklyn nytaj mahal restaurant brooklyn nytaj mahal restaurant brooklyn ny 11209

• do you love me like you saydo you love me like you say lyricsdo you love me like you say lyrics marvin gaye

Characteristics of user queries

• Sessions: users revisit their queries.

• Very short queries: typically 2 words long.

• A large number of typos.

• A small number of popular queries. A long tail of infrequent ones.

• Almost no use of advanced query operators with the exception of double quotes

Queries as documents

• Advantages:– Mathematically easier to manage

• Problems:– Different lengths– Syntactic differences– Repetitions of words (or lack thereof)

Document representations

• Term-document matrix (m x n)

• Document-document matrix (n x n)

• Typical example in a medium-sized collection: 3,000,000 documents (n) with 50,000 terms (m)

• Typical example on the Web: n=30,000,000,000, m=1,000,000

• Boolean vs. integer-valued matrices

Storage issues

• Imagine a medium-sized collection with n=3,000,000 and m=50,000

• How large a term-document matrix will be needed?

• Is there any way to do better? Any heuristic?

Tokenizing text

• (CNN) -- A tropical storm has strengthened into Hurricane Leslie in the Atlantic Ocean, forecasters said Wednesday.

• The slow-moving storm could affect Bermuda this weekend, according to the National Hurricane Center in Miami.

• The Category 1 hurricane was churning Wednesday afternoon about 465 miles (750 kilometers) south-southeast of the British territory and moving north at 2 mph (4 kph), the hurricane center said.

http://www.cnn.com/2012/09/05/world/americas/bermuda-hurricane-leslie/index.html

Inverted index

• Instead of an incidence vector, use a posting table

• CLEVELAND: D1, D2, D6• OHIO: D1, D5, D6, D7• Use linked lists to be able to insert new

document postings in order and to remove existing postings.

• Can be used to compute document frequency• Keep everything sorted! This gives you a

logarithmic improvement in access.

Basic operations on inverted indexes

• Conjunction (AND) – iterative merge of the two postings: O(x+y)

• Disjunction (OR) – very similar• Negation (NOT) – can we still do it in

O(x+y)? – Example: MICHIGAN AND NOT OHIO– Example: MICHIGAN OR NOT OHIO

• Recursive operations• Optimization: start with the smallest sets

Major IR models

• Boolean

• Vector

• Probabilistic

• Language modeling

• Fuzzy retrieval

• Latent semantic indexing

The Boolean model

x w y z

D1D2

Venn diagrams

Boolean queries

• Operators: AND, OR, NOT, parentheses• Example:

– CLEVELAND AND NOT OHIO– (MICHIGAN AND INDIANA) OR (TEXAS AND

OKLAHOMA)

• Ambiguous uses of AND and OR in human language– Exclusive vs. inclusive OR– Restrictive operator: AND or OR?

Canonical forms of queries

• De Morgan’s Laws:

NOT (A AND B) = (NOT A) OR (NOT B)

NOT (A OR B) = (NOT A) AND (NOT B)

• Normal forms– Conjunctive normal form (CNF)– Disjunctive normal form (DNF) – Some people swear by CNF - why?

Evaluating Boolean queries

• Incidence vectors:– CLEVELAND: 1100010– OHIO: 1000111

• Examples:– CLEVELAND AND OHIO– CLEVELAND AND NOT OHIO– CLEVALAND OR OHIO

Exercise

• D1 = “computer information retrieval”

• D2 = “computer retrieval”

• D3 = “information”

• D4 = “computer information”

• Q1 = “information AND retrieval”

• Q2 = “information AND NOT computer”

Exercise0

1 Swift

2 Shakespeare

3 Shakespeare Swift

4 Milton

5 Milton Swift

6 Milton Shakespeare

7 Milton Shakespeare Swift

8 Chaucer

9 Chaucer Swift

10 Chaucer Shakespeare

11 Chaucer Shakespeare Swift

12 Chaucer Milton

13 Chaucer Milton Swift

14 Chaucer Milton Shakespeare

15 Chaucer Milton Shakespeare Swift

((chaucer OR milton) AND (NOT swift)) OR ((NOT chaucer) AND (swift OR shakespeare))

SET FALL 2013

…3. Document preprocessing. Tokenization. Stemming. The Porter algorithm. Storing, indexing and searching text.

Inverted indexes.…

Document preprocessing

• Dealing with formatting and encoding issues• Hyphenation, accents, stemming, capitalization• Tokenization:

– USA vs. U.S.A. – equivalence class– Paul’s, Willow Dr., Dr. Willow, 555-1212, New York, ad

hoc, can’t– Example: “The New York-Los Angeles flight”– Hewlett-Packard– numbers, e.g., (888) 555-1313, 1-888-555-1313– dates, e.g., Jan-13-2012, 20120113, 13 January 2012,

01/13/12– MIT, mit (in German)?

Non-English languages

• http://www.kyodo.co.jp/entame/showbiz/2012-09-04_64060/

• ストロベリーナイト• http://ja.wikipedia.org/wiki/

%E3%82%B9%E3%83%88%E3%83%AD%E3%83%99%E3%83%AA%E3%83%BC%E3%83%8A%E3%82%A4%E3%83%88

• http://it.wikipedia.org/wiki/Dorama• http://it.wikipedia.org/wiki/Strawberry_Night• テレビドラマ

Non-English languages

– Arabic:

– Japanese:

(kono hon ha omoi)– German: Lebensversicherungsgesellschaftsangesteller– Chinese: shàng hé– http://www.mandarintools.com/worddict.html– http://en.wiktionary.org/wiki/%D9%83%D8%AA

%D8%A7%D8%A8

كتاب

この本は重い。

尚和

Hiragana, Katakana, Romaji, Kanji

• http://tastymiso.com/japanese-alphabets/113

Document preprocessing

• Normalization:– Casing (cat vs. CAT), the Fed– Stemming (computer, computation)– Soundex– Accent removal – cote in French– Labeled/labelled, extraterrestrial/extra-terrestrial/extra

terrestrial, Qaddafi/Kadhafi/Ghadaffi

• Index reduction– Dropping stop words (“and”, “of”, “to”)– Problematic for “to be or not to be”

Porter’s algorithmExample: the word “duplicatable”

duplicat rule 4duplicate rule 1b1duplic rule 3

The application of another rule in step 4, removing “ic,” cannotbe applied since one rule from each step is allowed to be applied.

More examples:

SSES SS caresses caressIES I ponies poniSS SS caress caressS [blank] cats cat

Porter’s algorithm

Computable Comput

Intervention Intervent

Retrieval Retriev

Document Docum

Representing Repres

Representative Repres

Links

• http://maya.cs.depaul.edu/~classes/ds575/porter.html

• http://www.tartarus.org/~martin/PorterStemmer/def.txt

When does stemming help?

• Camera, cameras?

• Electricity, electrical?

• Operating, operations, operative, operational

• (systems, research, dentistry, plan)

Approximate string matching

• The Soundex algorithm (Odell and Russell)

• Uses:– spelling correction– hash function– non-recoverable

The Soundex algorithm

1. Retain the first letter of the name, and drop all occurrences of a,e,h,I,o,u,w,y in other positions

2. Assign the following numbers to the remaining letters after the first:b,f,p,v : 1

c,g,j,k,q,s,x,z : 2

d,t : 3

l : 4

m n : 5

r : 6

The Soundex algorithm

3. if two or more letters with the same code were adjacent in the original name, omit all but the first

4. Convert to the form “LDDD” by adding terminal zeros or by dropping rightmost digits

Examples:

Euler: E460, Gauss: G200, H416: Hilbert, K530: Knuth, Lloyd: L300

same as Ellery, Ghosh, Heilbronn, Kant, and Ladd

Some problems: Rogers and Rodgers, Sinclair and StClair

Readings

• MRS1, MRS2, MRS3• MRS5 (Zipf), MRS6• MRS7, MRS8