System and method for winding audio content using a voice activity detection algorithm

Abstract
A system and method for locating a preferable playback start location after a winding or rewinding action in an audio playing device. In response to an adjustment of the playing location for audio content to a desired playing position, the system determines whether at least one non-speech or silent period of at least a predetermined duration exists within the vicinity of the desired playing position. If at least one such non-speech or silent period exists within the vicinity of the desired playing position, the system adjusts the playing position to fall within one of the at least one non-speech period or silent period.
Description
FIELD OF THE INVENTION

The present invention relates generally to voice compression. More particularly, the present invention relates to the use of voice compression techniques for improving the usability and quality of audio playback applications.


BACKGROUND OF THE INVENTION

In audio applications on electronic devices, rewinding/winding has become a required feature. In applications such as the RealPlayer, a user is capable of moving forward and backwards through various audio tracks. This feature can be used for a variety of purposes, such as to revisit a portion of an audio book where the user was distracted, or to skip ahead to a desired location within the audio content.


Winding and rewinding is conventionally performed based upon a certain time duration. Such systems can automatically move backwards or forwards in a track by a predetermined period of time with each “touch,” or the length of time can be dependent upon the length of time that a user presses a “forward” or “rewind” button or icon. It is also possible for the position in an audio track to be selected arbitrarily, where audio playback always starts from a selected location in the audio regardless of the track's content. In other words, in these systems, the playback position is not dependent on the audio content of a signal.


To demonstrate this issue, it is helpful to look at the effect of rewinding on both music content and speech content. If music content is rewinded back by, for example, twenty seconds, playback will then start in the middle of the music, without control of the exact starting position. Generally, this is not considered to be a significant issue because a music signal is usually considered to be a continuous signal. As a result of this fact, the user will usually not lose track of the music signal, even when playback is started in the middle of a music section.


If the audio comprises spoken speech, words, sentences, paragraphs or chapters, on the other hand, the situation is quite different. If such audio content is played starting in the middle of a word, sentence, paragraph or chapter, the entire meaning of the speech may be lost, as a person may not be able to infer the spoken text that exists before the playback starting point. This problem occurs frequently when traditional winding method is used, i.e., when a winding button is pressed and the playing position of the audio track is moved by an arbitrary time interval. In conventional winding systems, there is no control mechanism that can ensure that audio playing will start at the beginning of a word, sentence, paragraph or chapter, and such a system would be highly desirable by the user.


Audio content can include a type of indexing feature that is defined by the producer of the content. For example, the Victor Reader Classic talking book player includes keys that allow the user to easily move from one book element to another, permitting the user to quickly go to desired information. In such systems, a user is capable of moving by chapter, section, page, paragraph, book, or other elements that are defined by the book's producer. However, such a system only permits the user to wind or rewind to a limited set of predefined locations.


With music content, a user may often select only certain tracks within a music track collection for playback or play the entire track collection from start to finish. In such situations, the need for winding is not necessary, although basic winding functionality is usually still implemented in such music-specific applications. However, when the audio content includes speech, winding and rewinding is substantially more important, because the user is not simply listening to tracks or songs but is instead interested in “textual context.” For example, when a user is listening to an audio book, he or she may want to listen to specific chapters, paragraphs, sentences or even words in order to obtain the necessary or desired context of the respective section.


Another method of navigating through audio content is to divide the content into individual tracks to enable a listener to easily navigate through the document. Individual tracks are easy to access by moving back and forth between tracks. With this technique, the listener can efficiently access a desired section. For example, a listener can first browse various section headings that correspond to various tracks in order to find the section he or she wants to listen to. The user can then use the section numbers included with the section headings to travel to the desired section; the section number announced at the start of each section indicates if the desired section is before or after the current track. Once again, however, the user's options for winding and rewinding are limited. Using such a “track” system, for example, a user may not be able to rewind the audio to hear only a few seconds of sound that he or she may have missed during the original playing. Instead, the user would have to go back to, at a minimum, the beginning of the track, regardless of whether the beginning of the track was a few seconds or several minutes backwards in time. The user's only other option would be to attempt to manually wind or rewind the audio content, which leads to the problem of broken words, sentences, etc. discussed above.


