CS276A Text Information Retrieval, Mining, and Exploitation

Slides:



Advertisements
Similar presentations
Introduction to Information Retrieval Introduction to Information Retrieval Lecture 7: Scoring and results assembly.
Advertisements

3D Geometry for Computer Graphics
Text Databases Text Types
Dimensionality Reduction PCA -- SVD
Information Retrieval Lecture 6bis. Recap: tf-idf weighting The tf-idf weight of a term is the product of its tf weight and its idf weight. Best known.
From last time What’s the real point of using vector spaces?: A user’s query can be viewed as a (very) short document. Query becomes a vector in the same.
What is missing? Reasons that ideal effectiveness hard to achieve: 1. Users’ inability to describe queries precisely. 2. Document representation loses.
Hinrich Schütze and Christina Lioma
CS347 Lecture 4 April 18, 2001 ©Prabhakar Raghavan.
1 Latent Semantic Indexing Jieping Ye Department of Computer Science & Engineering Arizona State University
1 Algorithms for Large Data Sets Ziv Bar-Yossef Lecture 4 March 30, 2005
TFIDF-space  An obvious way to combine TF-IDF: the coordinate of document in axis is given by  General form of consists of three parts: Local weight.
Vector Space Model Any text object can be represented by a term vector Examples: Documents, queries, sentences, …. A query is viewed as a short document.
1/ 30. Problems for classical IR models Introduction & Background(LSI,SVD,..etc) Example Standard query method Analysis standard query method Seeking.
Introduction to Information Retrieval Introduction to Information Retrieval Hinrich Schütze and Christina Lioma Lecture 7: Scores in a Complete Search.
The Terms that You Have to Know! Basis, Linear independent, Orthogonal Column space, Row space, Rank Linear combination Linear transformation Inner product.
Introduction to Information Retrieval Introduction to Information Retrieval Hinrich Schütze and Christina Lioma Lecture 18: Latent Semantic Indexing 1.
1 Algorithms for Large Data Sets Ziv Bar-Yossef Lecture 6 May 7, 2006
Information Retrieval IR 6. Recap of the last lecture Parametric and field searches Zones in documents Scoring documents: zone weighting Index support.
Lecture 20 SVD and Its Applications Shang-Hua Teng.
E.G.M. PetrakisDimensionality Reduction1  Given N vectors in n dims, find the k most important axes to project them  k is user defined (k < n)  Applications:
DATA MINING LECTURE 7 Dimensionality Reduction PCA – SVD
Information Retrieval Latent Semantic Indexing. Speeding up cosine computation What if we could take our vectors and “pack” them into fewer dimensions.
Linear Algebra Review By Tim K. Marks UCSD Borrows heavily from: Jana Kosecka Virginia de Sa (UCSD) Cogsci 108F Linear.
CSCI 5417 Information Retrieval Systems Jim Martin Lecture 6 9/8/2011.
CS276A Information Retrieval Lecture 7. Recap of the last lecture Parametric and field searches Zones in documents Scoring documents: zone weighting Index.
CS276A Text Information Retrieval, Mining, and Exploitation Lecture 4 15 Oct 2002.
Documents as vectors Each doc j can be viewed as a vector of tf.idf values, one component for each term So we have a vector space terms are axes docs live.
Latent Semantic Indexing (mapping onto a smaller space of latent concepts) Paolo Ferragina Dipartimento di Informatica Università di Pisa Reading 18.
Chapter 2 Dimensionality Reduction. Linear Methods
1 Vector Space Model Rong Jin. 2 Basic Issues in A Retrieval Model How to represent text objects What similarity function should be used? How to refine.
CS246 Topic-Based Models. Motivation  Q: For query “car”, will a document with the word “automobile” be returned as a result under the TF-IDF vector.
Latent Semantic Indexing Debapriyo Majumdar Information Retrieval – Spring 2015 Indian Statistical Institute Kolkata.
Information Retrieval Lecture 6. Recap of the last lecture Parametric and field searches Zones in documents Scoring documents: zone weighting Index support.
CpSc 881: Information Retrieval. 2 Recall: Term-document matrix This matrix is the basis for computing the similarity between documents and queries. Today:
Latent Semantic Indexing: A probabilistic Analysis Christos Papadimitriou Prabhakar Raghavan, Hisao Tamaki, Santosh Vempala.
SINGULAR VALUE DECOMPOSITION (SVD)
Review of Linear Algebra Optimization 1/16/08 Recitation Joseph Bradley.
ITCS 6265 Information Retrieval & Web Mining Lecture 16 Latent semantic indexing Thanks to Thomas Hofmann for some slides.
Web Search and Data Mining Lecture 4 Adapted from Manning, Raghavan and Schuetze.
CS276 Information Retrieval and Web Search Lecture 7: Vector space retrieval.
Term weighting and Vector space retrieval
1 Objective To provide background material in support of topics in Digital Image Processing that are based on matrices and/or vectors. Review Matrices.
Information Retrieval and Web Search Lecture 7: Vector space retrieval.
CS246 Linear Algebra Review. A Brief Review of Linear Algebra Vector and a list of numbers Addition Scalar multiplication Dot product Dot product as a.
Prof. Paolo Ferragina, Algoritmi per "Information Retrieval"
Information Retrieval and Web Search
Packing to fewer dimensions
Prof. Paolo Ferragina, Algoritmi per "Information Retrieval"
Information Retrieval and Web Search
Lecture: Face Recognition and Feature Reduction
LSI, SVD and Data Management
Packing to fewer dimensions
Singular Value Decomposition
Lecture 21 SVD and Latent Semantic Indexing and Dimensional Reduction
SVD: Physical Interpretation and Applications
Representation of documents and queries
Chapter 3 Linear Algebra
8. Efficient Scoring Most slides were adapted from Stanford CS 276 course and University of Munich IR course.
Feature space tansformation methods
Prof. Paolo Ferragina, Algoritmi per "Information Retrieval"
Symmetric Matrices and Quadratic Forms
Maths for Signals and Systems Linear Algebra in Engineering Lectures 13 – 14, Tuesday 8th November 2016 DR TANIA STATHAKI READER (ASSOCIATE PROFFESOR)
Lecture 13: Singular Value Decomposition (SVD)
CS276 Lecture 7: Scoring and results assembly
CS 430: Information Discovery
Packing to fewer dimensions
Information Retrieval and Web Search
Lecture 20 SVD and Its Applications
Symmetric Matrices and Quadratic Forms
Presentation transcript:

