fast_ml fast_ml-lsi knowledge-graph by maker-knowledge-mining

fast_ml lsi model


lsi model topics list

topicId: wordWeight*wordName (topN-words)

topic #0: 0.156*"vw" + 0.120*"file" + 0.118*"error" + 0.104*"validation" + 0.103*"model" + 0.097*"mtry" + 0.095*"features" + 0.086*"learning" + 0.080*"layer" + 0.080*"random"

topic #1: -0.309*"vw" + 0.217*"mtry" + -0.150*"csv" + 0.145*"error" + -0.143*"file" + -0.140*"loss" + 0.124*"trees" + -0.121*"quantile" + -0.114*"wabbit" + -0.113*"vowpal"

topic #2: -0.407*"mtry" + -0.219*"error" + -0.211*"spearmint" + -0.131*"default" + -0.130*"trees" + -0.127*"validation" + 0.123*"deep" + -0.108*"setting" + -0.106*"hyperparams" + -0.105*"value"

topic #3: -0.293*"queries" + -0.262*"query" + -0.227*"search" + -0.224*"items" + 0.201*"vw" + -0.180*"product" + -0.150*"benchmark" + -0.114*"five" + -0.113*"spelling" + -0.111*"item"

topic #4: -0.286*"nvidia" + -0.252*"geforce" + -0.215*"gtx" + -0.207*"cuda" + -0.206*"meanvisb" + -0.192*"gpu" + -0.179*"valid" + -0.176*"cpu" + -0.157*"overfeat" + -0.137*"drivers"

topic #5: -0.322*"overfeat" + -0.201*"images" + 0.146*"lda" + 0.140*"nvidia" + -0.140*"layer" + 0.138*"lsi" + 0.113*"geforce" + 0.106*"gtx" + -0.105*"cat" + 0.105*"gensim"

topic #6: -0.258*"overfeat" + 0.243*"vw" + -0.166*"images" + 0.145*"nvidia" + 0.120*"geforce" + -0.117*"lda" + 0.114*"filtering" + -0.113*"lsi" + 0.112*"gtx" + 0.104*"meanvisb"

topic #7: -0.179*"lda" + 0.166*"file" + -0.161*"lsi" + -0.140*"overfeat" + 0.132*"seed" + -0.130*"gensim" + -0.120*"nmf" + -0.115*"models" + 0.114*"line" + -0.112*"vw"

topic #8: 0.167*"science" + -0.156*"dropout" + -0.148*"mnist" + 0.123*"big" + -0.122*"obj" + 0.110*"coursera" + 0.109*"vw" + -0.108*"epochs" + 0.105*"overfeat" + -0.103*"maxout"

topic #9: 0.212*"telecommunication" + 0.212*"chunghwa" + 0.189*"search" + 0.167*"path" + 0.140*"names" + -0.140*"line" + 0.139*"auc" + 0.138*"paths" + 0.138*"graph" + -0.137*"seed"

topic #10: 0.142*"shell" + -0.142*"trees" + -0.134*"boosted" + 0.124*"mrmr" + 0.122*"filtering" + 0.118*"threshold" + -0.109*"everything" + 0.109*"paste" + -0.108*"tree" + -0.107*"followers"

topic #11: -0.189*"mrmr" + -0.175*"threshold" + -0.130*"auc" + -0.129*"trees" + -0.117*"boosted" + 0.114*"wine" + 0.103*"mtry" + -0.101*"roc" + -0.101*"tree" + 0.095*"error"

topic #12: 0.196*"search" + -0.170*"yob" + -0.158*"auc" + -0.148*"users" + 0.145*"telecommunication" + 0.145*"chunghwa" + 0.129*"names" + -0.127*"precision" + -0.127*"roc" + 0.113*"cost"

topic #13: 0.175*"users" + 0.137*"linux" + 0.126*"shell" + 0.111*"windows" + 0.105*"precision" + 0.104*"pane" + 0.104*"console" + 0.104*"plots" + -0.104*"noise" + 0.104*"vmware"

topic #14: 0.169*"samples" + 0.161*"auc" + -0.143*"variation" + 0.133*"roc" + 0.122*"threshold" + -0.113*"yob" + -0.111*"page" + -0.104*"amelia" + -0.100*"content" + 0.098*"overfeat"

topic #15: 0.200*"amelia" + -0.148*"foreca" + -0.142*"precision" + -0.136*"samples" + 0.133*"imputed" + -0.118*"forecastable" + 0.118*"dictvectorizer" + 0.117*"pandas" + 0.117*"missing" + -0.106*"ap"

