610 likes | 1.08k Views
Measures of Text Similarity. Presented By : Ehsan Asgarian. Agenda. Introduction Syntactical (String-Based) Similarity Character-Based (word level) Term-Based (sentence or document level) Semantic (knowledge-Based) Similarity Path Length Information Content
E N D
Measures of Text Similarity Presented By: Ehsan Asgarian Ferdowsi University of Mashhad
Agenda • Introduction • Syntactical (String-Based) Similarity • Character-Based (word level) • Term-Based (sentence or document level) • Semantic (knowledge-Based) Similarity • Path Length • Information Content • Relatedness (Dictionary-based method) • Statistical (Corpus-Based) Similarity
Why text similarity? Used everywhere in NLP • Information retrieval (Query vs Document) • Text classification (Document vs Category) • Word-sense disambiguation (Context vs Context) • Automatic evaluation • Machine translation (Gold Standard vs Generated) • Text summarization (Summary vs Original)
Distance Function A metric on a set X is a function d : X × X → R (where R is the set of real numbers). For all x, y, z in X, this function is required to satisfy the following conditions: • d(x, y) ≥ 0 (non-negativity, or separation axiom) • d(x, y) = 0 if and only if x = y (coincidence axiom) • d(x, y) = d(y, x) (symmetry) • d(x, z) ≤ d(x, y) + d(y, z) (subadditivity / triangle inequality)
Agenda • Introduction • Syntactical (String-Based) Similarity • Character-Based (word level) • Term-Based (sentence or document level) • Semantic (knowledge-Based) Similarity • Path Length • Information Content • Relatedness (Dictionary-based method) • Statistical (Corpus-Based) Similarity
Syntactical (String-Based) Similarity • Term-Based • Block Distance • Euclidean Distance • Cosine Similarity • Jaccard Similarity • Dice's Coefficient • Tanimoto • Tversky • Matching Coefficient • Overlap Coefficient • Character-Based • LCS • Levenshtein • N-gram • Jaro • Jaro-Winkler • Soundex (phonetic algorithms) • …
Agenda • Introduction • Syntactical (String-Based) Similarity • Character-Based (word level) • Term-Based (sentence or document level) • Semantic (knowledge-Based) Similarity • Path Length • Information Content • Relatedness (Dictionary-based method) • Statistical (Corpus-Based) Similarity
LCS & Levenshtein Distance • LCS (Longest Common SubString) : algorithm considers the similarity between two strings is based on the length of contiguous chain of characters that exist in both strings. • Levenshtein : defines distance between two strings by counting the minimum number of operations needed to transform one string into the other, where an operation is defined as an insertion, deletion, or substitution of a single character, or a transposition of two adjacent characters.
N-gram Distance • N-gram is a sub-sequence of n items from a given sequence of text. • N-gram similarity algorithms compare the n-grams from each character or word in two strings. • Distance is computed by dividing the number of similar n-grams by maximal number of n-grams.
JaroDistance • Jarois based on the number and order of the common characters between two strings; it takes into account typical spelling deviations and mainly used in the area of record linkage. • where: m: is the number of matching characters. (Two characters from s1 and s2 respectively, are considered matching only if they are the same and not farther than:) t: is half the number of transpositions.
Jaro-Winkler Distance • Jaro-Winkler is an extension of Jaro distance; it uses a prefix scale which gives more favorable ratings to strings that match from the beginning for a set prefix length: • where: |Pref|:is the length of common prefix at the start of the string up to a maximum of 4 characters. p: is a constant scaling factor for how much the score is adjusted upwards for having common prefixes. (should not exceed 0.25, otherwise the distance can become larger than 1. The standard value for this constant in Winkler's work is p=0.1) bt: The boost threshold in Winkler's implementation was 0.7
Example • Given the strings Ehsanand Eihhooswe find: m = 2 (Note that the two ‘S’s are not considered matches because they are outside the match window of 3.), |s1|=5 , |s2| = 7 There is mismatched character (i/h) leading to : t = 1/2 • To find the Jaro–Winkler score using the standard weight p=0.1, we continue to find: |pref| = 1 Thus:
Character-Based Similarity (cont.) • Needleman-Wunsch(used in bioinformatics to align protein or nucleotide sequences) • Smith-Waterman (performs local sequence alignment) • Soundex (phonetic algorithms): is a phonetic algorithm for indexing names by sound, as pronounced in English. • Keyboard-Key Distance • …
Agenda • Introduction • Syntactical (String-Based) Similarity • Character-Based (word level) • Term-Based (sentence or document level) • Semantic (knowledge-Based) Similarity • Path Length • Information Content • Relatedness (Dictionary-based method) • Statistical (Corpus-Based) Similarity
Syntactical (String-Based) Similarity • Term-Based (syntactic) • Block Distance • Euclidean Distance • Cosine Similarity • Jaccard Similarity • Dice's Coefficient • Tanimoto • Tversky • Matching Coefficient • Overlap Coefficient • Character-Based • LCS • Levenshtein • N-gram • Jaro • Jaro-Winkler • Soundex (phonetic algorithms) • …
Example: Term vector space NormalizeTokenizeStemmingStop Word Removal
Hamming & Euclidean Distance • Hamming (Block Distance, L1 distance, city block distance and Manhattan distance) :In information theory, the Hamming distance between two strings of equal length is the sum of the differences of their corresponding components. • Euclidean distance or L2 distance : is the square root of the sum of squared differences between corresponding elements of the two vectors.
Matching & Overlapcoefficient • Simple Matching coefficient : Number of terms (variables) in which document (object) s1 and s2 mismatch / Number of terms (variables) : • Overlap coefficient : The overlap coefficient is a similarity measure related to the Jaccard index that measures the overlap between two sets, and is defined as the size of the intersection divided by the smaller of the size of the two sets:
Jaccard & Sørensen–Dice Distance • Jaccard: The Jaccard coefficient measures similarity between finite sample sets, and is defined as the size of the intersection divided by the size of the union of the sample sets. • Sørensen–Dice (Dice's coefficient) :Sørensen's original formula was intended to be applied to presence/absence data, and is :
Tanimoto & TverskyDistance • Tanimoto : Tanimoto distance is often referred to, erroneously, as a synonym for Jaccard distance. • Tversky: The Tversky index can be seen as a generalization of Dice's coefficient and Tanimoto coefficient. • Setting produces a=b=1 the Tanimotocoefficient; setting produces a=b=0.5 Dice's coefficient.
Agenda • Introduction • Syntactical (String-Based) Similarity • Character-Based (word level) • Term-Based (sentence or document level) • Semantic (knowledge-Based) Similarity • Path Length • Information Content • Relatedness (Dictionary-based method) • Statistical (Corpus-Based) Similarity
Semantic (knowledge-Based) Similarity • Path Length • Simple Path Length • Wu & Palmer • Leacock & Chodorow • Information Content • Resnik • Lin • Jiang & Conrath • Relatedness (Dictionary-based method) • Hirst-St.Onge (HSO) • Lesk • vector pairs
Agenda • Introduction • Syntactical (String-Based) Similarity • Character-Based (word level) • Term-Based (sentence or document level) • Semantic (knowledge-Based) Similarity • Path Length • Information Content • Relatedness (Dictionary-based method) • Statistical (Corpus-Based) Similarity
Definitions and Notation • Pathlen(c1, c2): number of edges in shortest path • depth(ci) : The depth of a node is the length of the path to it from the global root, i.e.,depth(ci)=pathlen(root,ci). • LCS(c1,c2):Least Common Subsumer is lowest node in hierarchy that is a hypernym of c1 & c2. • rel(c1,c2):for semantic relatedness between two conceptsc1andc2 , the relatedness rel(w1,w2) between two words w1and w2 can be calculated as Where s(wi) is “the set of concepts in the taxonomy that are senses of word wi” (Resnik 1995).
Path length • path-length based similarity:
Leacock & Chodorow • L&Chmeasure returns a score denoting how similar two word senses are, based on the shortest path that connects the senses and the maximum depth of the taxonomy in which the senses occur.
Wu and Palmer • W&P measure returns a score denoting how similar two word senses are, based on the depth of the two senses in the taxonomy and that of their Least Common Subsumer.
Agenda • Introduction • Syntactical (String-Based) Similarity • Character-Based (word level) • Term-Based (sentence or document level) • Semantic (knowledge-Based) Similarity • Path Length • Information Content • Relatedness (Dictionary-based method) • Statistical (Corpus-Based) Similarity
Information Content • P(C) = probability of seeing a concept of type C in a large corpus = probability of seeing instances of that concept. • Where words(c)is set of words subsumed by concept c, N is the number of words in corpus and also in thesaurus. • P(root)=1 since all words are subsumed by root concept, • The lower a concept in the hierarchy, the lower the probability
Information Content (cont.) Train probabilities by counting in a corpus: each word counts as an occurrence of all concepts “containing” it
Information Content (cont.) • Based on information content :
Information Content (cont.) e.g. corpus size = 10000 words IC(vehicle) = -log(75/10000) = 2.12 IC(caboose) = -log(10/10000) = 3 IC(freight car) = -log(1/10000) = 4 IC(coupe) = -log(14/10000) = 2.85 IC(sedan) = -log(16/10000) = 2.82 IC(taxi) = -log(34/10000) = 2.46 …
Resnik • Resnikis equal to the information content (IC) of the Least Common Subsumer (most informative subsumer). This means that the value will always be greater-than or equal-to zero. The upper bound on the value is generally quite large and varies depending upon the size of the corpus used to determine information content values.
Lin & Jiang-Conrath • Lin : The lin measure scales the information content of the Least Common Subsumerby the sum of the information content of concepts c1 and c2 themselves. • Jiang-Conrath : takes the difference of this sum and the information content of the Least Common Subsumer.
Agenda • Introduction • Syntactical (String-Based) Similarity • Character-Based (word level) • Term-Based (sentence or document level) • Semantic (knowledge-Based) Similarity • Path Length • Information Content • Relatedness (Dictionary-based method) • Statistical (Corpus-Based) Similarity
Lesk • Lesk algorithm used for word sense disambiguation • Dictionary-based method: makes use of glosses, a property of dictionaries • Lesk : two concepts/senses are similar if their glosses contain overlapping words
Extended Lesk • Extended Lesk measure: • Extended gloss overlap: two concepts/senses are similar if their glosses contain overlapping words • Let RELs be the set of possible WordNet relations with glosses we compare • For each n-word phrase seen in both glosses, eLesk adds n2; longer overlaps are rare, and should be weighted more heavily
Extended Lesk (Example) • drawing paper: paper that is specially prepared for use in drafting • decal: the art of transferring designs from specially preparedpaper to a wood or glass or metal surface overlap(decal, drawing paper)=12+22=5 if considering hyponyms only,
Hirst-St.Onge (HSO) • hsomeasure works by finding lexical chains linking the two word senses. • Where C and k are constants (in practice, they used C=8 and k=1), and turns(c1 ,c2) is the number of times the path between c1 and c2 changes direction.
vector pairs • vector measure creates a co–occurrence matrix for each word used in the WordNet glosses from a given corpus, and then represents each gloss/concept with a vector that is the average of these co–occurrence vectors. • where c1 and c2 are the two given concepts, v1 and v2 are the gloss vectors corresponding to the concepts and angle returns the angle between vectors. .
Agenda • Introduction • Syntactical (String-Based) Similarity • Character-Based (word level) • Term-Based (sentence or document level) • Semantic (knowledge-Based) Similarity • Path Length • Information Content • Relatedness (Dictionary-based method) • Statistical (Corpus-Based) Similarity
Statistical (Corpus-Based) Similarity Corpus-Based similarity is a semantic similarity measure that determines the similarity between words according to information gained from large corpora: • PMI • LSA • ESA • pLSI • NMF • LDA • DISCO • …