This application is based upon and claims the benefit of priority from Japanese Patent Application No. 2014-144378, filed on Jul. 14, 2014; the entire contents of which are incorporated herein by reference.
Embodiments described herein relate generally to a speech synthesis dictionary creation device, a speech synthesizer, a speech synthesis dictionary creation method, and a computer program product.
Speech synthesis technologies for converting a certain text into a synthesized waveform are known. In order to reproduce the quality of voice of a certain user by using a speech synthesis technology, a speech synthesis dictionary needs to be created from recorded speech of the user. In recent years, research and development of speech synthesis technologies based on hidden Markov model (HMM) have been increasingly conducted, and the quality of the technologies is being improved. Furthermore, technologies for creating a speech synthesis dictionary of a certain speaker in a second language from speech of a certain speaker in a first language have been studied. A typical technique therefor is cross-lingual speaker adaptation.
In related art, however, large quantities of data need to be provided for conducting cross-lingual speaker adaptation. Furthermore, there is a disadvantage that high-quality bilingual data are required to improve the quality of synthetic speech.
According to an embodiment, a speech synthesis dictionary creation device includes a mapping table creator, an estimator, and a dictionary creator. The mapping table creator is configured to create, based on similarity between distribution of nodes of a speech synthesis dictionary of a specific speaker in a first language and distribution of nodes of a speech synthesis dictionary of the specific speaker in a second language, a mapping table in which the distribution of nodes of the speech synthesis dictionary of the specific speaker in the first language is associated with the distribution of nodes of the speech synthesis dictionary of the specific speaker in the second language. The estimator is configured to estimate a transformation matrix to transform the speech synthesis dictionary of the specific speaker in the first language to a speech synthesis dictionary of a target speaker in the first language, based on speech and a recorded text of the target speaker in the first language and the speech synthesis dictionary of the specific speaker in the first language. The dictionary creator is configured to create a speech synthesis dictionary of the target speaker in the second language, based on the mapping table, the transformation matrix, and the speech synthesis dictionary of the specific speaker in the second language.
First, the background that led to the present invention will be described. The HMM described above if a source-filter speech synthesis system. This speech synthesis system receives as input a sound source a sound source signal (excitation source) generated from a pulse sound source representing sound source components produced by vocal cord vibration or a noise source representing a sound source produced by air turbulence or the like, and carries out filtering using parameters of a spectral envelope representing vocal tract characteristics or the like to generate a speech waveform.
Examples of filters using parameters of a spectral envelope include an all-pole filter, a lattice filter for PARCOR coefficients, an LSP synthesis filter, a logarithmic amplitude approximate filter, a mel all-pole filter, a mel logarithmic spectrum approximate filter, and a mel generalized logarithmic spectrum approximate filter.
Furthermore, one characteristic of the speech synthesis technologies based on the HMM is to be capable of diversely changing generated synthetic sounds. According to the speech synthesis technologies based on the HMM, the quality of voice and the tone of voice can also be easily changed in addition to the pitch (Fundamental frequency; F0) and the Speech rate, for example.
Furthermore, the speech synthesis technologies based on the HMM can generate synthetic speech sounding like that of a certain speaker even from a small amount of speech by using a speaker adaptation technology. The speaker adaptation technology is a technology for performing to bring a certain speech synthesis dictionary to be adapted closer to a certain speaker so as to generate a speech synthesis dictionary reproducing the speaker individuality of a certain speaker.
The speech synthesis dictionary to be adapted desirably contains as few individual speaker's habits as possible. Thus, a speech synthesis dictionary that is independently of speakers is created by training a speech synthesis dictionary to be adapted by using speech data of multiple speakers. This speech synthesis dictionary is called “average voice”.
The speech synthesis dictionaries constitute state clustering based on a decision tree with respect to features such as F0, band aperiodicity, and spectrum. The spectrum expresses spectrum information of speech as a parameter. The band aperiodicity is information representing the intensity of a noise component in a predetermined frequency band in a spectrum of each frame as a ratio to the entire spectrum of the band. In addition, each leaf node of the decision tree holds a Gaussian distribution.
For performing speech synthesis, a distribution sequence is first created by following the decision tree according to context information obtained by converting an input text, and a speech parameter sequence is generated from the resulting distribution sequence. A speech waveform is then generated from the generated parameter sequence (band aperiodicity, F0, spectrum).
Furthermore, technological development of multilingualization is also in progress as one of a diversity of speech synthesis. A typical technology thereof is the cross-lingual speaker adaptation technology mentioned above, which is a technology for converting a speech synthesis dictionary of a monolingual speaker into a speech synthesis dictionary of a particular language while maintaining the speaker individuality thereof. In a speech synthesis dictionary of a bilingual speaker, for example, a table for mapping a language of an input text to the closest node in an output language. When a text of the output language is input, nodes are followed from the output language side, and speech synthesis is conducted using distribution of nodes in the input language side.
Next, a speech synthesis dictionary creation device according to a first embodiment will be described.
The first storage 101, the second storage 103, the third storage 107, the fourth storage 105, and the fifth storage 110 are constituted by a single or multiple hard disk drives (HDDs) or the like, for example. The first adapter 102, the mapping table creator 104, the second adapter 106, the estimator 108, and the dictionary creator 109 may be either hardware circuits or software executed by a CPU, which is not illustrated.
The first storage 101 stores a speech synthesis dictionary of average voice in the first language. The first adapter 102 conducts speaker adaptation by using input speech (bilingual speaker speech in the first language, for example) and the speech synthesis dictionary of the average voice in the first language stored in the first storage 101 to generate a speech synthesis dictionary of the bilingual speaker (specific speaker) in the first language. The second storage 103 stores the speech synthesis dictionary of the bilingual speaker (specific speaker) in the first language generated as a result of the speaker adaptation conducted by the first adapter 102.
The third storage 107 stores a speech synthesis dictionary of average voice in the second language. The second adapter 106 conducts speaker adaptation by using input speech (bilingual speaker speech in the second language, for example) and the speech synthesis dictionary of the average voice in the second language stored by the third storage 107 to generate a speech synthesis dictionary of the bilingual speaker (specific speaker) in the second language. The fourth storage 105 stores the speech synthesis dictionary of the bilingual speaker (specific speaker) in the second language generated as a result of the speaker adaptation conducted by the second adapter 106.
The mapping table creator 104 creates a mapping table by using the speech synthesis dictionary of the bilingual speaker (specific speaker) in the first language stored in the second storage 103 and the speech synthesis dictionary of the bilingual speaker (specific speaker) in the second language stored in the fourth storage 105. More specifically, the mapping table creator 104 creates a mapping table associating distribution of nodes of the speech synthesis dictionary of the specific speaker in the second language with distribution of nodes of the speech synthesis dictionary of the specific speaker in the first language on the basis of the similarity between the nodes of the respective speech synthesis dictionaries of the specific speaker in the first language and in the second language.
The estimator 108 uses speech of the target speaker in the first language that is input and a recorded text thereof to extract acoustic features and contexts from the speech and the text, and estimates a transformation matrix for transforming the speech synthesis dictionary of the specific speaker in the first language to be speaker-adapted to the speech synthesis dictionary of the target speaker in the first language on the basis of the speech synthesis dictionary of the bilingual speaker in the first language stored in the second storage 103.
The dictionary creator 109 creates a speech synthesis dictionary of the target speaker in the second language by using the transformation matrix estimated by the estimator 108, the mapping table creator 104 created by the mapping table, and the speech synthesis dictionary of the bilingual speaker in the second language stored in the fourth storage 105. The dictionary creator 109 may be configured to use the speech synthesis dictionary of the bilingual speaker in the first language stored in the second storage 103.
The fifth storage 110 stores the speech synthesis dictionary of the target speaker in the second language created by the dictionary creator 109.
Next, detailed operation of the respective components included in the speech synthesis dictionary creation device 10 will be described. The speech synthesis dictionaries of the average voice in the respective languages stored in the first storage 101 and the third storage 107 are speech synthesis dictionaries to adapt for speaker adaptation and are generated from speech data of multiple speakers by using speaker adaptation training.
The first adapter 102 extracts acoustic features and the context from input speech data in the first language (bilingual speaker speech in the first language). The second adapter 106 extracts acoustic features and the context from input speech data in the second language (bilingual speaker speech in the second language).
Note that the speaker of the speeches input to the first adapter 102 and to the second adapter 106 is the same bilingual speaker who speaks the first language and the second language. Examples of the acoustic features include F0, a spectrum, a phoneme duration, and a band aperiodicity sequence. The spectrum expresses spectrum information of speech as a parameter as described above. The context represents language attribute information in units of phonemes. The units of phonemes may be monophone, triphone, and quinphone. Examples of the attribute information include {preceding, present, succeeding} phonemes, the syllable position of the present phoneme in a word, {preceding, present, succeeding} parts of speech, the numbers of syllables in {preceding, present, succeeding} words, the number of syllables from an accented syllable, positions of words in a sentence, the presence or absence of preceding or succeeding poses, the numbers of syllables in {preceding, present, succeeding} breath groups, the position of the present breath group, and the number of syllables in a sentence. Hereinafter, these pieces of attribute information will be referred to as contexts.
Subsequently, the first adapter 102 and the second adapter 106 conduct speaker adaptation training from the extracted acoustic features and contexts on the basis of a maximum likelihood linear regression (MLLR) and a maximum a posteriori (MAP). The MLLR that is most frequently used will be described as an example.
The MLLR is a method for adaptation by applying linear transformation to an average vector of a Gaussian distribution or a covariance matrix. In the MLLR, a linear parameter is derived by an EM algorithm according to most likelihood criteria. A Q function of the EM algorithm is expressed as the following Equation (1).
{circumflex over (μ)}(m) and {circumflex over (Σ)}(m) represent an average and a variance obtained by applying a transformation matrix to a component m.
In the expression, the superscript (m) represents a component of a model parameter. M represents the total number of model parameters relating to the transformation. K represents a constant relating to a transition probability. K(m) represents a normalization constant relating to a component m of the Gaussian distribution. Furthermore, in the following Equation (2), qm(τ) represents a component of the Gaussian distribution at time τ. OT represents an observation vector.
γm(τ)=p(qm(τ)|M, OT) (2)
Linear transformation is expressed as in the following Equations (3) to (5). Here, μ represents an average vector, A represents a matrix, b represents a vector, and W represents a transformation matrix. The estimator 108 estimates the transformation matrix W.
{circumflex over (μ)}=Aμ+b=Wξ (3)
ξ represents an average vector.
ξ=[1μT]T (4)
W=[bT AT] (5)
Since the effect of speaker adaptation using a covariance matrix is smaller than that using an average vector, speaker adaptation using an average vector is usually conducted. Transformation of an average is expressed by the following Equation (6). Note that kron( ) represents a Kronecker product of the expression enclosed by ( ), and vec( ) represents transformation into a vector with a matrix arranged in units of rows.
In addition, V(m), Z, and D are expressed by the following Equations (7) to (9), respectively.
An inverse matrix of Wi is represented by the following Equations (10) and (11).
Furthermore, partial differentiation of Equation (1) with respect to wij results in the following Equation (12). Thus, wij is expressed by the following Equation (13).
The second storage 103 stores the speaker-adapted speech synthesis dictionary in the first language generated by the first adapter 102. The fourth storage 105 stores the speaker-adapted speech synthesis dictionary in the second language generated by the second adapter 106.
The mapping table creator 104 measures similarity between the distributions of child nodes of the speaker-adapted speech synthesis dictionary in the first language and the speaker-adapted speech synthesis dictionary in the second language, and converts the association between distributions determined to be the closest into a mapping table (conversion to a table). Note that the similarity is measured using Kullback-Leibler divergence (KLD), a density ratio, or an L2 norm, for example. The mapping table creator 104 uses the KLD as expressed by the following Expressions (14) to (16), for example.
DKL(Ωjg, Ωks)≈DKL(Gks∥Gjg)+DKL(Gks∥Gjg) (16)
Note that k represents an index of a child node, s represents an original language, and t represents a target language. Furthermore, the decision tree of the speech synthesis dictionary at the speech synthesis dictionary creation device 10 is trained by context clustering. Thus, it is expected to further reduce distortion caused by mapping by selecting the most representative phoneme in each child node of the first language from the contexts of the phonemes, and selecting distributions from only distributions having a representative phonemes identical thereto or having representative phonemes of the same type in the second language by using the International Phonetic Alphabet (IPA). The same type mentioned herein refers to agreement in the phoneme type such as vowel/consonant, voiced/unvoiced sound, or plosive/nasal/trill sound.
The estimator 108 estimates a transformation matrix for speaker adaptation from the bilingual speaker (specific speaker) to the target speaker in the first language on the basis of the speech and the recorded text of the target speaker in the first language. An algorithm such as the MLLR, the MAP, or the constrained MLLR (CMLLR) is used for speaker adaptation.
The dictionary creator 109 creates the speech synthesis dictionary of the target speaker in the second language by using the mapping table indicating the state of the speaker-adapted dictionary of the second language in which the KLD is the smallest as expressed by the following Equation (17) and applying the transformation matrix estimated by the estimator 108 to the bilingual speaker-adapted dictionary of the second language.
Note that the transformation matrix wij is calculated by Equation (13) above, but parameters on the right side of Equation (13) above are required therefor. These are dependent on Gaussian components μ and σ. When the dictionary creator 109 conducts transformation by using the mapping table, the transformation matrices applied to leaf nodes of the second language may vary largely, which may cause degradation in speech quality. Thus, the dictionary creator 109 may be configured to regenerate a transformation matrix for a higher-level node by using leaf nodes G and Z to be adapted.
The fifth storage 110 stores the speech synthesis dictionary of the target speaker in the second language created by the dictionary creator 109.
Subsequently, the mapping table creator 104 performs mapping on the speaker-adapted dictionary of the first language at the leaf nodes of the second language by using the speech synthesis dictionaries of the bilingual speaker (speaker-adapted dictionaries) generated by the first adapter 102 and the second adapter 106, respectively (step S102).
The estimator 108 extracts contexts and acoustic features from the speech data and the recorded text of the target speaker in the first language, and estimates a transformation matrix for speaker adaptation to the speech synthesis dictionary of the target speaker in the first language on the basis of the speech synthesis dictionary of the bilingual speaker in the first language stored by the second storage 103 (step S103).
The dictionary creator 109 then creates the speech synthesis dictionary of the target language in the second language (dictionary creation) by applying the transformation matrix estimated for the first language and the mapping table to the leaf nodes of the bilingual speaker-adapted dictionary in the second language (step S104).
Subsequently, operation of speech synthesis using the speech synthesis dictionary creation device 10 will be described in comparison with a comparative example.
As illustrated in
As illustrated in
In this manner, since the speech synthesis dictionary creation device 10 creates the speech synthesis dictionary of the target speaker in the second language on the basis of the mapping table, the transformation matrix, and the speech synthesis dictionary of the specific speaker in the second language, the speech synthesis dictionary creation device 10 can suppress required speech data, and easily create the speech synthesis dictionary of the target speaker in the second language from the target speaker speech in the first language.
Next, a speech synthesis dictionary creation device according to a second embodiment will be described.
The first storage 201, the second storage 203, the third storage 205, the fourth storage 105, and the fifth storage 110 are constituted by a single or multiple hard disk drives (HDDs) or the like, for example. The first adapter 202, the speaker selector 204, and the second adapter 206 may be either hardware circuits of software executed by a CPU, which is not illustrated.
The first storage 201 stores a speech synthesis dictionary of average voice in the first language. The first adapter 202 conducts speaker adaptation by using multiple input speeches (bilingual speaker speeches in the first language) and the speech synthesis dictionary of average voice in the first language stored by the first storage 201 to generate speech synthesis dictionaries of multiple bilingual speakers in the first language. The first storage 201 may be configured to store multiple bilingual speaker speeches in the first language.
The second storage 203 stores the speech synthesis dictionaries of the bilingual speakers in the first language each being generated by conducting speaker adaptation by the first adapter 202.
The speaker selector 204 uses speech and a recorded text of the target speaker in the first language that are input thereto to select a speech synthesis dictionary of a bilingual speaker in the first language that most resembles to the voice quality of the target speaker is selected from multiple speech synthesis dictionaries stored by the second storage 203. Thus, the speaker selector 204 selects one of the bilingual speakers.
The third storage 205 stores a speech synthesis dictionary of average voice in the second language and multiple bilingual speaker speeches in the second language, for example. The third storage 205 also outputs bilingual speaker speech in the second language of the bilingual speaker selected by the speaker selector 204 and the speech synthesis dictionary of average voice in the second language in response to an access from the second adapter 206.
The second adapter 206 conducts speaker adaptation by using the bilingual speaker speech in the second language input from the third storage 205 and the speech synthesis dictionary of average voice in the second language to generate a speech synthesis dictionary in the second language of the bilingual speaker selected by the speaker selector 204. The fourth storage 105 stores the speech synthesis dictionary of the bilingual speaker (specific speaker) in the second language generated by conducting speaker adaptation by the second adapter 206.
The mapping table creator 104 creates a mapping table by using the speech synthesis dictionary in the first language of the bilingual speaker (specific speaker) selected by the speaker selector 204 and the speech synthesis dictionary in the second language of the bilingual speaker (the same specific speaker) stored by the fourth storage 105 on the basis of the similarity between distributions of nodes of the two speech synthesis dictionaries.
The estimator 108 uses speech and a recorded text of the target speaker speech in the first language that are input thereto to extract acoustic features and contexts from the speech and the text, and estimates a transformation matrix for speaker adaptation to the speech synthesis dictionary of the target speaker in the first language on the basis of the speech synthesis dictionary of the bilingual speaker in the first language stored by the second storage 203. Note that the second storage 203 may be configured to output the speech synthesis dictionary of the bilingual speaker selected by the speaker selector 204 to the estimator 108.
Alternatively, in the speech synthesis dictionary creation device 20, the second adapter 206 and the third storage 205 may have configurations different from those illustrated in
In the speech synthesis dictionary creation device 10 illustrated in
Examples of criteria on which the speaker selector 204 selects an appropriate speech synthesis dictionary include a root mean square error (RMSE) of a fundamental frequency (F0) of synthetic speech obtained by synthesis from multiple texts by using a speech synthesis dictionary, a log spectral distance (LSD) of a mel-cepstrum, a RMSE of the duration of a phoneme, and a KLD of distribution of leaf nodes. The speaker selector 204 selects a speech synthesis dictionary with least transformation distortion on the basis of at least any one of these criteria, or the pitch of voice, the speed of speech, the phoneme duration, and the spectrum.
Next, a speech synthesizer 30 that creates a speech synthesis dictionary and synthesizes speech of a target speaker in a target language from a text of the target language will be described.
The analyzer 301 analyzes an input text and acquires context information. The analyzer 301 then outputs the context information to the parameter generator 302.
The parameter generator 302 follows a decision tree according to features on the basis of the input context information, acquires distributions from nodes, and generates distribution sequences. The parameter generator 302 then generates parameters from the generated distribution sequences.
The waveform generator 303 generates a speech waveform from the parameters generated by the parameter generator 302, and outputs the speech waveform. For example, the waveform generator 303 generates an excitation source signal by using parameter sequences of F0 and band aperiodicity, and generates speech from the generated signal and a spectrum parameter sequence.
Next, hardware configurations of the speech synthesis dictionary creation device 10, the speech synthesis dictionary creation device 20, and speech synthesizer 30 will be described with reference to
The speech synthesis dictionary creation device 10 includes a control device such as a central processing unit (CPU) 400, a storage device such as a read only memory (ROM) 401 and a random access memory (RAM) 402, a communication interface (I/F) 403 to connect to a network for communication, and a bus 404 connecting the components.
Programs (such as a speech synthesis dictionary creation program) to be executed by the speech synthesis dictionary creation device 10 are embedded in the ROM 401 or the like in advance and provided therefrom.
The programs to be executed by the speech synthesis dictionary creation device 10 may be recorded on a computer-readable recording medium such as a compact disk read only memory (CD-ROM), a compact disk recordable (CD-R) or a digital versatile disk (DVD) in a form of a file that can be installed or executed and provided as a computer program product.
Furthermore, the programs to be executed by the speech synthesis dictionary creation device 10 may be stored on a computer connected to a network such as the Internet, and provided by allowing the programs to be downloaded via the network. Alternatively, the programs to be executed by the speech synthesis dictionary creation device 10 may be provided or distributed via a network such as the Internet.
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel embodiments described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the embodiments described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
Number | Date | Country | Kind |
---|---|---|---|
2014-144378 | Jul 2014 | JP | national |