topic #16: -0.186*"wine" + -0.159*"alcohol" + -0.157*"nrows" + -0.138*"yob" + -0.122*"chunghwa" + -0.122*"telecommunication" + 0.116*"weka" + 0.113*"degrees" + 0.113*"freedom" + 0.103*"mrmr"

topic #17: 0.177*"telecommunication" + 0.177*"chunghwa" + 0.155*"weka" + -0.143*"foreca" + 0.143*"users" + 0.126*"overfeat" + -0.115*"forecastable" + 0.110*"lasso" + -0.108*"threshold" + 0.105*"jobs"

topic #18: 0.185*"nrows" + -0.173*"wine" + -0.167*"weka" + -0.153*"alcohol" + -0.137*"sauc" + -0.125*"tacc" + -0.125*"tauc" + -0.125*"srms" + -0.125*"sacc" + -0.125*"trms"

topic #19: 0.283*"weka" + 0.169*"nrows" + -0.134*"gefs" + 0.133*"java" + -0.126*"yob" + -0.107*"lat" + -0.107*"lon" + -0.098*"wine" + 0.097*"memory" + 0.095*"auc"

topic #20: 0.179*"foreca" + 0.144*"forecastable" + -0.137*"precision" + 0.125*"freedom" + 0.125*"degrees" + 0.123*"weka" + 0.108*"omega" + -0.103*"ap" + -0.101*"variation" + -0.101*"sauc"

topic #21: -0.177*"amelia" + -0.150*"nrows" + -0.144*"weka" + 0.138*"sauc" + 0.134*"degrees" + 0.134*"freedom" + 0.126*"sacc" + 0.126*"srms" + 0.126*"tacc" + 0.126*"tauc"

topic #22: 0.422*"weka" + 0.200*"java" + -0.128*"shell" + 0.126*"linux" + -0.123*"big" + -0.104*"dropconnect" + 0.102*"vmware" + 0.096*"precision" + 0.093*"yob" + -0.091*"paste"

topic #23: -0.269*"nrows" + -0.200*"sauc" + -0.183*"tauc" + -0.183*"sacc" + -0.183*"srms" + -0.183*"tacc" + -0.183*"trms" + -0.146*"pass" + 0.127*"dropconnect" + -0.124*"gefs"

topic #24: 0.269*"dropconnect" + 0.159*"dropout" + 0.158*"error" + -0.150*"wine" + -0.137*"alcohol" + 0.119*"li" + -0.105*"gamma" + -0.104*"library" + -0.103*"mapped" + -0.101*"distance"

topic #25: -0.219*"mrmr" + -0.173*"nrows" + -0.173*"wine" + -0.157*"alcohol" + -0.142*"threshold" + 0.140*"foreca" + 0.113*"amelia" + 0.113*"samples" + 0.112*"forecastable" + -0.112*"selection"

topic #26: -0.167*"samples" + -0.156*"chunghwa" + -0.156*"telecommunication" + -0.149*"weka" + -0.124*"pybrain" + 0.109*"mnist" + -0.103*"schmidhuber" + 0.103*"relus" + 0.099*"precision" + -0.099*"shell"

topic #27: -0.270*"yob" + 0.228*"amelia" + 0.171*"foreca" + 0.152*"imputed" + 0.137*"forecastable" + -0.116*"mit" + -0.116*"demographics" + 0.114*"bagging" + 0.103*"omega" + 0.101*"idvars"

topic #28: 0.199*"wine" + 0.183*"alcohol" + -0.142*"noise" + 0.133*"pane" + 0.133*"console" + 0.133*"plots" + -0.106*"foreca" + 0.101*"gefs" + 0.100*"rstudio" + 0.099*"wines"

topic #29: 0.181*"shell" + -0.176*"linux" + -0.168*"telecommunication" + -0.168*"chunghwa" + -0.141*"vmware" + 0.130*"paste" + -0.124*"sauc" + -0.114*"amelia" + -0.113*"sacc" + -0.113*"trms"

topic #30: 0.165*"yob" + -0.149*"vmware" + -0.146*"linux" + 0.141*"plots" + 0.141*"pane" + 0.141*"console" + 0.129*"lasso" + -0.120*"gefs" + -0.113*"amelia" + 0.106*"rstudio"