CS276A Text Information Retrieval, Mining, and Exploitation Lecture 5 17 Oct 2002

Recap of last time Ranking models Inverted indexes with term weighting The vector space model Inverted indexes with term weighting Evaluation with ranking models

Recall document as vector Each doc j is a vector of tfidf values, one component for each term. Can normalize to unit length. So we have a vector space terms are axes docs live in this space even with stemming, we may have 50,000+ dimensions A user’s query can be viewed as a (very) short document. Query becomes a vector in the same space

Intuition Postulate: Documents that are “close together” θ φ t1 d5 t2 d4 Postulate: Documents that are “close together” in vector space talk about the same things.

Cosine similarity Can compute cosine similarity from a query (vector of terms, e.g., truth forever) to each document. We use this to compute a document ranking

Today’s topics Computing cosine-based ranking Speeding up cosine ranking Reducing the number of cosine computations Union of term-wise candidates Sampling and pre-grouping Reducing the number of dimensions Latent Semantic Indexing Random projection

Exercises How would you augment the inverted index built in lectures 1–3 to support cosine ranking computations? Walk through the steps of serving a query. The math of the vector space model is quite straightforward, but being able to do cosine ranking efficiently at runtime is nontrivial

Efficient cosine ranking Ranking consists of computing the k docs in the corpus “nearest” to the query  k largest query-doc cosines. Efficient ranking: Computing a single cosine efficiently. Choosing the k largest cosine values efficiently.