It would therefore be desirable to provide a system and method for permitting the winding and rewinding of audio content that addresses the above-identified difficulties.


SUMMARY OF THE INVENTION

The present invention provides for an improved system and method for audio winding and rewinding. According to the present invention, the position where playback is started after winding or rewinding is selected based upon the underlying audio signal in the audio content. Because speech signals tend to have burst-like characteristics, short “non-speech” period or silent periods exist within speech signal bursts. The present invention uses the presence and absence of bursts to find a location in the audio content which is not in the middle of a word, sentence or paragraph. The present invention then starts the playback in one of these locations.


The present invention provides for a number of advantages not found in conventional systems. By starting playback in locations that are not in the middle of words, sentences or paragraphs, the user receives a more pleasant audio playback without having to suffer through annoying speech/audio clipping. The present invention allows for the informative portion of a piece of audio content to be conveyed to the user completely when the playback is started, and eliminates the need to have to wind or rewind again due to the precise location not being correct. As a result, there is a greatly reduced need for continuous iterations of winding and rewinding until the precise desired location is found, as has been conventionally necessary on playback devices dating back to the first tape recorders. The present invention can be used on a wide variety of electronic devices, including mobile electronic devices such as mobile telephones.


These and other advantages and features of the invention, together with the organization and manner of operation thereof, will become apparent from the following detailed description when taken in conjunction with the accompanying drawings, wherein like elements have like numerals throughout the several drawings described below.




BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a perspective view of a mobile telephone that can be used in the implementation of the present invention;



FIG. 2 is a schematic representation of the telephone circuitry of the mobile telephone of FIG. 1;



FIG. 3 is a representation of a media player/audio player within which the present invention may be implemented;



FIG. 4 is a plot showing the burst characteristics of a speech signal; and



FIG. 5 is a flow chart showing the implementation of one embodiment of the present invention.




DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS


FIGS. 1 and 2 show one representative mobile telephone 12 within which the present invention may be implemented. It should be understood, however, that the present invention is not intended to be limited to one particular type of mobile telephone 12 or other electronic device. Instead, the present invention can be incorporated into virtually any type of electronic device, including but not limited to laptop and desktop computers, personal digital assistants, dictating machines, integrated messaging devices, printers, scanners, fax machines and other devices.


The mobile telephone 12 of FIGS. 1 and 2 includes a housing 30, a display 32 in the form of a liquid crystal display, a keypad 34, a microphone 36, an ear-piece 38, a battery 40, an infrared port 42, an antenna 44, a smart card 46 in the form of a UICC according to one embodiment of the invention, a card reader 48, radio interface circuitry 52, codec circuitry 54, a controller 56 and a memory 58. Individual circuits and elements are all of a type well known in the art, for example in the Nokia range of mobile telephones.


The present invention provides for an improved system and method for audio winding and rewinding. According to the present invention, the position where playback is started after winding or rewinding is selected based upon the underlying audio signal in the audio content. Because speech signals tend to have burst-like characteristics, short non-speech periods or silent periods exist within speech signal bursts. The present invention uses the presence and absence of bursts to find a location in the audio content which is not in the middle of a word, sentence or paragraph. The present invention then starts the playback in one of these locations.


It has been estimated that speech activity in audio content, such as audio books or audio news, can comprise about around 80% of the total content. In other words, about 80% of a selected contact track will comprise actual speech, while the remaining 20% would comprise periods of relative silence, such as between paragraphs, or sections of the content. For this reason, it is likely that, after any winding or rewinding occurs within a piece of audio content, the playback position will be in the middle of a sentence or word, and not in a non-speech period or silent period. However, speech signals usually have a high tendency of sound bursts, meaning that even one second of speech might include many short periods of silence. FIG. 4 shows these “bursty” characteristics within a speech signal. As can be observed in this figure. There are several short periods that are characterized as possess a general lack of sound activity, as well as one longer period of silence


According to the proposed invention, the position where playback is started after winding or rewinding is selected based upon the audio signal. In the present invention, a user first implements general winding and rewinding methods to move the playing position to a generally location. The system then uses this general location as a starting point and then locates a non-speech period that meets predetermined criteria. This non-speech period is then selected as the actual starting point.