topic #31: 0.267*"weka" + -0.169*"chunghwa" + -0.169*"telecommunication" + 0.136*"java" + 0.135*"yob" + 0.123*"filtering" + -0.106*"foreca" + 0.103*"noise" + -0.100*"lasso" + -0.098*"plots"

topic #32: 0.152*"dropconnect" + 0.137*"nrows" + -0.124*"shell" + -0.124*"weka" + 0.116*"freedom" + 0.116*"degrees" + 0.114*"roc" + 0.108*"dropout" + 0.103*"linux" + -0.101*"chunghwa"

topic #33: -0.195*"chunghwa" + -0.195*"telecommunication" + -0.154*"shell" + -0.145*"gamma" + -0.131*"mapped" + 0.118*"lasso" + -0.112*"nrows" + 0.112*"linux" + -0.108*"centers" + 0.105*"search"

topic #34: 0.163*"overfeat" + 0.142*"console" + 0.142*"plots" + 0.142*"pane" + -0.142*"expressions" + -0.142*"linux" + -0.132*"vmware" + -0.126*"pybrain" + 0.116*"variation" + -0.110*"users"

topic #35: 0.179*"foreca" + 0.171*"dropconnect" + -0.161*"noise" + 0.144*"forecastable" + 0.131*"weka" + -0.124*"amelia" + -0.115*"layers" + 0.108*"omega" + 0.106*"mrmr" + 0.092*"overfeat"

topic #36: 0.207*"precision" + 0.156*"ap" + -0.141*"writer" + 0.132*"samples" + 0.124*"matrix" + 0.103*"noise" + -0.099*"models" + 0.097*"recall" + 0.096*"average" + -0.095*"quantile"

topic #37: -0.155*"lasso" + 0.145*"matrix" + -0.134*"amelia" + -0.111*"gamma" + -0.105*"mapped" + -0.097*"shell" + 0.096*"lmnn" + 0.092*"pane" + 0.092*"plots" + 0.092*"console"

topic #38: -0.234*"noise" + 0.149*"variation" + -0.146*"layers" + 0.124*"interval" + -0.122*"yob" + 0.118*"salaries" + 0.108*"page" + -0.100*"quadratic" + -0.100*"mnist" + 0.098*"bandits"

topic #39: -0.191*"yob" + 0.172*"pandas" + 0.171*"dictvectorizer" + -0.152*"shell" + 0.109*"categorical" + 0.102*"frame" + 0.092*"roc" + -0.091*"writer" + 0.091*"everything" + -0.090*"magic"

topic #40: -0.172*"lasso" + -0.139*"dropconnect" + 0.121*"pybrain" + 0.101*"schmidhuber" + 0.101*"yob" + -0.100*"samples" + 0.099*"csv" + 0.098*"quadratic" + -0.098*"noise" + 0.096*"users"

topic #41: 0.140*"lasso" + -0.135*"precision" + -0.112*"degrees" + -0.112*"freedom" + -0.111*"mtry" + -0.101*"ap" + 0.098*"matrix" + 0.097*"jobs" + 0.090*"coursera" + -0.087*"samples"

topic #42: 0.185*"noise" + -0.150*"samples" + 0.122*"big" + -0.107*"variation" + 0.106*"corpus" + 0.102*"layers" + -0.097*"telecommunication" + -0.097*"chunghwa" + 0.095*"apple" + 0.095*"hype"

topic #43: -0.154*"tree" + 0.134*"mtry" + -0.122*"noise" + -0.105*"writer" + 0.098*"expressions" + -0.096*"sec" + -0.096*"logprob" + 0.093*"amelia" + 0.093*"nrows" + -0.093*"estimate"

topic #44: 0.162*"pybrain" + 0.135*"schmidhuber" + 0.127*"roc" + 0.107*"expressions" + -0.106*"obj" + -0.103*"mrmr" + -0.102*"telecommunication" + -0.102*"chunghwa" + -0.102*"sec" + -0.102*"logprob"

topic #45: -0.133*"writer" + -0.124*"dropconnect" + 0.113*"expressions" + 0.111*"chunghwa" + 0.111*"telecommunication" + 0.110*"mnist" + 0.100*"mrmr" + 0.095*"threshold" + -0.088*"writers" + -0.084*"nrows"

topic #46: -0.156*"mtry" + 0.151*"gamma" + 0.126*"dropconnect" + 0.122*"mapped" + -0.120*"filtering" + -0.108*"sec" + -0.108*"logprob" + -0.108*"lasso" + 0.103*"users" + -0.098*"image"