Efficient cosine ranking What an IR system does is in effect solve the k nearest neighbor problem for each query This in general cannot be done efficiently for high-dimensional spaces But it is solvable for short queries, and standard indexes are optimized to do this

Computing a single cosine For every term i, with each doc j, store term frequency tfij. Some tradeoffs on whether to store term count, term weight, or weighted by idfi. Accumulate component-wise sum More on speeding up a single cosine later on If you’re indexing 2,469,940,685 documents (Google) an array of accumulators is infeasible Ideas?

Encoding document frequencies abacus 8 aargh 2 acacia 35 1,2 7,3 83,1 87,2 … 1,1 5,1 13,1 17,1 … 7,1 8,2 40,1 97,3 … Add tfd,t to postings lists Almost always as frequency – scale at runtime Unary code is very effective here  code (as in 1st class) is an even better choice Overall, requires little additional space Why?

Computing the k largest cosines: selection vs. sorting Typically we want to retrieve the top k docs (in the cosine ranking for the query) not totally order all docs in the corpus just pick off docs with k highest cosines.

Use heap for selecting top k Binary tree in which each node’s value > values of children Takes 2n operations to construct, then each of k log n “winners” read off in 2log n steps. For n=1M, k=100, this is about 10% of the cost of sorting.

Bottleneck Still need to first compute cosines from query to each of n docs  several seconds for n = 1M. Can select from only non-zero cosines Need union of postings lists accumulators (<<1M) Can further limit to documents with non-zero cosines on rare (high idf) words Enforce conjunctive search (a la Google): non-zero cosines on all words in query Need min of postings lists sizes accumulators But still potentially expensive

Can we avoid this? Yes, but may occasionally get an answer wrong a doc not in the top k may creep into the answer.

Term-wise candidates Preprocess: Pre-compute, for each term, its k nearest docs. (Treat each term as a 1-term query.) lots of preprocessing. Result: “preferred list” for each term. Search: For a t-term query, take the union of their t preferred lists – call this set S. Compute cosines from the query to only the docs in S, and choose top k.

Exercises Fill in the details of the calculation: Which docs go into the preferred list for a term? Devise a small example where this method gives an incorrect ranking.

Sampling and pre-grouping First run a pre-processing phase: pick n docs at random: call these leaders For each other doc, pre-compute nearest leader Docs attached to a leader: its followers; Likely: each leader has ~ n followers. Process a query as follows: Given query Q, find its nearest leader L. Seek k nearest docs from among L’s followers.

Visualization Query Leader Follower

Why use random sampling Fast Leaders reflect data distribution

General variants Have each follower attached to a=3 (say) nearest leaders. From query, find b=4 (say) nearest leaders and their followers. Can recur on leader/follower construction.

Exercises To find the nearest leader in step 1, how many cosine computations do we do? What is the effect of the constants a,b on the previous slide? Devise an example where this is likely to fail – i.e., we miss one of the k nearest docs. Likely under random sampling.

Dimensionality reduction What if we could take our vectors and “pack” them into fewer dimensions (say 50,000100) while preserving distances? (Well, almost.) Speeds up cosine computations. Two methods: “Latent semantic indexing”. Random projection.

Random projection onto k<<m axes Choose a random direction x1 in the vector space. For i = 2 to k, Choose a random direction xi that is orthogonal to x1, x2, … xi–1. Project each document vector into the subspace spanned by {x1, x2, …, xk}.

E.g., from 3 to 2 dimensions t 3 d2 x2 x2 d2 d1 d1 t 1 x1 x1 t 2 x1 is a random direction in (t1,t2,t3) space. x2 is chosen randomly but orthogonal to x1.

Guarantee With high probability, relative distances are (approximately) preserved by projection. Pointer to precise theorem in Resources. (Using random projection is a newer idea: it’s somewhat surprising, but it works very well.)

