Methods and systems for rapid automatic keyword extraction for information retrieval and analysis. Embodiments can include parsing words in an individual document by delimiters, stop words, or both in order to identify candidate keywords. word scores for each word within the candidate keywords are then calculated based on a function of co-occurrence degree, co-occurrence frequency, or both. Based on a function of the word scores for words within the candidate keyword, a keyword score is calculated for each of the candidate keywords. A portion of the candidate keywords are then extracted as keywords based, at least in part, on the candidate keywords having the highest keyword scores.
|
1. A computer-implemented method of extracting keywords from an individual document, the method comprising:
Parsing an individual document by delimiters and stop words to identify candidate keywords;
Determining co-occurrences of words within the candidate keywords;
Calculating word scores for each word within the candidate keywords based on a function of co-occurrence degree, co-occurrence frequency, or both;
Calculating a keyword score for each candidate keyword based on a function of word scores for words within the candidate keyword; and
Selecting a portion of the candidate keywords to extract as keywords based, at least in part, on the candidate keywords with highest keyword scores.
11. A system for extracting keywords from an individual document, the system comprising:
A storage device, a communications interface, or both providing at least one individual document; and
A processor programmed to:
Parse the individual document by delimiters and stop words to identify candidate keywords;
Determine co-occurrences of words within the candidate keywords;
Calculate word scores for each word within the candidate keywords based on a function of co-occurrence degree, co-occurrence frequency, or both;
Calculate a keyword score for each candidate keyword based on a function of word scores for words within the candidate keyword; and
Select a portion of the candidate keywords to extract as keywords based, at least in part, on the candidate keywords with highest keyword scores.
2. The computer-implemented method of
3. The computer-implemented method of
4. The computer-implemented method of
5. The computer-implemented method of
6. The computer-implemented method of
7. The computer-implemented method of
8. The computer-implemented method of
9. The computer-implemented method of
10. The computer-implemented method of
Providing the keywords and a corpus of documents comprising a plurality of said individual documents;
Constructing a word list of all words in the corpus of documents;
Determining the keyword adjacency frequency of words in the corpus of documents;
Determining the keyword frequency in the corpus of documents;
Excluding words from the word list if the ratio of keyword adjacency frequency to keyword frequency is less than a predetermined value; and
Truncating the word list based on a predetermined criteria to form the stop word list.
12. The system of
13. The system of
14. The system of
15. The system of
16. The system of
17. The system of
18. The system of
19. The system of
Provide the keywords and a corpus of documents comprising a plurality of said individual documents;
Construct a word list of all words in the corpus of documents;
Determine the keyword adjacency frequency of words in the corpus of documents;
Determine the keyword frequency in the corpus of documents;
Exclude words from the word list if the ratio of keyword adjacency frequency to keyword frequency is less than a predetermined value; and
Truncate the word list based on a predetermined criteria to form the stop word list.
|
This invention claims priority from U.S. Provisional Patent Application No. 61/222,737, entitled “Feature Extraction Methods and Apparatus for Information Retrieval and Analysis,” filed Jul. 2, 2009.
This invention was made with Government support under Contract DE-ACO576RL01830 awarded by the U.S. Department of Energy. The Government has certain rights in the invention.
Keywords can provide a compact representation of the essential content in a document or a corpus of documents. Keywords are widely used to define queries within information retrieval (IR) systems because they are easy to define, revise, remember, and share. In comparison to mathematical signatures, keywords can be independent of a given corpus and can be applied across multiple corpora and IR systems. Keywords have also been applied to improve the functionality of IR systems and to enrich the presentation of search results. However, despite their utility for analysis, indexing, and retrieval, most documents do not have assigned keywords.
Most of the existing approaches for assigning keywords focus on manual assignment by professional curators who may use a fixed taxonomy, or rely on the author's judgment to provide a representative list. Accordingly, state-of-the-art methods commonly focus on automatically extracting words from documents as an aid to either suggest keywords for a professional indexer or generate summary features for documents that would otherwise be inaccessible. Early approaches to automatically extracting keywords focused on evaluating corpus-level statistics of individual words across the corpus of documents. However, corpus-level approaches can miss important keywords within the corpus that are not statistically discriminating. These corpus-oriented methods can also tend to operate on single words, which can be a limitation because a single word is often used in multiple and different contexts.
Keyword extraction methods that operate on individual documents can be applied to avoid the drawbacks of corpus-oriented methods. However, many of these document-oriented approaches rely on natural language processing and are not highly efficient. Accordingly, a need exists for automatic keyword extraction methods and apparatus that operate from individual documents and that are unsupervised, domain-independent, and language-independent.
The present invention is based, at least in part, on the observation that keywords frequently contain multiple words but rarely contain standard punctuation or stop words, such as the function words and, the, and of or other words with minimal lexical meaning. A keyword, as used herein, can refer to a sequence of one or more words that provides a compact summary of a document's content and has been applied to improve access for information retrieval and analysis systems. Stop words, as used herein, can refer to words that are considered to be uninformative and/or lexically meaningless. As such, stop words are typically dropped from indexes within information retrieval systems and are not included in various text analyses.
According to one embodiment of the present invention, rapid, automatic, keyword extraction (RAKE) methods and systems can include parsing words in an individual document by delimiters, stop words, or both in order to identify candidate keywords. Co-occurrences of words within these candidate keywords can be meaningful and, thus, are identified. In a preferred embodiment, word co-occurrences are identified without the application of an arbitrarily sized sliding window. Word scores for each word within the candidate keywords are then calculated based on a function of co-occurrence degree, co-occurrence frequency, or both. Based on a function of the word scores for words within the candidate keyword, a keyword score is calculated for each of the candidate keywords. A portion of the candidate keywords are then extracted as keywords based, at least in part, on the candidate keywords having the highest keyword scores.
Co-occurrences of words can be stored within a word co-occurrence graph. A word co-occurrence graph can represent words as nodes and word co-occurrences or word associations as weighted edges between word nodes. The word co-occurrence graph can also be represented or stored in matrix form.
In one embodiment, keyword scores for each candidate keyword are calculated by summing the word scores for each word within the candidate keywords.
In another embodiment, selection of the portion of the candidate keywords to extract as keywords is accomplished by selecting a predetermined number, T, of the candidate keywords having the highest keyword scores. Preferably, T is equal to one-third of the number of candidate keywords.
Embodiments of the present invention can further include identification of adjoining candidate keywords that adjoin one another at least twice in the individual document and in the same order. In such instances, a new candidate keyword can be created from the adjoining candidate keywords and can include any interior stop words.
In preferred embodiments, the keywords that have been extracted from one or more documents can be provided to a stop word list generator and used to generate or refine a list of stop words. An exemplary stop word list generator can be provided keywords and a corpus of documents comprising a plurality of individual documents from which a list of all words can be constructed. The generator can then determine the keyword adjacency frequency of words in the corpus of documents as well as the keyword frequency. Words from the word list are then excluded if the ratio of keyword adjacency frequency to keyword frequency is less than a predetermined value. The generator can then truncate the list based on a predetermined criteria to form the stop word list.
In some embodiments, the individual document is part of a dynamic collection of documents (e.g., a corpus that changes with time). Therefore, regardless of the current state of the corpus to which the individual document belongs, embodiments of the present invention will extract the same keywords. Accordingly, the present invention is not corpus-oriented, but is rather document-oriented, and can be said to be context independent. It can enable analytic methods that characterize changes within a text stream over time. Furthermore, consistent with the present embodiment, the invention can scale to vast collections of documents.
The purpose of the foregoing abstract is to enable the United States Patent and Trademark Office and the public generally, especially the scientists, engineers, and practitioners in the art who are not familiar with patent or legal terms or phraseology, to determine quickly from a cursory inspection the nature and essence of the technical disclosure of the application. The abstract is neither intended to define the invention of the application, which is measured by the claims, nor is it intended to be limiting as to the scope of the invention in any way.
Various advantages and novel features of the present invention are described herein and will become further readily apparent to those skilled in this art from the following detailed description. In the preceding and following descriptions, the various embodiments, including the preferred embodiments, have been shown and described. Included herein is a description of the best mode contemplated for carrying out the invention. As will be realized, the invention is capable of modification in various respects without departing from the invention. Accordingly, the drawings and description of the preferred embodiments set forth hereafter are to be regarded as illustrative in nature, and not as restrictive.
Embodiments of the invention are described below with reference to the following accompanying drawings.
The following description includes the preferred best mode of one embodiment of the present invention. It will be clear from this description of the invention that the invention is not limited to these illustrated embodiments but that the invention also includes a variety of modifications and embodiments thereto. Therefore the present description should be seen as illustrative and not limiting. While the invention is susceptible of various modifications and alternative constructions, it should be understood that there is no intention to limit the invention to the specific form disclosed, but, on the contrary, the invention is to cover all modifications, alternative constructions, and equivalents falling within the spirit and scope of the invention as defined in the claims.
Referring first to
According to the present embodiments, the input parameters for keyword extraction comprise a list of stop words (or stoplist), a set of phrase delimiters, and a set of word delimiters. The stop words, word delimiters, and phrase delimiters are used to partition the document text into candidate keywords, which can be sequences of content words as they occur in the text. Co-occurrences of words within these candidate keywords are meaningful and allow for the identification of word co-occurrence without the application of an arbitrarily sized sliding window. Word associations are thus measured in a manner that automatically adapts to the style and content of the text, enabling adaptive and fine-grained measurement of word co-occurrences that will be used to score candidate keywords.
Embodiments of the present invention begin keyword extraction on an individual document by parsing its text into a set of candidate keywords. First, the document text is split into an array of words by the specified word delimiters. This array is then split into sequences of contiguous words at phrase delimiters and stop word positions. Words within a sequence are assigned the same position in the text and together are considered a candidate keyword.
After every candidate keyword is identified and a graph of word co-occurrences is completed, which is shown as a matrix in
The word scores for each of the content words in the sample abstract are listed in
Because embodiments of the present invention can split candidate keywords by stop words, extracted keywords do not contain interior stop words. In some instances identifying keywords that contain interior stopwords, such as axis of evil, can be desirable and/or beneficial. To find these stopword-containing keywords, embodiments of the present invention can look for pairs of keywords that adjoin one another at least twice in the same document and in the same order. A new candidate keyword is then created as a combination of those keywords and their interior stop words. The score for the new keyword is the sum of its member keyword scores.
After candidate keywords are scored, the top T scoring candidate keywords are selected and extracted as keywords for the document. In preferred embodiments, T is ⅓ the number of words in the co-occurrence graph (i.e., the number content words). The sample abstract contains 28 content words, resulting in T=9 keywords.
To evaluate performance, the present embodiment of the invention was tested against a collection of technical abstracts used in the keyword extraction experiments reported by Hulth (2003. “Improved automatic keyword extraction given more linguistic knowledge.” In Proceedings of the 2003 conference on Empirical methods in natural language processing Volume 10, Association for Computational Linguistics) and by Mihalcea and Tarau (2004. TextRank: Bringing order into texts. In Proceedings of EMNLP. D. L. a. D. Wu. Barcelona, Spain, Association for Computational Linguistics: 404-411). The collection consists of 2000 Inspec abstracts for journal papers from Computer Science and Information Technology. The abstracts are divided into a training set with 1000 abstracts, a validation set with 500 abstracts, and a testing set with 500 abstracts. We followed the approach of Mihalcea and Tarau, using the testing set for evaluation because the present invention does not require a training set. Extracted keywords for each abstract are compared against the abstract's associated set of manually assigned uncontrolled keywords.
Because of increasing interest in energy conservation in large data centers, we also evaluated the computational cost associated with extracting keywords according to embodiments of the present invention and compared it to Mihalcea and Tarau's TextRank. TextRank is a graph-based ranking model for text processing.
In the instant example, TextRank's damping factor, d, was set to 0.85 and its convergence threshold to 0.0001, as recommended by Mihalcea and Tarau. However, the particular syntactic filters referenced by Mihalcea and Tarau were not accessible, so it was not possible to evaluate their exact computational cost.
To minimize disparity in the comparison, all parsing stages in the respective extraction methods are identical, TextRank accumulates co-occurrences in a window of size 2, and the instant embodiment of the present invention accumulates word co-occurrences within candidate keywords. After co-occurrences are tallied, the algorithms compute keyword scores according to their respective methods. The benchmark was implemented in Java and executed in the Java SE Runtime Environment (JRE) 6 on a computer workstation.
We calculated the total time for the instant embodiment of the present invention and for TextRank (as an average over 100 iterations) to extract keywords from the Inspec testing set of 500 abstracts, after the abstracts were read from files and loaded in memory. The instant embodiment extracted keywords from the 500 abstracts in 160 milliseconds. TextRank extracted keywords in 1002 milliseconds, which is more than six times the amount of computational resources.
Referring to
The present invention can be applied in many different systems and applications. For example, an automatically generated stoplist can be used to configure embodiments of the present invention on particular corpora, domains, and languages. According to the present invention, the automatically generated stoplist can be created from a set of documents for which keywords are defined. Aspects of the stoplist generation is based on the intuition that words adjacent to, and not within, keywords are less likely to be meaningful and therefore are good choices for stop words.
In one example, a stop list was automatically generated by first identifying for each abstract in the Inspec training set the words occurring adjacent to words in the abstract's uncontrolled keyword list. The frequency of each word occurring adjacent to a keyword was accumulated across the abstracts. Words that occurred more frequently within keywords than adjacent to them were excluded from the stoplist.
To evaluate automatic stoplist generation of the present invention, six stoplists were generated, 3 of which select words for the stoplist by term frequency (TF), and 3 that select words by term frequency but also exclude words from the stoplist whose keyword frequency was greater than their keyword adjacency frequency (KA). We refer to this latter set of stoplists as keyword adjacency (KA) stoplists since they primarily include words that are adjacent to and not within keywords.
Each of the stoplists was set as the input stoplist for the previously described keyword extraction, which was then run on the testing set of the Inspec corpus of technical abstracts. The table in
Because the generated KA stoplists leverage manually assigned keywords, preferred applications would be within existing digital libraries or IR systems and collections where defined keywords exist or are easily identified for a subset of the documents. Stoplists only need to be generated once for particular domains enabling keyword extraction to be applied according to the present invention to new and future articles, facilitating annotation and indexing of new documents.
The keywords extracted according to embodiments of the present invention have been characterized to determine how well they represent the essential content within a corpus of documents for which keywords have not been manually assigned. The characterization included applying embodiments of the present invention to the Multi-Perspective Question Answering (MPQA) Corpus. The MPQA Corpus consists of 535 news articles provided by the Center for the Extraction and Summarization of Events and Opinions in Text (CERATOPS). Articles in the MPQA Corpus are from 187 different foreign and U.S. news sources and date from June 2001 to May 2002.
The keywords were extracted from title and text fields of documents in the MPQA Corpus and a minimum document threshold of 2 was set to focus on keywords that are associated with multiple documents. Candidate keyword scores were based on word scores as deg(w)/freq(w) and as deg(w). Calculating word scores as deg(w)/freq(w), 517 keywords were extracted that were referenced by an average of 4.9 documents. Calculating word scores as deg(w), 711 keywords were extracted that were referenced by an average of 8.1 documents.
This difference in average number of referenced document counts is the result of longer keywords having lower frequency across documents. The word score metric deg(w)/freq(w) favors longer keywords and therefore results in extracted keywords that occur in fewer documents in the MPQA Corpus. In many cases a subject is occasionally presented in its long form and more frequently referenced in its shorter form. For example, referring to the table in
Because most documents are unique within any given corpus, one can expect to find variability in what documents are essentially about as well as how each document represents specific subjects. While some documents may be primarily about the kyoto protocol, greenhouse gas emissions, and climate change, other documents may only make references to those subjects. Documents in the former set will likely have kyoto protocol, greenhouse gas emissions, and climate change extracted as keywords whereas documents in the latter set will not.
In many applications, users have a desire to capture all references to extracted keywords. Accordingly, counts can be accumulated on how often each extracted keyword is referenced by documents in the corpus. The referenced document frequency of a keyword, rdf(k), is the number of documents in which the keyword occurred as a candidate keyword. The extracted document frequency of a keyword, edf(k), is the number of documents from which the keyword was extracted.
A keyword that is extracted from all of the documents in which it is referenced can be characterized as exclusive or essential, whereas a keyword that is referenced in many documents but extracted from a few may be characterized as general. Comparing the relationship of edf(k) and rdf(k) provides one way to characterize the exclusivity of a particular keyword and can be defined as the keyword exclusivity exc(k) as shown in Equation 1.
Of the 711 extracted keywords, 395 have an exclusivity score of 1, indicating that they were extracted from every document in which they were referenced. Within that set of 395 exclusive keywords, some occur in more documents than others and can therefore be considered more essential to the corpus of documents. A measure of how essential a keyword is can be defined as the essentiality of a keyword, ess(k), as shown in Equation 2.
ess(k)=exc(k)×edf(k) Equation 2
In addition to keywords that are essential to documents, keywords can also be characterized by how general they are to the corpus. In other words, how often was a keyword referenced by documents from which it was not extracted? In this case, the generality of a keyword, gen(k), can be defined as shown in Equation 3.
gen(k)=rdf(k)×(1.0−exc(k)) Equation 3
While a number of embodiments of the present invention have been shown and described, it will be apparent to those skilled in the art that many changes and modifications may be made without departing from the invention in its broader aspects. The appended claims, therefore, are intended to cover all such changes and modifications as they fall within the true spirit and scope of the invention.
Rose, Stuart J, Cowley, Wendy E, Crow, Vernon L, Cramer, Nicholas O
Patent | Priority | Assignee | Title |
10019492, | Dec 01 2015 | HUAWEI CLOUD COMPUTING TECHNOLOGIES CO , LTD | Stop word identification method and apparatus |
10224025, | Dec 14 2012 | Robert Bosch GmbH | System and method for event summarization using observer social media messages |
10452778, | Oct 13 2004 | Bloomberg Finance L.P. | System and method for managing news headlines |
10614108, | Nov 10 2015 | International Business Machines Corporation | User interface for streaming spoken query |
11315552, | Mar 23 2018 | Amazon Technologies, Inc | Responding with unresponsive content |
11461375, | Nov 10 2015 | International Business Machines Corporation | User interface for streaming spoken query |
11544303, | Mar 23 2018 | Amazon Technologies, Inc | Responding with unresponsive content |
11854040, | Mar 23 2018 | Amazon Technologies, Inc | Responding with unresponsive content |
8402022, | Mar 03 2006 | Amazon Technologies, Inc | Convergence of terms within a collaborative tagging environment |
9235563, | Jul 02 2009 | Battelle Memorial Institute | Systems and processes for identifying features and determining feature associations in groups of documents |
9349095, | Mar 03 2006 | Amazon Technologies, Inc. | Creation and utilization of relational tags |
9495467, | Oct 13 2004 | BLOOMBERG FINANCE L P | System and method for managing news headlines |
Patent | Priority | Assignee | Title |
4319085, | Apr 08 1980 | SIEMENS CORPORATE RESEARCH & SUPPORT, INC , A DE CORP | Speech recognition apparatus and method |
6304841, | Oct 28 1993 | International Business Machines Corporation | Automatic construction of conditional exponential models from elementary features |
6886010, | Sep 30 2002 | The United States of America as represented by the Secretary of the Navy; NAVY, UNITED STATES OF AMERICA, AS REPRESENTED BY THE SEC Y OF THE | Method for data and text mining and literature-based discovery |
7249012, | Nov 20 2002 | Microsoft Technology Licensing, LLC | Statistical method and apparatus for learning translation relationships among phrases |
7275061, | Apr 13 2000 | LINKAPEDIA,INC | Systems and methods for employing an orthogonal corpus for document indexing |
7627559, | Dec 15 2005 | Microsoft Technology Licensing, LLC | Context-based key phrase discovery and similarity measurement utilizing search engine query logs |
7860706, | Mar 16 2001 | Meaningful Machines LLC | Knowledge system method and appparatus |
7890539, | Oct 10 2007 | Raytheon BBN Technologies Corp | Semantic matching using predicate-argument structure |
20080162528, | |||
20090094021, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Sep 01 2009 | COWLEY, WENDY E | Battelle Memorial Institute | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 023206 | /0099 | |
Sep 01 2009 | CROW, VERNON L | Battelle Memorial Institute | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 023206 | /0099 | |
Sep 02 2009 | ROSE, STUART J | Battelle Memorial Institute | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 023206 | /0099 | |
Sep 08 2009 | CRAMER, NICHOLAS O | Battelle Memorial Institute | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 023206 | /0099 | |
Sep 09 2009 | Battelle Memorial Institute | (assignment on the face of the patent) | / | |||
Nov 05 2009 | BATTELLE MEMORIAL INSTITUTE, PACIFIC NORTHWEST DIVISION | U S DEPARTMENT OF ENERGY | CONFIRMATORY LICENSE SEE DOCUMENT FOR DETAILS | 023746 | /0670 |
Date | Maintenance Fee Events |
Aug 25 2015 | M2551: Payment of Maintenance Fee, 4th Yr, Small Entity. |
Aug 14 2019 | M2552: Payment of Maintenance Fee, 8th Yr, Small Entity. |
Oct 23 2023 | REM: Maintenance Fee Reminder Mailed. |
Apr 08 2024 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Mar 06 2015 | 4 years fee payment window open |
Sep 06 2015 | 6 months grace period start (w surcharge) |
Mar 06 2016 | patent expiry (for year 4) |
Mar 06 2018 | 2 years to revive unintentionally abandoned end. (for year 4) |
Mar 06 2019 | 8 years fee payment window open |
Sep 06 2019 | 6 months grace period start (w surcharge) |
Mar 06 2020 | patent expiry (for year 8) |
Mar 06 2022 | 2 years to revive unintentionally abandoned end. (for year 8) |
Mar 06 2023 | 12 years fee payment window open |
Sep 06 2023 | 6 months grace period start (w surcharge) |
Mar 06 2024 | patent expiry (for year 12) |
Mar 06 2026 | 2 years to revive unintentionally abandoned end. (for year 12) |