topic #47: -0.176*"mnist" + 0.158*"mrmr" + 0.128*"pythonpath" + 0.114*"wrapper" + 0.110*"categories" + -0.100*"epochs" + -0.099*"permutation" + 0.096*"relus" + 0.094*"library" + 0.088*"reader"

topic #48: -0.194*"mrmr" + 0.142*"roc" + 0.135*"cubic" + -0.130*"quantile" + -0.124*"loss" + -0.114*"noise" + 0.113*"polynomial" + 0.112*"quadratic" + 0.106*"lasso" + -0.103*"fea"

topic #49: -0.221*"queries" + 0.170*"categories" + 0.127*"reader" + 0.109*"cost" + -0.105*"query" + -0.103*"chunghwa" + -0.103*"telecommunication" + 0.098*"quantile" + 0.096*"cloud" + 0.095*"loss"






Latent semantic indexing

Latent semantic indexing (LSI) is an indexing and retrieval method that uses a mathematical technique called singular value decomposition (SVD) to identify patterns in the relationships between the terms and concepts contained in an unstructured collection of text. LSI is based on the principle that words that are used in the same contexts tend to have similar meanings. A key feature of LSI is its ability to extract the conceptual content of a body of text by establishing associations between those terms that occur in similar contexts.

LSI is also an application of correspondence analysis, a multivariate statistical technique developed by Jean-Paul Benzécri in the early 1970s, to a contingency table built from word counts in documents.

Called Latent Semantic Indexing because of its ability to correlate semantically related terms that are latent in a collection of text, it was first applied to text at Bellcore in the late 1980s. The method, also called latent semantic analysis (LSA), uncovers the underlying latent semantic structure in the usage of words in a body of text and how it can be used to extract the meaning of the text in response to user queries, commonly referred to as concept searches. Queries, or concept searches, against a set of documents that have undergone LSI will return results that are conceptually similar in meaning to the search criteria even if the results don’t share a specific word or words with the search criteria.

Benefits of LSI

LSI overcomes two of the most problematic constraints of Boolean keyword queries: multiple words that have similar meanings (synonymy) and words that have more than one meaning (polysemy). Synonymy is often the cause of mismatches in the vocabulary used by the authors of documents and the users of information retrieval systems. As a result, Boolean or keyword queries often return irrelevant results and miss information that is relevant.

LSI is also used to perform automated document categorization. In fact, several experiments have demonstrated that there are a number of correlations between the way LSI and humans process and categorize text. Document categorization is the assignment of documents to one or more predefined categories based on their similarity to the conceptual content of the categories. LSI uses example documents to establish the conceptual basis for each category. During categorization processing, the concepts contained in the documents being categorized are compared to the concepts contained in the example items, and a category (or categories) is assigned to the documents based on the similarities between the concepts they contain and the concepts that are contained in the example documents.

Dynamic clustering based on the conceptual content of documents can also be accomplished using LSI. Clustering is a way to group documents based on their conceptual similarity to each other without using example documents to establish the conceptual basis for each cluster. This is very useful when dealing with an unknown collection of unstructured text.

Because it uses a strictly mathematical approach, LSI is inherently independent of language. This enables LSI to elicit the semantic content of information written in any language without requiring the use of auxiliary structures, such as dictionaries and thesauri. LSI can also perform cross-linguistic concept searching and example-based categorization. For example, queries can be made in one language, such as English, and conceptually similar results will be returned even if they are composed of an entirely different language or of multiple languages.

LSI is not restricted to working only with words. It can also process arbitrary character strings. Any object that can be expressed as text can be represented in an LSI vector space. For example, tests with MEDLINE abstracts have shown that LSI is able to effectively classify genes based on conceptual modeling of the biological information contained in the titles and abstracts of the MEDLINE citations.

LSI automatically adapts to new and changing terminology, and has been shown to be very tolerant of noise (i.e., misspelled words, typographical errors, unreadable characters, etc.). This is especially important for applications using text derived from Optical Character Recognition (OCR) and speech-to-text conversion. LSI also deals effectively with sparse, ambiguous, and contradictory data.

Text does not need to be in sentence form for LSI to be effective. It can work with lists, free-form notes, email, Web-based content, etc. As long as a collection of text contains multiple terms, LSI can be used to identify patterns in the relationships between the important terms and concepts contained in the text.

LSI has proven to be a useful solution to a number of conceptual matching problems. The technique has been shown to capture key relationship information, including causal, goal-oriented, and taxonomic information.

LSI timeline

Mid-1960s – Factor analysis technique first described and tested (H. Borko and M. Bernick)