FIG. 3 is a representation of an audio player 100 within which the present invention may be implemented. The audio player 100 includes a play button 102, a stop button 104, and a position control dial 106. In many such systems, a user can use a cursor to move the position control dial 106 forward or backwards (referred to herein as winding or rewinding, respectively) through a piece of audio content. The user can then actuate the play button 102 to begin playing the content at the selected position.



FIG. 5 is a flow chart showing the implementation of one embodiment of the present invention. At step 500 in FIG. 5, a user moves the position control dial 106-of the audio player 100 either forward or backwards to a desired general position. At step 510, the status of a voice activity detection (VAD) flag is checked around the selected position to be played. If the selected position in the audio content is identified as X, for example, the voice activity flag is checked in every speech frame that is in the vicinity of X. The vicinity can comprise, for example, 0.5 seconds forward and 0.5 seconds backward from the selected position X. The vicinity could also comprise “non-symmetrical” time periods around the selected position X (i.e., 0.5 seconds backward and only 0.25 seconds forward), or the entire vicinity could be before or after the selected position X. One second of audio usually includes several speech frames. For example, speech frames of AMR and AMR-WB codecs are 20 ms long. Therefore, one second of audio signal possesses 50 speech frames. It should be noted that the numerical values discussed herein are only examples and can be altered depending on the exact application, or type of content. Variations of these numerical values can be used by those skilled in the art under the present invention.


It should be noted that, although a VAD flag and algorithm is discussed herein, any suitable or desirable algorithm can be used for detecting whether certain periods of audio content contain speech or do not contain speech. For example, current cellular codecs such as GSM AMR or GSM AMR-WB contain algorithms which can be used for this purpose. In addition, custom-made algorithms can be used for the implementation of the present invention.


At step 520 in FIG. 5, it is determined whether the VAD flags within the vicinity indicate that a sufficiently long non-speech period has been found within the investigated time interval. “Sufficiently long” can be based upon a predetermined time threshold, and “non-speech period” can refer to the amount of recorded sound being below a predetermined threshold. For example, a “non-speech” period can refer to a period where only general background noise and/or background music is determined, or it can refer to a complete silent period where no sound is detected at all. Other definitions for “non-speech period” are also possible. “Sufficiently long” may depend upon the application being used and/or user preferences, as well as whether the application and/or the user wants to wind or rewind word-by-word, sentence-by-sentence or paragraph-by-paragraph. For example, the user may have a preference that playback always begins at the start of a paragraph, which would require searching for relative long non-speech periods. If the preference were for the beginning of a word, on the other hand, “sufficiently long” would constitute a shorter time interval. Therefore, the duration of the desired non-speech period can vary significantly, ranging from as little as single speech frame (which is usually around 20 ms) to several seconds (which comprises tens of speech frames).


If there is a sufficiently long non-speech period within the interval, then it is determined whether the exact playing position selected by the user is set within a sufficiently long non-speech period at step 530. If the exact playing position selected by the user is set within a sufficiently long non-speech period, then no adjustment is made to the playing position at step 540. If the exact playing position selected by the user is not set within a sufficiently long non-speech period, then the playing position is adjusted to occur within the nearest sufficiently long non-speech period at step 550. If more than one non-speech period is found, then non-speech period closest to the position X is selected to be the position to start the playback. In one embodiment of the invention, positions backward or behind from the current position X are preferred so as to not miss the start of the sentence or word of interest to the user. This preference can take a variety of forms. For example, the system first could scan the entire portion of the interval before the selected position first, and only scan the remainder of the interval if no sufficient long non-speech periods exist before the selected position. Alternatively, this preference can be “weaker” in that the system goes “backwards” only if there are two non-speech periods substantially equidistant in time from the selected position. Other permutations for such preferences are also possible. Additionally, system or user requirements can dictate the exact position within the sufficiently long non-speech period for playback to start. For example, playback can ultimately begin at the beginning, midpoint, or end of the non-speech period, or another period could also be selected.


