This application claims priority under 35 U.S.C. §119 to Japanese Patent Application No. 2006-350508 filed Dec. 26, 2006, the entire text of which is specifically incorporated by reference herein.
The present invention relates to a method for dividing speech. In particular, the present invention relates to a method for dividing speech by use of acknowledgement responses.
In a transcription process on telephone conversation contents in an operator-service support system and the like, a speech of an operator and that of a customer are separately recorded and converted into text data. Conventionally, in order to efficiently search a recorded speech, a position where a predetermined keyword such as a product name is spoken is recorded, and the timestamp of the position is used as an index. The transcription process is performed by specifying a position of the keyword with automatic speech recognition and the like, and then by replaying the speech of a corresponding part. However, information on the conversation contents cannot be accurately extracted in such a method, since the method does not effectively use the customer's speech, particularly an acknowledgement. To be specific, it is difficult to accurately recognize and analyze a speech from a voice stream, since the speech is not divided into appropriate utterance.
An example of a conventional technique is disclosed in Japanese Patent Application Laid-open Publication No. 2006-276754.
The present invention has been made in view of the aforementioned technical problems. An object of the present invention is to divide a conversational dialog into speech units, what is called an utterance in linguistics by use of acknowledgement responses (hereinafter, simply called acknowledgements). In addition, another object of the invention is to accurately recognize a speech from a voice stream.
In order to achieve the aforementioned objects, an aspect of the present invention is to provide an apparatus for dividing a conversational dialog into utterance. The apparatus is configured to include: a word database for storing spellings and pronunciations of words; a grammar database for storing syntactic rules on words; a pause detecting section which detects a pause location in a channel taking a turn, that is to say speaker's channel, hereafter a main speech, among conversational dialogs inputted in at least two channels; an acknowledgement detecting section which detects an acknowledgement location in a channel not speaking (listener's channel); a boundary-candidate extracting section which extracts boundary candidates in the main speech, by extracting the pauses existing within a predetermined range before and after a base point that is the acknowledgement location; and a recognizing unit which outputs a word string of the speech segmented by one of the extracted candidates after dividing the segmented speech into optimal utterance in reference to the word database and grammar database.
In addition, the grammar database may include fixed-phrase grammar, acknowledgement grammar and recognition grammar. Moreover, the fixed-phrase grammar may include fixed phrases for starting and ending a confirmation, and the word database may include spellings and pronunciations of the fixed phrases for starting and ending a confirmation. Then, the apparatus may include a recognition-target segment determination unit which determines in advance a recognition target segment to be divided into utterance, by referring to the fixed-phrase grammar.
Another aspect of the present invention is to provide a method for dividing a conversational dialog into utterance by use of conversational dialogs inputted in separated channels, by use of a word database in which spellings and pronunciations of words are described, and by use of a grammar database in which grammar including syntactic rules on words is described. The method includes the steps of: detecting a pause location in a channel making a main speech; detecting an acknowledgement location in a channel not making the main speech; extracting boundary candidates in the main speech by extracting pauses existing within a predetermined range before and after a base point that is the acknowledgement location; and outputting a word string of the speech segmented by one of the extracted boundary candidates, after dividing the segmented speech into optimal utterance in reference to the word database and grammar database.
For a more complete understanding of the present invention and the advantage thereof, reference is now made to the following description taken in conjunction with the accompanying drawings.
Note that an acknowledgement is a response for making a confirmation in response to speech of a conversation partner. Typically, an acknowledgement is a back-channel feedback which is a short response made to a conversation partner with a main speaker unchanged in a conversation. In conventional techniques, such acknowledgements are not positively used in dividing and recognizing speech, but rather are regarded as unnecessary. However, three acknowledgements are registered as examples in the aforementioned acknowledgement grammar, and other acknowledgements can be added as needed to the acknowledgement grammar.
To the boundary extracting unit 120, continuous conversational dialogs 110, that is, voice streams are inputted in a plurality of channels corresponding to the respective speakers. By use of a following method of the present invention, the boundary extracting unit 120 passes, to the recognizing unit 130, voice data of the channel mainly speaking, and boundary candidates for dividing the main speech into utterance. Specifically, a boundary candidate is passed by use of a time of the initial point of the voice stream, regarding the initial point as a base point of the boundary candidate. The recognizing unit 130 makes recognition using the received voice data and the aforementioned boundary candidates by referring to the recognition grammar and to a dictionary, and then outputs a word string 160 which is a recognition result corresponding to a segment obtained by dividing the voice data by dividing positions (strings) recognized as optimal. Further, each of the word strings is, for example, configured of a segment and a recognized content which are expressed as XXXX for segment 1, YYYY for segment 2 and so on. Preferably, the word string 160 is further passed to a sentence comprehending unit or the like in some applications. However, a description of the sentence comprehending unit will be omitted since the processing thereof is independent from the present invention.
Hereinafter, a detailed description on the processing of the present invention will be provided with reference to
Firstly, in step 210, a time (ts, te) of a speech segment to be recognized is recorded, by matching the speech of the channel corresponding to the main speech, with the fixed-phrase grammar. This processing is equivalent to 310 in
Steps 220 to 250 are the processing executed in the boundary extracting unit 120 for extracting boundaries (dividing position) in a speech. The boundary extracting unit 120 extracts boundary (dividing position) candidates in a speech in the following manner of: firstly, detecting pause locations in the channel which makes a main speech and detecting acknowledgement locations in the channel which does not make the main speech; and secondly, extracting pauses each existing within a certain time period before and after an acknowledgement location.
To be more precise, in step 220, the pause detecting section 122 detects pause locations in the recognition target segment in C2. This processing is equivalent to 320 in
In step 230, the acknowledgement detecting section 124 detects an acknowledgement location in the recognition target segment in channel C1 which is for the respondent (listener), by matching the speech with the acknowledgement grammar. In the acknowledgement grammar, expressions of acknowledgement, for example, words and phrases such as “hai (yes)” and “ee (OK)” are registered. This processing is equivalent to 330 in
In the processing executed in step 240 and following steps, the speech recognition is performed by dividing the recognition target segment by use of the pause locations and acknowledgement locations. This processing is equivalent to 340 in
In step 250, the recognizing unit 130 performs recognition on the segment between the dividing start position and each of the boundary candidates extracted in step 240. Thereafter, the recognizing unit 130 recognizes the segment with the highest likelihood as an utterance, and thereby outputs a word string. This processing is equivalent to 350 in
One of a variety of possible likelihoods is a likelihood calculated on the basis of a probability P (X|W) that, given an outputted word string, an acoustic feature amount X is outputted from the target segment ((ts, p2) in this embodiment), where W denotes the word string. This value can be obtained consequently, when the recognizing unit 130 matches the string of acoustic feature amount with the acoustic model. Since many studies have been made on the aforementioned likelihoods and confidence measures in the field of speech recognition, there are various possible methods for calculating the probability value. In step 250, a determination of a divided segment based on the recognition results and likelihoods may be made by using a statistical language model instead of using the recognition grammar. In such a case, the learning for generating the language model from a written learning text is performed with a sentence start/end symbols added to each location corresponding to the acknowledgement. Hence, the generated language model is used in the recognition. In the case of using the statistical language model, the likelihood may be calculated by using a product P(W)·P(X|W) obtained by multiplying the probability P (X|W) of outputting the acoustic feature amount X, by the probability P(W) of outputting the language model.
In step 255, it is determined whether or not the processing is completed up to the end of the recognition target segment. If the processing is completed, the processing is terminated, while if not, the processing continues to step 260.
In step 260, the dividing start position is changed to the dividing end position determined in step 250, namely, the right end of segment B, denoted by p2. Then, steps 240 to 260 are repeated to the end of the recognition target segment. This processing is equivalent to 360 of
Next, an example of a hardware configuration of the present invention will be explained. Needless to say, each of the blocks shown in
The CPU 500 operates in accordance with programs stored in the ROM 530, a BIOS and the RAM 540, and thereby controls each section. The graphic controller 570 acquires graphic data generated in a buffer inside the RAM 540, by the CPU 500 and the like, and then displays the data on the display 575. Otherwise, the graphic controller 570 may include a buffer therein to store graphic data generated by the CPU 500 and the like. To be more specific, voice streams are inputted in a plurality of channels from the sound input/output device 565, and then are stored in the storage device 580 via the input/output controller 520. In the storage device 580, the word database 140 and the grammar database 150 are stored. Inputted and stored conversational dialogs of plural channels and these dictionaries are used to accurately divide and recognize a main speech through a computing operation by the CPU 500. This computing operation is performed by loading to the memory 540 and then executing a program for speech segmentation and recognition of the present invention. Output results of speech segmentation and a word string are displayed on the display 575.
The communication interface 550 communicates with outer communication devices via a network. The information processing apparatus 501 can also receive conversational dialogs from the outside via the communication interface 550, perform speech segmentation and recognition, and then transmit the result to an outer information processing apparatus via the communication interface 550. Incidentally, any one of wired, wireless, infrared connections and a short distance radio connection such as BLUETOOTH can be employed to build the network, and any kind of network can be used without adding any alterations in order to implement the present invention. The storage device 580 stores codes and data for a program of the present invention, an application, an OS and the like used by the computer 501. The multi-combo drive 590 reads programs or data from the media 595 such as a CD or a DVD, and thereafter the read programs and data are loaded to the PAM 540 to be used by the CPU 500. Instead, the program and dictionaries of the present invention may be provided from an external recording media.
As the external recording media, an optical recording medium such as a DVD and a PD, a magneto-optical recording medium such as an MD, a tape medium, a semiconductor memory such as an IC card can be used. Moreover, the program may be obtained via the network from a server system connected to a dedicated communication network or the Internet by using, as the recording medium, a storage device such as a hard disk or a PAM provided in the server system. As can be seen from the abovementioned configuration example, any hardware having the function of a general computer can be employed as hardware necessary for the present invention. For example, a mobile terminal, a portable terminal and home electric appliances can be used freely without any problem. It should be noted that
The preferred information processing apparatus 501 of the present invention employs an operating system, which supports a graphical user interface (GUI) multi-window environment, such as Windows (R) operation system provided by Microsoft Corporation, Mac OS (R) provided by Apple Inc., and Unix (R) system including X Window System (for example, AIX (R) provided by International Business Machines Corporation). Additionally, the present invention can be achieved by employing hardware, software or a combination of hardware and software.
According to the present invention, a voice stream is divided into appropriate utterance by using information obtained by combining an acknowledgement location and a pause location. Consequently, accuracy is improved in recognition and analysis of speech.
Although the preferred embodiment of the present invention has been described in detail, it should be understood that various changes, substitutions and alternations can be made therein without departing from spirit and scope of the present inventions as defined by the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
2006-350508 | Dec 2006 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5357596 | Takebayashi et al. | Oct 1994 | A |
5761637 | Chino | Jun 1998 | A |
5806021 | Chen et al. | Sep 1998 | A |
6496799 | Pickering | Dec 2002 | B1 |
6694055 | Wu | Feb 2004 | B2 |
6839670 | Stammler et al. | Jan 2005 | B1 |
6873953 | Lennig | Mar 2005 | B1 |
6876967 | Goto et al. | Apr 2005 | B2 |
6885987 | Buchholz et al. | Apr 2005 | B2 |
7076430 | Cosatto et al. | Jul 2006 | B1 |
7177810 | Shriberg et al. | Feb 2007 | B2 |
7313526 | Roth et al. | Dec 2007 | B2 |
7373300 | Bangalore et al. | May 2008 | B1 |
7493251 | Gao et al. | Feb 2009 | B2 |
7493257 | Kim et al. | Feb 2009 | B2 |
7567902 | Davis et al. | Jul 2009 | B2 |
7756709 | Gierach | Jul 2010 | B2 |
7801838 | Colbath et al. | Sep 2010 | B2 |
7818174 | Resnick et al. | Oct 2010 | B1 |
8165880 | Hetherington et al. | Apr 2012 | B2 |
20020032564 | Ehsani et al. | Mar 2002 | A1 |
20020184373 | Maes | Dec 2002 | A1 |
20030004730 | Yuschik | Jan 2003 | A1 |
20030163309 | Yamada et al. | Aug 2003 | A1 |
20040193400 | McDonald | Sep 2004 | A1 |
20040199375 | Ehsani et al. | Oct 2004 | A1 |
20050027523 | Tarlton et al. | Feb 2005 | A1 |
20050216264 | Attwater et al. | Sep 2005 | A1 |
20060287847 | Moore | Dec 2006 | A1 |
20070067172 | Lee et al. | Mar 2007 | A1 |
20070071206 | Gainsboro et al. | Mar 2007 | A1 |
20070203709 | Yasutaka | Aug 2007 | A1 |
20080215325 | Horii et al. | Sep 2008 | A1 |
Number | Date | Country |
---|---|---|
1573925 | Feb 2005 | CN |
1731804 | Feb 2006 | CN |
2001-272990 | Oct 2001 | JP |
2006-276754 | Dec 2006 | JP |
Entry |
---|
Andreas Stolcke et al.: “Automatic Linguistic Segmentation of Conversational Speech,” Proceedings of the International Conference on Spoken Language Processing, vol. 2, Philadelphia 1996; pp. 1005-1008. |
“Sentence Boundary Detection in Broadcast Speech Transcripts,” Proceedings of the International Speech Communication Association Workshop: Automatic Speech Recognition: Challenges for the New Millennium, Paris, Sep. 2000; 8 pages. |
Office Action mailed Jan. 18, 2011 in Japanese Patent Application No. 2006-350508. |
Number | Date | Country | |
---|---|---|---|
20080154594 A1 | Jun 2008 | US |