1988 – Seminal paper on LSI technique published (Deerwester et al.)

1989 – Original patent granted (Deerwester et al.)

1992 – First use of LSI to assign articles to reviewers (Dumais and Nielsen)

1994 – Patent granted for the cross-lingual application of LSI (Landauer et al.)

1995 – First use of LSI for grading essays (Foltz, et al., Landauer et al.)

1999 – First implementation of LSI technology for intelligence community for analyzing unstructured text (SAIC).

2002 – LSI-based product offering to intelligence-based government agencies (SAIC)

2005 – First vertical-specific application – publishing – EDB (EBSCO, Content Analyst Company)

Mathematics of LSI

LSI uses common linear algebra techniques to learn the conceptual correlations in a collection of text. In general, the process involves constructing a weighted term-document matrix, performing a Singular Value Decomposition on the matrix, and using the matrix to identify the concepts contained in the text.

Term-document matrix

LSI begins by constructing a term-document matrix, A, to identify the occurrences of the m unique terms within a collection of n documents. In a term-document matrix, each term is represented by a row, and each document is represented by a column, with each matrix cell, a_{ij}, initially representing the number of times the associated term appears in the indicated document, \mathrm{tf_{ij}}. This matrix is usually very large and very sparse.

Once a term-document matrix is constructed, local and global weighting functions can be applied to it to condition the data. The weighting functions transform each cell, a_{ij} of A, to be the product of a local term weight, l_{ij}, which describes the relative frequency of a term in a document, and a global weight, g_i, which describes the relative frequency of the term within the entire collection of documents.

Some common local weighting functions are defined in the following table.

Rank-reduced singular value decomposition

A rank-reduced, singular value decomposition is performed on the matrix to determine patterns in the relationships between the terms and concepts contained in the text. The SVD forms the foundation for LSI. It computes the term and document vector spaces by transforming the single term-frequency matrix, A, into three other matrices— an m by r term-concept vector matrix T, an r by r singular values matrix S, and a n by r concept-document vector matrix, D, which satisfy the following relations:

A = TSD^T

T^T T = I_r \quad D^T D = I_r

S_{1,1} \geq S_{2,2} \geq \ldots \geq S_{r,r} > 0 \quad S_{i,j} = 0 \; \text{where} \; i \neq j

In the formula, A is the supplied m by n weighted matrix of term frequencies in a collection of text where m is the number of unique terms, and n is the number of documents. T is a computed m by r matrix of term vectors where r is the rank of A—a measure of its unique dimensions ≤ min(m,n). S is a computed r by r diagonal matrix of decreasing singular values, and D is a computed n by r matrix of document vectors.

The LSI modification to a standard SVD is to reduce the rank or truncate the singular value matrix S to size k « r, typically on the order of a k in the range of 100 to 300 dimensions, effectively reducing the term and document vector matrix sizes to m by k and n by k respectively. The SVD operation, along with this reduction, has the effect of preserving the most important semantic information in the text while reducing noise and other undesirable artifacts of the original space of A. This reduced set of matrices is often denoted with a modified formula such as:

A ≈ Ak = Tk Sk DkT

Efficient LSI algorithms only compute the first k singular values and term and document vectors as opposed to computing a full SVD and then truncating it.

Note that this rank reduction is essentially the same as doing Principal Component Analysis (PCA) on the matrix A, except that PCA subtracts off the means. PCA loses the sparseness of the A matrix, which can make it infeasible for large lexicons.

Querying and augmenting LSI vector spaces

The computed Tk and Dk matrices define the term and document vector spaces, which with the computed singular values, Sk, embody the conceptual information derived from the document collection. The similarity of terms or documents within these spaces is a factor of how close they are to each other in these spaces, typically computed as a function of the angle between the corresponding vectors.

The same steps are used to locate the vectors representing the text of queries and new documents within the document space of an existing LSI index. By a simple transformation of the A = T S DT equation into the equivalent D = AT T S−1 equation, a new vector, d, for a query or for a new document can be created by computing a new column in A and then multiplying the new column by T S−1. The new column in A is computed using the originally derived global term weights and applying the same local weighting function to the terms in the query or in the new document.

A drawback to computing vectors in this way, when adding new searchable documents, is that terms that were not known during the SVD phase for the original index are ignored. These terms will have no impact on the global weights and learned correlations derived from the original collection of text. However, the computed vectors for the new text are still very relevant for similarity comparisons with all other document vectors.