If no non-speech periods are found within the designated time interval, then playback is started at the selected position at step 560 in one embodiment of the invention. In an alternative embodiment, an iterative technique may be used instead. Instead of simply choosing the selected position, a longer time interval is selected at step 570 and searched for an acceptable time interval. This process can repeated a certain number of times (i.e., up until a maximum time interval or until the beginning or end of a track is reached) or indefinitely, with each repeat of process involving the increase of the time interval being searched. During this process, the required duration of the non-speech period can also be increased, if necessary or desired. The concept of changing the duration of the non-speech period is based upon the fact that, the longer is the non-speech period, the more significant is the pause in the speech content. Therefore, one can allow more deviation from the original playback position X. This depends on whether the user or system desires to find pauses between sentences, chapters or words. For example, for audio books, it may often be desirable to wind paragraph by paragraph, in which case the system would attempt to search for longer non-speech periods than would be necessary for winding sentence by sentence.


It should be noted that, although particular methods for determining silence periods in speech are discussed herein, the present invention can also include other methods of differentiating pauses between words, sentences or paragraphs. For example, methods such as utilizing statistics of spoken speech for different languages can be used to implement the detection of pauses between words, sentences, paragraphs or chapters. Alternatively, the present invention can be implemented without any differentiation between pause types (i.e., words, sentences, etc.), instead simply looking to the nearest silence period from a selected position in accordance with the process depicted in FIG. 5.


The present invention is described in the general context of method steps, which may be implemented in one embodiment by a program product including computer-executable instructions, such as program code, executed by computers in networked environments.


Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Computer-executable instructions, associated data structures, and program modules represent examples of program code for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represent examples of corresponding acts for implementing the functions described in such steps.


Software and web implementations of the present invention could be accomplished with standard programming techniques with rule based logic and other logic to accomplish the various database searching steps, correlation steps, comparison steps and decision steps. It should also be noted that the words “component” and “module” as used herein, and in the claims, is intended to encompass implementations using one or more lines of software code, and/or hardware implementations, and/or equipment for receiving manual inputs.


The foregoing description of embodiments of the present invention have been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the present invention to the precise form disclosed, and modifications and variations are possible in light of the above teachings or may be acquired from practice of the present invention. The embodiments were chosen and described in order to explain the principles of the present invention and its practical application to enable one skilled in the art to utilize the present invention in various embodiments and with various modifications as are suited to the particular use contemplated.

