Query CS276A. Incidence vectors. Term-document incidence. Answers to query. Bigger corpora

Similar documents
Lecture 1: Introduction and the Boolean Model

1 Boolean retrieval. Online edition (c)2009 Cambridge UP

Introduction to Information Retrieval

Topics in basic DBMS course

Big Data Technology Map-Reduce Motivation: Indexing in Search Engines

Search and Information Retrieval

This lecture. Introduction to information retrieval. Making money with information retrieval. Some technical basics. Link analysis.

Ngram Search Engine with Patterns Combining Token, POS, Chunk and NE Information

Search Engine Design understanding how algorithms behind search engines are established

1 o Semestre 2007/2008

Information Retrieval System Assigning Context to Documents by Relevance Feedback

A Cost-Benefit Analysis of Indexing Big Data with Map-Reduce

Introduction to Information Retrieval

Note: These activities are suitable for students who don t know a lot (possibly nothing at all) about Shakespeare s writing.

COMP3420: Advanced Databases and Data Mining. Classification and prediction: Introduction and Decision Tree Induction

Similarity Search in a Very Large Scale Using Hadoop and HBase

ifinder ENTERPRISE SEARCH

Clustering Big Data. Anil K. Jain. (with Radha Chitta and Rong Jin) Department of Computer Science Michigan State University November 29, 2012

Chapter 2 The Information Retrieval Process

Introduction to Parallel Programming and MapReduce

Why is Internal Audit so Hard?

Text Analytics Illustrated with a Simple Data Set

Search Result Optimization using Annotators

Search Taxonomy. Web Search. Search Engine Optimization. Information Retrieval

Review of Hashing: Integer Keys

Introduction to IR Systems: Supporting Boolean Text Search. Information Retrieval. IR vs. DBMS. Chapter 27, Part A

Optimization of Search Results with Duplicate Page Elimination using Usage Data A. K. Sharma 1, Neelam Duhan 2 1, 2

Julius Caesar: Act I Reading and Study Guide

TF-IDF. David Kauchak cs160 Fall 2009 adapted from:

TDPA: Trend Detection and Predictive Analytics

11 Multivariate Polynomials

CSCI 5417 Information Retrieval Systems Jim Martin!

CS104: Data Structures and Object-Oriented Design (Fall 2013) October 24, 2013: Priority Queues Scribes: CS 104 Teaching Team

Principles of Data Mining

Statistical Models in Data Mining

Database Systems. Lecture 1: Introduction

8 Square matrices continued: Determinants

Mining Text Data: An Introduction

Performance Analysis of Naive Bayes and J48 Classification Algorithm for Data Classification

The Hadoop Framework

Jeffrey D. Ullman slides. MapReduce for data intensive computing

Recognition. Sanja Fidler CSC420: Intro to Image Understanding 1 / 28

Data Structures Fibonacci Heaps, Amortized Analysis

Web Log Data Sparsity Analysis and Performance Evaluation for OLAP

DATA MINING TECHNOLOGY. Keywords: data mining, data warehouse, knowledge discovery, OLAP, OLAM.

MATRIX ALGEBRA AND SYSTEMS OF EQUATIONS

Storing Measurement Data

Exam in course TDT4215 Web Intelligence - Solutions and guidelines -

Introduction. A. Bellaachia Page: 1

2x + y = 3. Since the second equation is precisely the same as the first equation, it is enough to find x and y satisfying the system

Advanced & Actionable SEO for WordPress. Ryan Erwin Internet Marketing Chicago LLC. Internetmarekting.chicago.com

1 Solving LPs: The Simplex Algorithm of George Dantzig

Concepts of digital forensics

CS 378 Big Data Programming. Lecture 2 Map- Reduce

Social Media and Digital Marketing Analytics ( INFO-UB ) Professor Anindya Ghose Monday Friday 6-9:10 pm from 7/15/13 to 7/30/13

The information contained herein is proprietary to Decision Software, Inc. and is provided solely for the benefit of our customers and potential

The Data Mining Process

An Information Retrieval using weighted Index Terms in Natural Language document collections

Linear Algebra Methods for Data Mining

Julius Caesar Character list and Speeches

CS 2750 Machine Learning. Lecture 1. Machine Learning. CS 2750 Machine Learning.

Computational Geometry. Lecture 1: Introduction and Convex Hulls

CSE373: Data Structures and Algorithms Lecture 1: Introduction; ADTs; Stacks/Queues. Linda Shapiro Spring 2016

CS 378 Big Data Programming

Inmagic Content Server Workgroup Configuration Technical Guidelines

Search Engines. Stephen Shaw 18th of February, Netsoc

Distributed Computing and Big Data: Hadoop and MapReduce

SEARCH ENGINE WITH PARALLEL PROCESSING AND INCREMENTAL K-MEANS FOR FAST SEARCH AND RETRIEVAL

Regular Expressions and Automata using Haskell

(Refer Slide Time: 00:01:16 min)

Web Mining. Margherita Berardi LACAM. Dipartimento di Informatica Università degli Studi di Bari

Electronic Document Management Using Inverted Files System