Computing the random projection Projecting n vectors from m dimensions down to k dimensions: Start with m  n matrix of terms  docs, A. Find random k  m orthogonal projection matrix R. Compute matrix product W = R  A. jth column of W is the vector corresponding to doc j, but now in k << m dimensions.

Cost of computation This takes a total of kmn multiplications. Why? This takes a total of kmn multiplications. Expensive – see Resources for ways to do essentially the same thing, quicker. Exercise: by projecting from 50,000 dimensions down to 100, are we really going to make each cosine computation faster?

Latent semantic indexing (LSI) Another technique for dimension reduction Random projection was data-independent LSI on the other hand is data-dependent Eliminate redundant axes Pull together “related” axes – hopefully car and automobile

Notions from linear algebra Matrix, vector Matrix transpose and product Rank Eigenvalues and eigenvectors.

Overview of LSI Pre-process docs using a technique from linear algebra called Singular Value Decomposition. Have control over the granularity of this process: create new vector space, details to follow. Queries handled in this new vector space.

Term-Document matrix wi,j = (normalized) weighted count (ti , dj) dj

Matrix Factorizations A = W x H n k n = x k m m Basis Representation hj is representation of dj in terms of basis W If rank(W) ≥ rank(A) then we can always find H so A = WH If not, we find a reduced rank approximation, A ~

Minimization Problem Minimize Given: norm constraints on W, S, V for SVD, the 2-norm constraints on W, S, V for SVD, W and V are orthonormal, and S is diagonal

Matrix Factorizations: SVD A = W x S x VT n k n = x x S scales rows k m m Singular Values Basis Representation Restrictions on representation: W, V orthonormal; S diagonal Best rank k approximation according to 2-norm

Singular-Value Decomposition Recall m  n matrix of terms  docs, A. A has rank r  m,n. Define term-term correlation matrix T = AAt At denotes the matrix transpose of A. T is a square, symmetric m  m matrix. Doc-doc correlation matrix D=AtA. D is a square, symmetric n  n matrix. Why?

Eigenvectors Denote by W the m  r matrix of eigenvectors of T. Denote by V the n  r matrix of eigenvectors of D. It turns out A can be expressed (decomposed) as A = WSVt S is a diagonal matrix with the eigenvalues of T = AAt in sorted order. An “almost unique” representation (modulo sign flips, etc.)

Dimension reduction For some s << r, zero out all but the s biggest eigenvalues in S. Denote by Ss this new version of S. Typically s in the hundreds while r could be in the (tens of) thousands. Let As = W Ss Vt = WsSsVst As is a good approximation to A. Best rank k approximation according to 2-norm

Matrix Factorizations: SVD As = W x Ss x VT s n n k s = x x S scales rows k m m Singular Values Basis Representation The columns of As represent the docs, but in s << m dimensions Best rank s approximation according to 2-norm

Guarantee Relative distances are (approximately) preserved by projection: Of all m  n rank s matrices, As is the best approximation to A. Pointer to precise theorem in Resources.

Doc-doc similarities AstAs is a matrix of doc-doc similarities: the (j,k) entry is a measure of the similarity of doc j to doc k.

Semi-precise intuition We accomplish more than dimension reduction here: Docs with lots of overlapping terms stay together Terms from these docs also get pulled together. Thus car and automobile get pulled together because both co-occur in docs with tires, radiator, cylinder, etc.

Query processing View a query as a (short) doc: call it column 0 of As. Now the entries in column 0 of AstAs give the similarities of the query with each doc. Entry (j,0) is the score of doc j on the query. Exercise: fill in the details of scoring/ranking.

Resources Random projection theorem: http://citeseer.nj.nec.com/dasgupta99elementary.html Faster random projection: http://citeseer.nj.nec.com/frieze98fast.html Latent semantic indexing: http://citeseer.nj.nec.com/deerwester90indexing.html http://cs276a.stanford.edu/handouts/fsnlp-svd.pdf Books: MG 4.6, MIR 2.7.2.