Claims
  • 1. A method of locating a preferable playback start location after a winding or rewinding action in an audio playing device, comprising: in response to an adjustment of the playing location for an audio content to a desired playing position, determining whether at least one non-speech period of at least a predetermined duration exists within the vicinity of the desired playing position; and if at least one non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, adjusting the playing position to fall within one of the at the least one non-speech period.
  • 2. The method of claim 1, wherein the predetermined duration comprises a designated period of time before and after the desired playing position.
  • 3. The method of claim 1, wherein, if more than one non-speech periods of at least the predetermined duration exist within the vicinity of the desired playing position, the playing position is adjusted to fall within the non-speech period that is closest in time to desired playing position.
  • 4. The method of claim 1, wherein, if a non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position before the desired playing position, and if a non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position after the desired playing position, the playing position is adjusted to fall within the non-speech period before the desired playing position.
  • 5. The method of claim 1, wherein the determining of whether at least one non-speech period of at least a predetermined duration exists within the vicinity of the desired playing position includes checking the status voice activity detection flags for every sound frame that is within the vicinity of the desired playing position.
  • 6. The method of claim 1, wherein a non-speech period comprises a length of time where any recorded sound does not exceed a predetermined threshold in magnitude.
  • 7. The method of claim 1, further comprising, if no non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, not adjusting the playing position.
  • 8. The method of claim 1, further comprising, if no non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, lengthening the duration of the vicinity of the desired playing position; determining whether at least one non-speech period of at least a predetermined duration exists within the lengthened vicinity of the desired playing position; and if at least one non-speech period of at least the predetermined duration exists within the lengthened vicinity of the desired playing position, adjusting the playing position to fall within one of the at least one non-speech period.
  • 9. The method of claim 8, further comprising: if no non-speech period of at least the predetermined duration exists within the lengthened vicinity of the desired playing position, continuing to lengthen the vicinity of the desired playing position until a non-speech period of at least the predetermined duration is found or until a predetermined number of lengthenings of the vicinity of the desired playing position has been attempted; and if at least one non-speech period of at least the predetermined duration exists within a vicinity of the desired playing position before the predetermined number of lengthenings of the vicinity of the desired playing position has been attempted, adjusting the playing position to fall within one of the at least one the non-speech period.
  • 10. The method of claim 1, further comprising: after determining that at least one non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, determining whether the desired playing position falls within one of the at least one non-speech period of at least the predetermined duration; and if the desired playing position falls within one of the at least one non-speech period of at least the predetermined duration, not adjusting the playing position.
  • 11. A computer program product for locating a preferable playback start location after a winding or rewinding action in an audio playing device, comprising: computer code for, in response to an adjustment of the playing location for an audio content to a desired playing position, determining whether at least one non-speech period of at least a predetermined duration exists within the vicinity of the desired playing position; and computer code for, if at least one non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, adjusting the playing position to fall within one of the at least one non-speech period.
  • 12. The computer program product of claim 11, wherein the predetermined duration comprises a designated period of time before and after the desired playing position.
  • 13. The computer program product of claim 11, wherein, if more than one non-speech periods of at least the predetermined duration exist within the vicinity of the desired playing position, the playing position is adjusted to fall within the non-speech period that is closest in time to desired playing position.
  • 14. The computer program product of claim 11, wherein, if a non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position before the desired playing position, and if a non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position after the desired playing position, the playing position is adjusted to fall within the non-speech period before the desired playing position.
  • 15. The computer program product of claim 11, further comprising computer code for, if no non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, not adjusting the playing position.
  • 16. The computer program product of claim 11, further comprising, computer code for, if no non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, lengthening the duration of the vicinity of the desired playing position; computer code for determining whether at least one non-speech period of at least a predetermined duration exists within the lengthened vicinity of the desired playing position; and computer code for, if at least one non-speech period of at least the predetermined duration exists within the lengthened vicinity of the desired playing position, adjusting the playing position to fall within one of the at least one non-speech period.
  • 17. The computer program product of claim 11, further comprising: computer code for, after determining that at least one non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, determining whether the desired playing position falls within one of the at least one non-speech period of at least the predetermined duration; and computer code for, if the desired playing position falls within one of the at least one non-speech period of at least the predetermined duration, not adjusting the playing position.
  • 18. An electronic device, comprising: a processor; and a memory unit operatively connected to the processor and including: computer code for, in response to an adjustment of the playing location for an audio content to a desired playing position, determining whether at least one non-speech period of at least a predetermined duration exists within the vicinity of the desired playing position; and computer code for, if at least one non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, adjusting the playing position to fall within one of the at least one non-speech period.
  • 19. The electronic device of claim 18, wherein the predetermined duration comprises a designated period of time before and after the desired playing position.
  • 20. The electronic device of claim 18, wherein, if more than one non-speech periods of at least the predetermined duration exist within the vicinity of the desired playing position, the playing position is adjusted to fall within the non-speech period that is closest in time to desired playing position.
  • 21. The electronic device of claim 18, wherein, if a non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position before the desired playing position, and if a non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position after the desired playing position, the playing position is adjusted to fall within the non-speech period before the desired playing position.
  • 22. The electronic device of claim 18, wherein the memory unit further comprises computer code for, if no non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, not adjusting the playing position.
  • 23. The electronic device of claim 18, wherein the memory unit further comprises, computer code for, if no non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, lengthening the duration of the vicinity of the desired playing position; computer code for determining whether at least one non-speech period of at least a predetermined duration exists within the lengthened vicinity of the desired playing position; and computer code for, if at least one non-speech period of at least the predetermined duration exists within the lengthened vicinity of the desired playing position, adjusting the playing position to fall within one of the at least one non-speech period.
  • 24. The electronic device of claim 18, wherein the memory unit further comprises: computer code for, after determining that at least one non-speech period of at least the predetermined duration exists within the vicinity of the desired playing position, determining whether the desired playing position falls within one of the at least one non-speech period of at least the predetermined duration; and computer code for, if the desired playing position falls within one of the at least one non-speech period of at least the predetermined duration, not adjusting the playing position.
  • 25. The electronic device of claim 18, wherein the at least one non-speech period comprises at least one silent period.