Large-Scale Data Sets Clustering Based on MapReduce and Hadoop

STUDY GUIDE. Julius Caesar WILLIAM SHAKESPEARE

Mining the Software Change Repository of a Legacy Telephony System

Big Data Processing with Google s MapReduce. Alexandru Costan

Protein Protein Interaction Networks

Lecture 1: Data Storage & Index

Basic indexing pipeline

Hexaware E-book on Predictive Analytics

Web Document Clustering

Information Management

Cost Effective Lexis & Westlaw and Alternatives to Lexis & Westlaw. Sue Altmeyer c 2012

Clustering. Danilo Croce Web Mining & Retrieval a.a. 2015/201 16/03/2016

Large-Scale Test Mining

WebSphere Business Monitor

Files. Files. Files. Files. Files. File Organisation. What s it all about? What s in a file?

Macbeth s early state of mind

6.080/6.089 GITCS Feb 12, Lecture 3

MATH10212 Linear Algebra. Systems of Linear Equations. Definition. An n-dimensional vector is a row or a column of n numbers (or letters): a 1.

Mining Signatures in Healthcare Data Based on Event Sequences and its Applications

Transcription:

CS276A Text Retrieval and Mining Lecture 1 Query Which plays of Shakespeare contain the words AND but NOT? One could grep all of Shakespeare s plays for and, then strip out lines containing? Slow (for large corpora) NOT is non-trivial Other operations (e.g., find the word Romans near countrymen) not feasible Term-document incidence Incidence vectors Antony and Cleopatra Julius The Tempest Hamlet Othello Macbeth Antony 0 0 0 1 0 1 0 0 0 1 0 1 0 0 0 0 Cleopatra 1 0 0 0 0 0 mercy 1 0 So we have a 0/1 vector for each term. To answer query: take the vectors for, and (complemented) bitwise AND. 110100 AND 110111 AND 101111 = 100100. worser 1 0 1 0 AND but NOT 1 if play contains word, 0 otherwise Answers to query Antony and Cleopatra, Act III, Scene ii Agrippa [Aside to DOMITIUS ENOBARBUS]: Why, Enobarbus, When Antony found Julius dead, He cried almost to roaring; and he wept When at Philippi he found slain. Hamlet, Act III, Scene ii Lord Polonius: I did enact Julius I was killed i' the Capitol; killed me. Bigger corpora Consider n = 1M documents, each with about 1K terms. Avg 6 bytes/term incl spaces/punctuation 6GB of data in the documents. Say there are m = 500K distinc terms among these. 1

Can t build the matrix 500K x 1M matrix has half-a-trillion 0 s and 1 s. But it has no more than one billion 1 s. matrix is extremely sparse. Why? What s a better representation? We only record positions. Inverted index For each term T, we must store a list of all documents that contain T. Do we use an array or a list for this? 3 5 8 13 21 34 What happens if the word is added to document 14? Inverted index Linked lists generally preferred to arrays Dynamic space allocation Insertion of terms into documents easy Space overhead of pointers Inverted index construction Documents to be indexed. Tokenizer Friends, Romans, countrymen. Token stream. Friends Romans Countrymen Dictionary 3 5 8 13 21 34 Postings Sorted by docid (more later on why). More on these later. Linguistic modules Modified tokens. friend roman countryman Inverted index. Indexer friend roman countryman 2 4 Indexer steps Sequence of (Modified token, Document ID) pairs. Doc 1 I did enact Julius I was killed i' the Capitol; killed me. Doc 2 So let it be with. The noble hath told you was ambitious hath 2 Sort by terms. Core indexing step. hath 2 hath 1 2

The result is split into a Dictionary file and a Postings file. Multiple term entries in a single document are merged. Frequency information is added. Why frequency? Will discuss later. hath 1 Freq ambitious be brutus brutus capitol caesar 2 did enact hath 2 i' it julius 2 let me noble so the the told you was was with Freq ambitious be brutus brutus capitol caesar 2 did enact hath 2 i' it julius 2 let me noble so the the told you was was with Term N docs Tot Freq ambitious be 2 capitol 3 did enact hath 2 i' it julius 2 let me noble so 2 told you 2 with Doc # Freq 2 2 Where do we pay in storage? The index we just built Terms Term N docs Tot Freq ambitious be 2 capitol 3 did enact hath 2 i' it julius 2 let me noble so 2 told you 2 with Doc # Freq 2 2 Will quantify the storage, later. Today s How do we process a query? focus Later - what kinds of queries can we process? Pointers Query processing Consider processing the query: AND Locate in the Dictionary; Retrieve its postings. Locate in the Dictionary; Retrieve its postings. Merge the two postings: 2 4 8 16 32 64 3 5 8 13 21 128 34 The merge 2 8 Walk through the two postings simultaneously, in time linear in the total number of postings entries 2 4 8 16 32 64 128 3 5 8 13 21 34 If the list lengths are x and y, the merge takes O(x+y) operations. Crucial: postings sorted by docid. 3

