System and a Method for Generating Semantically Similar Sentences for Building a Robust SLM

Information

  • Patent Application
  • 20130018649
  • Publication Number
    20130018649
  • Date Filed
    July 13, 2011
    13 years ago
  • Date Published
    January 17, 2013
    12 years ago
Abstract
A system and method are described for generating semantically similar sentences for a statistical language model. A semantic class generator determines for each word in an input utterance a set of corresponding semantically similar words. A sentence generator computes a set of candidate sentences each containing at most one member from each set of semantically similar words. A sentence verifier grammatically tests each candidate sentence to determine a set of grammatically correct sentences semantically similar to the input utterance. Also note that the generated semantically similar sentences are not restricted to be selected from an existing sentence database.
Description
TECHNICAL FIELD

The invention generally relates to computer systems for natural language processing such as for automatic speech recognition (ASR), and more specifically to statistical language models used in such systems.


BACKGROUND ART

One specific example of a natural language processing application is an automatic speech recognition (ASR) system that tries to determine a representative meaning (e.g., text) corresponding to input speech. Typically, the input speech is processed into a sequence of digital frames. Each frame can be thought of as a multi-dimensional vector that represents various characteristics of the speech signal present during a short time window of the speech. In a continuous speech recognition system, variable numbers of frames are organized as “utterances” representing a period of speech followed by a pause which in real life loosely corresponds to a spoken sentence or phrase.


The ASR system compares the input utterances to find statistical acoustic models that best match the vector sequence characteristics and determines corresponding representative text associated with the acoustic models. When framing the problem in a statistical context, it is often discussed in terms of the well-known Bayes formula. That is, if given some input observations A, the probability that some string of words W were spoken is represented as P(W|A), where the ASR system attempts to determine the most likely word string:







W
^

=

arg







max
W



P


(

W
|
A

)








Given a system of statistical acoustic models, this formula can be re-expressed as:







W
^

=

arg







max
W




P


(
W
)




P


(

A
|
W

)









where P(A|W) corresponds to the acoustic models and P(W) represents the value of a statistical language model reflecting the probability of given word in the recognition vocabulary occurring.


Modern acoustic models typically use probabilistic state sequence models such as hidden Markov models (HMMs) that model speech sounds (usually phonemes) using mixtures of probability distribution functions, typically Gaussians. Phoneme models often represent phonemes in specific contexts, referred to as PELs (Phonetic Elements), e.g. triphones or phonemes with known left and/or right contexts. State sequence models can be scaled up to represent words as connected sequences of acoustically modeled phonemes, and phrases or sentences as connected sequences of words. When the models are organized together as words, phrases, and sentences, additional language-related information is also typically incorporated into the models in the form of a statistical language model.


The words or phrases associated with the best matching model structures are referred to as recognition candidates or hypotheses. A system may produce a single best recognition candidate—the recognition result—or multiple recognition hypotheses in various forms such as an N-best list, a recognition lattice, or a confusion network. Further details regarding continuous speech recognition are provided in U.S. Pat. No. 5,794,189, entitled “Continuous Speech Recognition,” and U.S. Pat. No. 6,167,377, entitled “Speech Recognition Language Models,” the contents of which are incorporated herein by reference.


SUMMARY

Embodiments of the present invention are directed to a system and method for generating semantically similar sentences for a statistical language model. A semantic class generator determines for each word in an input utterance a set of corresponding semantically similar words. A sentence generator computes a set of candidate sentences each containing at most one member from each set of semantically similar words. A sentence verifier grammatically tests each candidate sentence to determine a set of grammatically correct sentences semantically similar to the input utterance. Also note that the generated semantically similar sentences are not restricted to be selected from an existing sentence database.


In specific embodiments may also include an existing statistical language model to which the grammatically correct sentences are added. For example, the existing statistical language model may be for a natural language processing application such as a user query interface or an automatic speech recognition application.


The semantic class generator may determine the corresponding semantically similar words based on using a generic ontology or a domain-specific ontology such as a domain-specific dictionary. The sentence verifier may grammatically test each candidate sentence using an existing language model, a syntactic parser, and/or a grammar checker.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 shows various hardware components of an embodiment of an ASR system which uses a language model according to the present invention.



FIG. 2 shows the basic architecture of an embodiment for adding semantically similar sentences.



FIG. 3 shows an example of the text flows through an embodiment of the present invention.





DETAILED DESCRIPTION

