These teachings relate generally to text-to-speech (TTS) systems and methods and, more particularly, relate to concatenative TTS (CTTS) systems and methods.
Conventional CTTS systems use a database of speech segments (e.g., phonemes, syllables, and/or entire words) recorded from a single speaker to select speech segments to concatenate based on some input text string. In order to achieve high-quality synthetic speech, however, a large amount of data need be collected from the single speaker; thus making the development of such a database time-consuming and costly.
Reference with regard to some conventional approaches may be had, for example, to U.S. Pat. No. 6,725,199 B2, “Speech Synthesis Apparatus and Selection Method”, Brittan et al.; U.S. Pat. No. 5,878,393, “High Quality Concatenative Reading System”, Hata et al.; and U.S. Pat. No. 5,860,064, “Method and Apparatus for Automatic Generation of Vocal Emotion in a Synthetic Text-to-Speech System”, Caroline G. Henton. For example, the system described in U.S. Pat. No. 5,878,393 employs a dictionary of sampled sounds, where the dictionary may include separate dictionaries of sounds sampled at different sampling rates. The dictionary may also store all pronunciation variants of a word for each of a plurality of prosodic environments.
New domains for deploying text-to-speech invariably arise, usually accompanied by a desire to supplement the database of recordings used to build a CTTS system with additional data corresponding to words, phrases and/or sentences which are highly relevant to the new domain, such as specific company names or technical phrases not present in the original script.
However, in the event that the original speaker whose voice was recorded and sampled to populate the dictionary is no longer available to make an additional recording, a new speaker may be required to re-record all of the original script, in addition to the new domain-specific script. Such a process would not be efficient for a number of reasons.
The foregoing and other problems are overcome, and other advantages are realized, in accordance with the presently preferred embodiments of these teachings.
In one aspect thereof this invention provides a method and an apparatus to generate an audible speech word that corresponds to text. The method includes providing a text word and, in response to the text word, processing pre-recorded speech segments that are derived from a plurality of speakers to selectively concatenate together speech segments based on at least one cost function to form audio data for generating an audible speech word that corresponds to the text word.
In another aspect thereof this invention provides a data structure embodied with a computer readable medium for use in a concatenative text-to-speech system. The data structure includes a plurality of speech segments that are derived from a plurality of speakers, where each speech segment includes an associated attribute vector each of which is comprised of at least one attribute vector element that identifies the speaker from which the speech segment was derived.
In preferred embodiments of this invention the speech segments are pre-recorded by a process that comprises designating one speaker as a target speaker, examining an input speech segment to determine if it is similar to a corresponding speech segment of the target speaker and, if it is not, modifying at least one characteristic of the input speech segment, such as a temporal and/or a spectral characteristic, so as to make it more similar to the corresponding speech segment of the target speaker. The preferred embodiments of this invention also enable the pooling of speech segments of the target speaker and the possibly modified auxiliary speakers to form a larger database from which to draw speech segments for concatenative text-to-speech synthesis.
The foregoing and other aspects of these teachings are made more evident in the following Detailed Description of the Preferred Embodiments, when read in conjunction with the attached Drawing Figures, wherein:
In accordance with exemplary embodiments of this invention a system and method operate to combine speech segment databases from several speakers to form a larger combined database from which to select speech segments at run-time.
Referring to
In accordance with exemplary embodiments of this invention the database 16 may actually be viewed as a plurality of separate databases 161, 162, . . . , 16n each storing sampled speech segments recorded from one of a plurality of speakers, for example two, three or more speakers who read the same or different text words, phrases and/or sentences. Assuming by way of example, and not as a limitation, that the sampled speech segments of an original speaker are stored in the database 161, then additional speech segment data stored in the databases 162-16n may be derived from one or more auxiliary speakers who naturally sound similar (that is, have similar spectral characteristics and pitch contours) to some original speaker, or the additional speech segment data may be derived from one or more auxiliary speakers who sound dissimilar to the original speaker, but whose pitch and/or spectral characteristics are modified by speech sampling sub-system 14 using suitable signal processing so that the resulting speech sounds similar to the original speaker. For those speakers who are processed to sound like the original speaker, the processed speech database 16 may be combined with the other databases to form a single database, while for speakers who naturally sound like the original speaker their unprocessed speech segment data may be combined with the data from the other speakers. After combining data from two or more speakers, it is preferred that one large (unified) database 17 is formed, which allows for higher quality speech output.
It is thus preferred to employ one or more signal processing techniques to transform the input speech from two or more speakers in order to pool data from the several speakers to sound as if it all originated from the same speaker. Either manual hand-tuning or automatic methods of finding the appropriate transformation may be used for this purpose of populating the unified speech segment database 17.
The CTTS 10 may then be built from a combination of the optionally processed supplemental databases 162, . . . , 16n and the original database 16, for the purpose of enhancing the quality of the output speech. Note that the original, typically preferred speaker need not be present when recording and storing the speech annunciated by the other (auxiliary) speakers.
The foregoing process may be of particular value when updating a legacy CTTS system to include new words, phrases and/or sentences which are highly relevant to a new domain or context for the CTTS system. In this case the legacy speaker is naturally the “target” speaker, and the other speaker or speakers from whom the additional data come are naturally the “auxiliary” speakers. However, it should be appreciated that in other embodiments the CTTS system 10 may be designed from the start to include the multiple speech segment databases 161, 162, . . . , 16n and/or the unified speech segment database 17. In this latter case it may still be the case that one of the speakers is a target speaker, or one having a most preferred speech sound for a given application of the CTTS system 10, to which the other speakers are compared and their speech modified as necessary to more closely resemble the speech of the target speaker.
Referring to
In one non-limiting example of the use of the CTTS 10 two female speakers were found to be very close in pitch and spectral characteristics, and their respective speech segment databases 16 were combined or pooled without normalization. A third female speaker with markedly low pitch was processed using commercially available third party software, such as one known as Adobe® Audition™ 1.5, to raise the average pitch so as to be in the same range of pitch frequencies as the other two female speakers. The third female speaker's processed data were merged or pooled with the data of the other two speakers.
In accordance with non-limiting embodiments of this invention, during the process of building the pooled dataset stored in the database 17 by the CTTS engine 18 (indicated by the signal line or bus 18B shown in
During synthesis the input speech segment data, which is preferably, but not as a limitation, in the form of an extended Speech Synthesis Markup Language (SSML) document (http://www.w3.org/TYR/2004/REC-speech-synthesis-20040907/), are processed by an XML parser. The extended SSML tags are used to form a target attribute vector, analogous to one used in a voice-dataset-building process to label the speech segments. In this case one element of the target attribute vector is the identity of the target speaker (Speaker_ID, as in
It can thus be appreciated than an aspect of this invention is a data structure that is stored in a computer readable medium for use in a concatenative text-to-speech system, where the data structure is comprised of a plurality of speech segments derived from a plurality of speakers, where each speech segment includes an associated attribute vector each of which is comprised of at least one attribute vector element that identifies the speaker from which the speech segment was derived. An additional element may be one that indicates a style of the speech segment. A speech segment may be derived from a speaker by simply sampling, digitizing and partitioning spoken words into some units, such as phonemes or syllables, with little or no processing or modification of the speech segments. Alternatively, a speech segment may be derived from a speaker by sampling, digitizing, spectrally or otherwise processing the digitized speech samples, such as by performing pitch enhancement or some other spectral modification, and/or by performing temporal modification, and partitioning the processed speech sample data into the units of interest.
An attribute cost function C(t,o) may be used to penalize the use of a speech segment labeled with an attribute vector o when the target is labeled by attribute vector t. A cost matrix Ci is preferably defined for each element i in the attribute vector. An example of such a cost matrix is shown in
Asymmetries in the cost matrix may arise because of different sizes of datasets. For example, if one speaker has a very large dataset compared to another speaker, it may be preferred to penalize more heavily the use of speech segments from the smaller dataset when the speaker with the large dataset is the target, and to penalize less heavily the use of segments from the large dataset when the speaker corresponding to the small dataset is the target.
A desired end result of the foregoing processes is that an audible speech word that is output from the loudspeaker 22 may be comprised of constituent voice sounds, such as phonemes or syllables, that are actually derived from two or more speakers and that are selectively concatenated together based on at least one cost function.
The embodiments of this invention may be implemented by computer software executable by the data processor 18A of the CTTS engine 18, or by hardware, or by a combination of software and hardware. Further in this regard it should be noted that the various blocks of the logic flow diagram of
The foregoing description has provided by way of exemplary and non-limiting examples a full and informative description of the best method and apparatus presently contemplated by the inventors for carrying out the invention. However, various modifications and adaptations may become apparent to those skilled in the relevant arts in view of the foregoing description, when read in conjunction with the accompanying drawings and the appended claims. For example, the use of other similar or equivalent speech processing and modification hardware and software may be attempted by those skilled in the art. Further, other types of cost functions and modifications of same may occur to those skilled in the art, when guided by these teachings. Still further, it can be appreciated that many CTTS systems will not include the microphone 12 and speech sampling sub-system 14, as once the database 16 is generated it can be provided in or on a computer-readable tangible medium, such as on a disk or in semiconductor memory, and need not be generated or even maintained locally. However, all such and similar modifications of the teachings of this invention will still fall within the scope of the embodiments of this invention.
Furthermore, some of the features of the preferred embodiments of this invention may be used to advantage without the corresponding use of other features. As such, the foregoing description should be considered as merely illustrative of the principles, teachings and embodiments of this invention, and not in limitation thereof.