Boolean queries: Exact match Example: WestLaw http://www.westlaw.com/ Boolean Queries are queries using AND, OR and NOT together with query terms Views each document as a set of words Is precise: document matches condition or not. Primary commercial retrieval tool for 3 decades. Professional searchers (e.g., lawyers) still like Boolean queries: You know exactly what you re getting. Largest commercial (paying subscribers) legal search service (started 1975; ranking added 1992) About 7 terabytes of data; 700,000 users Majority of users still use boolean queries Example query: What is the statute of limitations in cases involving the federal tort claims act? LIMIT! /3 STATUTE ACTION /S FEDERAL /2 TORT /3 CLAIM Long, precise queries; proximity operators; incrementally developed; not like web search More general merges Exercise: Adapt the merge for the queries: AND NOT OR NOT Can we still run through the merge in time O(x+y)? Merging What about an arbitrary Boolean formula? ( OR ) AND NOT (Antony OR Cleopatra) Can we always merge in linear time? Linear in what? Can we do better? Query optimization Query optimization example What is the best order for query processing? Consider a query that is an AND of terms. For each of the terms, get its postings, then AND together. Process in order of increasing freq: start with smallest set, then keep cutting further. This is why we kept freq in dictionary 3 5 8 16 21 34 3 5 8 13 21 34 Query: AND AND Execute the query as ( AND ) AND. 4

More general optimization Exercise e.g., (madding OR crowd) AND (ignoble OR strife) Get freq s for all terms. Estimate the size of each OR by the sum of its freq s (conservative). Process in increasing order of OR sizes. Recommend a query processing order for (tangerine OR trees) AND (marmalade OR skies) AND (kaleidoscope OR eyes) Term Freq eyes 213312 kaleidoscope 87009 marmalade 107913 skies 271658 tangerine 46653 trees 316812 Query processing exercises If the query is friends AND romans AND (NOT countrymen), how could we use the freq of countrymen? Exercise: Extend the merge to an arbitrary Boolean query. Can we always guarantee execution in time linear in the total postings size? Hint: Begin with the case of a Boolean formula query: the each query term appears only once in the query. Beyond term search What about phrases? Proximity: Find Gates NEAR Microsoft. Need index to capture position information in docs. More later. Zones in documents: Find documents with (author = Ullman) AND (text contains automata). Evidence accumulation 1 vs. 0 occurrence of a search term 2 vs. 1 occurrence 3 vs. 2 occurrences, etc. Need term frequency information in docs Ranking search results Boolean queries give inclusion or exclusion of docs. Need to measure proximity from query to each doc. Whether docs presented to user are singletons, or a group of docs covering various aspects of the query. 5

Structured vs unstructured data Structured data tends to refer to information in tables Employee Manager Salary Smith Jones 50000 Chang Smith 60000 Ivy Smith 50000 Unstructured data Typically refers to free text Allows Keyword queries including operators More sophisticated concept queries e.g., find all web pages dealing with drug abuse Classic model for searching text documents Typically allows numerical range and exact match (for text) queries, e.g., Salary < 60000 AND Manager = Smith. Structured data has been the big commercial success [think, Oracle ] but unstructured data is now becoming dominant in a large and increasing range of activities [think, email, the web] Semi-structured data In fact almost no data is unstructured E.g., this slide has distinctly identified zones such as the Title and Bullets Facilitates semi-structured search such as Title contains data AND Bullets contain search to say nothing of linguistic structure More sophisticated semistructured search Title is about Object Oriented Programming AND Author something like stro*rup where * is the wild-card operator Issues: how do you process about? how do you rank results? The focus of XML search. Clustering and classification Given a set of docs, group them into clusters based on their contents. Given a set of topics, plus a new doc D, decide which topic(s) D belongs to. The web and its challenges Unusual and diverse documents Unusual and diverse users, queries, information needs Beyond terms, exploit ideas from social networks link analysis, clickstreams... 6

Exercise Try the search feature at http://www.rhymezone.com/shakespeare/ Write down five search features you think it could do better Course administrivia Course URL: cs276a.stanford.edu [a.k.a.,http://www.stanford.edu/class/cs276a/] Work/Grading: Problem sets (2) 20% Practical exercises (2) 20% Midterm 20% Final 40% Textbook: No required text Managing Gigabytes best early on Will distribute brief readings Looking ahead to CS276B (winter) Course staff Course organization: two quarter sequence 276A Text Retrieval and Mining We cover all the basic search and machine learning techniques for text Small practical exercises; no big project 276B Web Search and Mining Web search challenges Link analysis, crawling, and other web-specifics (Textual) XML Project Professor: Christopher Manning Office: Gates 158 [new office!] manning@cs.stanford.edu Professor: Prabhakar Raghavan pragh@db.stanford.edu TA: Louis Eisenberg tarheel@stanford.edu In general don t use the above addresses, but: su.class.cs276a (first option) cs276a-aut0405-staff@lists.stanford.edu Resources for today s lecture Managing Gigabytes, Chapter 3.2 Modern Information Retrieval, Chapter 8.2 Shakespeare: http://www.rhymezone.com/shakespeare/ Try the neat browse by keyword sequence feature! Any questions? 7