Natural languages provide multiple different ways to express similar or the same situations. For example, the utterance “I want to change my home address” could be expressed as “I want to update my house address” or “I wish to modify my home address”. Knowledge of the various ways of expressing a situation is useful for building language models for speech recognition and other natural language applications. Embodiments of the present invention are directed to generating a set of semantically similar sentences that correspond to a given input sentence. This can be useful, for example, for building better query interfaces for natural language applications.



FIG. 1 shows various hardware components of an embodiment of an ASR system which uses a language model according to the present invention. A computer system 10 includes a speech input microphone 11 which is connected through a suitable preamplifier 13 to an analog-to-digital (A/D) converter 15. A front-end speech pre-processor 17 typically performs a Fourier transform so as to extract spectral features to characterize the input speech as a sequence of representative multi-dimensional vectors. A speech recognition processor 12, e.g., an Intel Core i7 processor or the like, is programmed to run one or more specialized computer software processes to determine a recognition output corresponding to the speech input. To that end, processor memory 120, e.g., random access memory (RAM) and/or read-only memory (ROM) stores the speech processing software routines, the speech recognition models and data for use by the speech recognition processor 12. The recognition output may be displayed, for example, as representative text on computer workstation display 14. Such a computer workstation would also typically include a keyboard 16 and a mouse 18 for user interaction with the system 10.


Of course, many other typical arrangements are also familiar such as an ASR implemented for a mobile device such as a cell phone, ASR for the cabin of an automobile, client-server based ASR, etc. And while specific embodiments of the present invention are described herein in terms of an ASR-based arrangement, the invention is not limited to such systems and is broadly useful in the general field of natural language processing, especially for applications using a statistical language model, for example, in user interfaces for natural language dialog systems, etc.



FIG. 2 shows the basic architecture of one specific embodiment for generating semantically similar sentences for a statistical language model, and FIG. 3 shows an example of the text flows through such an embodiment. Initially, a given input sentence 201—in this case, “I want to change my home address.”—is input to a semantic class generator 202 that provides a set of corresponding semantically similar words 203 for each word in the input sentence 201. Specifically, the semantic class generator 202 can be based on using generic ontologies such as WordNet, or domain-specific dictionaries that can be built manually or automatically.


Using the set of semantically similar words 203 from the semantic class generator 201, a sentence generator 204 computes a set of candidate sentences 301 each containing at most one member from each set of semantically similar words 203 that contain at most one word from each set. For each candidate sentence 301, a sentence verifier 205 uses a combination of language model, syntactic parsers and grammar checker to grammatically test each candidate sentence to determine a set of grammatically correct sentences 206 that are semantically similar to the input utterance 201.


The grammatically correct sentences 206 from the sentence verifier 205 can be added to an existing statistical language model, for example, in a natural language processing application such as a user query interface or an automatic speech recognition application. Incorrect variations 302 that fail the testing of the sentence verifier 205 can be discarded or saved for later study.


Embodiments of the invention may be implemented in whole or in part in any conventional computer programming language. For example, preferred embodiments may be implemented in a procedural programming language (e.g., “C”) or an object oriented programming language (e.g., “C++”, Python). Alternative embodiments of the invention may be implemented as pre-programmed hardware elements, other related components, or as a combination of hardware and software components. For example, a pseudo code representation of such an embodiment might be set forth as follows:

















Process SemanticallySimilarSentences



  determine semantically_similar_words (input utterance)



  compute candidate_sentences (semantically_similar_words)



  test grammatically_correct_sentences (candidate_sentences)










Embodiments can be implemented in whole or in part as a computer program product for use with a computer system. Such implementation may include a series of computer instructions fixed either on a tangible medium, such as a computer readable medium (e.g., a diskette, CD-ROM, ROM, or fixed disk) or transmittable to a computer system, via a modem or other interface device, such as a communications adapter connected to a network over a medium. The medium may be either a tangible medium (e.g., optical or analog communications lines) or a medium implemented with wireless techniques (e.g., microwave, infrared or other transmission techniques). The series of computer instructions embodies all or part of the functionality previously described herein with respect to the system. Those skilled in the art should appreciate that such computer instructions can be written in a number of programming languages for use with many computer architectures or operating systems. Furthermore, such instructions may be stored in any memory device, such as semiconductor, magnetic, optical or other memory devices, and may be transmitted using any communications technology, such as optical, infrared, microwave, or other transmission technologies. It is expected that such a computer program product may be distributed as a removable medium with accompanying printed or electronic documentation (e.g., shrink wrapped software), preloaded with a computer system (e.g., on system ROM or fixed disk), or distributed from a server or electronic bulletin board over the network (e.g., the Internet or World Wide Web). Of course, some embodiments of the invention may be implemented as a combination of both software (e.g., a computer program product) and hardware. Still other embodiments of the invention are implemented as entirely hardware, or entirely software (e.g., a computer program product).


