DSA Homework

Roger Jang


Due date:

N-gram Search (Information Retrieval)

Outlines

Problem definition

Google's Web 1T dataset is a big collection of n-grams (with n=2, 3, 4, and 5) of English that can be used for various applications, including machine translation, speech recognition, English usage correction, etc. In this assignment, we need to implement an efficient information retrieval method for querying a slim version of the Web 1T dataset.

Given a query of n-gram, you program should return its frequency based on the slim Web 1T. The given n-gram query can be a simple query such as "listen to music" or "in a position to". Additionally, it can contains wildcards and special characters to make the query more flexible, as explain next.

To test these special characters, please try Linggle.

Please check out the recording and slides of this homework.

Suggested approach

The basic approach is based on inverted index. In other words, for a give word, we need to be able to find which n-gram it appears. More info can be found in the first three sections of Boolean retrieval:

Tutorials by Stanford NLP-Professor Dan Jurafsky & Chris Manning

To be more precise, here is a typical approach to the problem:

For query expansion, you need to follow the rules shown next (which may not be exactly the same as those used by Linggle):
  1. First, expand "?" (which, if exist, always applear as the first character in a token). For instance, "abc ?x/y/z _ ?*/p" can be expanded into the following 4 queries:
  2. Second, expand "/". For instance, "abc x/y/z _ */p" can be expanded into the following 6 queries:
  3. Last, expand "*" into emptiness or combinations of "_". For instance, "give * a *" can be expaneded into the following 10 queries:
Note that it will be easier to write a recursive function for each of the above expansions.

Input/output formats

An typical example of input file is as follows, where each line is a query:

regarding our site to occupation does resolution with all eliminated _ _ the resulted from negligent understand that you _ _ alprazolam international free/on cartoon sex _ and _ states storing large _ of/for/with data

For each query, you only need to generate at most top-5 output with ascending order of frequency. If there is tie, list them according to alphabetical order of the n-grams. The output file corresponding to the previous input file is shown next:

query: regarding our site to output: 1 regarding our site to 1103 query: occupation does output: 1 occupation does 4704 query: resolution with all output: 1 resolution with all 6938 query: eliminated _ _ the output: 5 eliminated most of the 6744 eliminated many of the 4848 eliminated some of the 4467 eliminated all of the 4131 eliminated much of the 3933 query: resulted from negligent output: 1 resulted from negligent 3434 query: understand that you _ _ output: 5 understand that you do not 11830 understand that you can not 9507 understand that you are not 6594 understand that you are using 5366 understand that you want to 5175 query: alprazolam international output: 1 alprazolam international 1414 query: free/on cartoon sex _ output: 5 free cartoon sex video 10298 free cartoon sex free 7323 free cartoon sex pics 4177 free cartoon sex movie 3575 free cartoon sex film 2412 query: and _ states output: 5 and other states 139463 and the states 105148 and surrounding states 25879 and all states 17070 and some states 16149 query: storing large _ of/for/with data output: 1 storing large amounts of data 2578 Each output entry and its frequency are separated by a tab.

Requirements

Datasets

  1. The original Google Web 1T dataset is too big to process for machines with limited memory. Hence we shall use a subset for this project, as shown next. These files are already available under /tmp2/dsa2017_hw02/ of linux1 to linux13.
  2. Open test sets
  3. Hidden test sets