In natural language processing and information retrieval, explicit semantic analysis (ESA) is a vectoral representation of text (individual words or entire documents) that uses a document corpus as a knowledge base. Specifically, in ESA, a word is represented as a column vector in the tf–idf matrix of the text corpus and a document (string of words) is represented as the centroid of the vectors representing its words. Typically, the text corpus is English Wikipedia, though other corpora including the Open Directory Project have been used.[1]

ESA was designed by Evgeniy Gabrilovich and Shaul Markovitch as a means of improving text categorization[2] and has been used by this pair of researchers to compute what they refer to as "semantic relatedness" by means of cosine similarity between the aforementioned vectors, collectively interpreted as a space of "concepts explicitly defined and described by humans", where Wikipedia articles (or ODP entries, or otherwise titles of documents in the knowledge base corpus) are equated with concepts. The name "explicit semantic analysis" contrasts with latent semantic analysis (LSA), because the use of a knowledge base makes it possible to assign human-readable labels to the concepts that make up the vector space.[1][3]


To perform the basic variant of ESA, one starts with a collection of texts, say, all Wikipedia articles; let the number of documents in the collection be N. These are all turned into "bags of words", i.e., term frequency histograms, stored in an inverted index. Using this inverted index, one can find for any word the set of Wikipedia articles containing this word; in the vocabulary of Egozi, Markovitch and Gabrilovitch, "each word appearing in the Wikipedia corpus can be seen as triggering each of the concepts it points to in the inverted index."[1]

The output of the inverted index for a single word query is a list of indexed documents (Wikipedia articles), each given a score depending on how often the word in question occurred in them (weighted by the total number of words in the document). Mathematically, this list is an N-dimensional vector of word-document scores, where a document not containing the query word has score zero. To compute the relatedness of two words, one compares the vectors (say u and v) by computing the cosine similarity,

and this gives a numeric estimate of the semantic relatedness of the words. The scheme is extended from single words to multi-word texts by simply summing the vectors of all words in the text.[3]


ESA, as originally posited by Gabrilovich and Markovitch, operates under the assumption that the knowledge base contains topically orthogonal concepts. However, it was later shown by Anderka and Stein that ESA also improves the performance of information retrieval systems when it is based not on Wikipedia, but on the Reuters corpus of newswire articles, which does not satisfy the orthogonality property; in their experiments, Anderka and Stein used newswire stories as "concepts".[4] To explain this observation, links have been shown between ESA and the generalized vector space model.[5] Gabrilovich and Markovitch replied to Anderka and Stein by pointing out that their experimental result was achieved using "a single application of ESA (text similarity)" and "just a single, extremely small and homogenous test collection of 50 news documents".[1]


Word relatedness

ESA is considered by its authors a measure of semantic relatedness (as opposed to semantic similarity). On datasets used to benchmark relatedness of words, ESA outperforms other algorithms, including WordNet semantic similarity measures and skip-gram Neural Network Language Model (Word2vec).[6]

Document relatedness

ESA is used in commercial software packages for computing relatedness of documents.[7] Domain-specific restrictions on the ESA model are sometimes used to provide more robust document matching.[8]


Cross-language explicit semantic analysis (CL-ESA) is a multilingual generalization of ESA.[9] CL-ESA exploits a document-aligned multilingual reference collection (e.g., again, Wikipedia) to represent a document as a language-independent concept vector. The relatedness of two documents in different languages is assessed by the cosine similarity between the corresponding vector representations.

See also


  1. ^ a b c d Egozi, Ofer; Markovitch, Shaul; Gabrilovich, Evgeniy (2011). "Concept-Based Information Retrieval using Explicit Semantic Analysis" (PDF). ACM Transactions on Information Systems. 29 (2): 1–34. doi:10.1145/1961209.1961211. S2CID 743663. Retrieved January 3, 2015.
  2. ^ Gabrilovich, Evgeniy; Markovitch, Shaul (2006). Overcoming the brittleness bottleneck using Wikipedia: enhancing text categorization with encyclopedic knowledge (PDF). Proc. 21st National Conference on Artificial Intelligence (AAAI). pp. 1301–1306.
  3. ^ a b Gabrilovich, Evgeniy; Markovitch, Shaul (2007). Computing semantic relatedness using Wikipedia-based Explicit Semantic Analysis (PDF). Proc. 20th Int'l Joint Conf. on Artificial Intelligence (IJCAI). pp. 1606–1611.
  4. ^ Maik Anderka and Benno Stein. The ESA retrieval model revisited Archived 2012-06-10 at the Wayback Machine. Proceedings of the 32nd International ACM Conference on Research and Development in Information Retrieval (SIGIR), pp. 670-671, 2009.
  5. ^ Thomas Gottron, Maik Anderka and Benno Stein. Insights into explicit semantic analysis Archived 2012-06-10 at the Wayback Machine. Proceedings of the 20th ACM International Conference on Information and Knowledge Management (CIKM), pp. 1961-1964, 2011.
  6. ^ Kliegr, Tomáš, and Ondřej Zamazal. Antonyms are similar: Towards paradigmatic association approach to rating similarity in SimLex-999 and WordSim-353. Data & Knowledge Engineering 115 (2018): 174-193. (source may be paywalled, mirror)
  7. ^ Marc Hornick (November 17, 2017). "Explicit Semantic Analysis (ESA) for Text Analytics". Retrieved 31 March 2023.
  8. ^ Luca Mazzola, Patrick Siegfried, Andreas Waldis, Michael Kaufmann, Alexander Denzler. A Domain Specific ESA Inspired Approach for Document Semantic Description. Proceedings of the 9th IEEE Conf. on Intelligent Systems 2018 (IS), pp. 383-390, 2018.
  9. ^ Martin Potthast, Benno Stein, and Maik Anderka. A Wikipedia-based multilingual retrieval model Archived 2012-06-10 at the Wayback Machine. Proceedings of the 30th European Conference on IR Research (ECIR), pp. 522-530, 2008.