Although various exemplary embodiments of the invention have been disclosed, it should be apparent to those skilled in the art that various changes and modifications can be made which will achieve some of the advantages of the invention without departing from the true scope of the invention.

Claims
  • 1. A semantic processing system for generating semantically similar sentences, the system comprising: a semantic class generator that determines for each word in an input utterance a set of corresponding semantically similar words;a sentence generator that computes a set of candidate sentences each containing at most one member from each set of semantically similar words; anda sentence verifier that grammatically tests each candidate sentence to determine a set of grammatically correct sentences semantically similar to the input utterance.
  • 2. A system according to claim 1, further comprising: an existing statistical language model to which the grammatically correct sentences are added.
  • 3. A system according to claim 2, wherein the existing statistical language model is for a natural language processing application.
  • 4. A system according to claim 3, wherein the natural language processing application includes a user query interface.
  • 5. A system according to claim 3, wherein the natural language processing application includes an automatic speech recognition application.
  • 6. A system according to claim 1, wherein the semantic class generator determines the corresponding semantically similar words based on using a generic ontology.
  • 7. A system according to claim 1, wherein the semantic class generator determines the corresponding semantically similar words based on using a domain-specific ontology.
  • 8. A system according to claim 1, wherein the sentence verifier grammatically tests each candidate sentence using an existing language model.
  • 9. A system according to claim 1, wherein the sentence verifier grammatically tests each candidate sentence using a syntactic parser.
  • 10. A system according to claim 1, wherein the sentence verifier grammatically tests each candidate sentence using a grammar checker.
  • 11. A method of generating semantically similar sentences for a statistical language model, the method comprising: determining for each word in an input utterance a set of corresponding semantically similar words;computing a set of candidate sentences each containing at most one member from each set of semantically similar words; andgrammatically testing each candidate sentence to determine a set of grammatically correct sentences semantically similar to the input utterance.
  • 12. A method according to claim 11, further comprising: adding the grammatically correct sentences to an existing statistical language model.
  • 13. A method according to claim 12, wherein the existing statistical language model is for a natural language processing application.
  • 14. A method according to claim 13, wherein the natural language processing application includes a user query interface.
  • 15. A method according to claim 13, wherein the natural language processing application includes an automatic speech recognition application.
  • 16. A method according to claim 11, wherein determining the corresponding semantically similar words is based on using a generic ontology.
  • 17. A method according to claim 11, wherein determining the corresponding semantically similar words is based on using a domain-specific ontology.
  • 18. A method according to claim 11, wherein grammatically testing each candidate sentence includes testing using an existing language model.
  • 19. A method according to claim 11, wherein grammatically testing each candidate sentence includes testing using a syntactic parser.
  • 20. A method according to claim 11, wherein grammatically testing each candidate sentence includes testing using a grammar checker.
  • 21. A computer program product implemented in a tangible computer readable storage medium for generating semantically similar sentences for a statistical language model, the product comprising: program code for determining for each word in an input utterance a set of corresponding semantically similar words;program code for computing a set of candidate sentences each containing at most one member from each set of semantically similar words; andprogram code for grammatically testing each candidate sentence to determine a set of grammatically correct sentences semantically similar to the input utterance.
  • 22. A product according to claim 21, further comprising: program code for adding the grammatically correct sentences to an existing statistical language model.
  • 23. A product according to claim 22, wherein the existing statistical language model is for a natural language processing application.
  • 24. A product according to claim 23, wherein the natural language processing application includes a user query interface.
  • 25. A product according to claim 23, wherein the natural language processing application includes an automatic speech recognition application.
  • 26. A product according to claim 21, wherein the program code for determining the corresponding semantically similar words is based on using a generic ontology.
  • 27. A product according to claim 21, wherein the program code for determining the corresponding semantically similar words is based on using a domain-specific ontology.
  • 28. A product according to claim 21, wherein the program code for grammatically testing each candidate sentence includes program code for testing using an existing language model.
  • 29. A product according to claim 21, wherein the program code for grammatically testing each candidate sentence includes program code for testing using a syntactic parser.
  • 30. A product according to claim 21, wherein the program code for grammatically testing each candidate sentence includes program code for testing using a grammar checker.