The process of augmenting the document vector spaces for an LSI index with new documents in this manner is called folding in. Although the folding-in process does not account for the new semantic content of the new text, adding a substantial number of documents in this way will still provide good results for queries as long as the terms and concepts they contain are well represented within the LSI index to which they are being added. When the terms and concepts of a new set of documents need to be included in an LSI index, either the term-document matrix, and the SVD, must be recomputed or an incremental update method (such as the one described in) be used.

Additional uses of LSI

It is generally acknowledged that the ability to work with text on a semantic basis is essential to modern information retrieval systems. As a result, the use of LSI has significantly expanded in recent years as earlier challenges in scalability and performance have been overcome.

LSI is being used in a variety of information retrieval and text processing applications, although its primary application has been for concept searching and automated document categorization. Below are some other ways in which LSI is being used:

Information discovery (eDiscovery, Government/Intelligence community, Publishing)

Automated document classification (eDiscovery, Government/Intelligence community, Publishing)

Text summarization (eDiscovery, Publishing)

Relationship discovery (Government, Intelligence community, Social Networking)

Automatic generation of link charts of individuals and organizations (Government, Intelligence community)

Matching technical papers and grants with reviewers (Government)

Online customer support (Customer Management)

Determining document authorship (Education)

Automatic keyword annotation of images

Understanding software source code (Software Engineering)

Filtering spam (System Administration)

Information visualization

Essay scoring (Education)

Literature-based discovery

LSI is increasingly being used for electronic document discovery (eDiscovery) to help enterprises prepare for litigation. In eDiscovery, the ability to cluster, categorize, and search large collections of unstructured text on a conceptual basis is essential. Concept-based searching using LSI has been applied to the eDiscovery process by leading providers as early as 2003.) be used.

Challenges to LSI

Early challenges to LSI focused on scalability and performance. LSI requires relatively high computational performance and memory in comparison to other information retrieval techniques. However, with the implementation of modern high-speed processors and the availability of inexpensive memory, these considerations have been largely overcome. Real-world applications involving more than 30 million documents that were fully processed through the matrix and SVD computations are not uncommon in some LSI applications. A fully scalable (unlimited number of documents, online training) implementation of LSI is contained in the open source gensim software package.

Another challenge to LSI has been the alleged difficulty in determining the optimal number of dimensions to use for performing the SVD. As a general rule, fewer dimensions allow for broader comparisons of the concepts contained in a collection of text, while a higher number of dimensions enable more specific (or more relevant) comparisons of concepts. The actual number of dimensions that can be used is limited by the number of documents in the collection. Research has demonstrated that around 300 dimensions will usually provide the best results with moderate-sized document collections (hundreds of thousands of documents) and perhaps 400 dimensions for larger document collections (millions of documents). However, recent studies indicate that 50-1000 dimensions are suitable depending on the size and nature of the document collection.

Checking the amount of variance in the data after computing the SVD can be used to determine the optimal number of dimensions to retain. The variance contained in the data can be viewed by plotting the singular values (S) in a scree plot. Some LSI practitioners select the dimensionality associated with the knee of the curve as the cut-off point for the number of dimensions to retain. Others argue that some quantity of the variance must be retained, and the amount of variance in the data should dictate the proper dimensionality to retain. Seventy percent is often mentioned as the amount of variance in the data that should be used to select the optimal dimensionality for recomputing the SVD.

from wiki http://en.wikipedia.org/wiki/Latent_semantic_indexing

Latent semantic analysis

Latent semantic analysis (LSA) is a technique in natural language processing, in particular in vectorial semantics, of analyzing relationships between a set of documents and the terms they contain by producing a set of concepts related to the documents and terms. LSA assumes that words that are close in meaning will occur in similar pieces of text. A matrix containing word counts per paragraph (rows represent unique words and columns represent each paragraph) is constructed from a large piece of text and a mathematical technique called singular value decomposition (SVD) is used to reduce the number of columns while preserving the similarity structure among rows. Words are then compared by taking the cosine of the angle between the two vectors formed by any two rows. Values close to 1 represent very similar words while values close to 0 represent very dissimilar words.

LSA was patented in 1988 (US Patent 4,839,853) by Scott Deerwester, Susan Dumais, George Furnas, Richard Harshman, Thomas Landauer, Karen Lochbaum and Lynn Streeter. In the context of its application to information retrieval, it is sometimes called Latent Semantic Indexing (LSI).

from wiki http://en.wikipedia.org/wiki/Latent_semantic_analysis