A speech recognition system includes a receiver component that receives a distorted speech utterance. The speech recognition also includes an adaptor component that selectively adapts parameters of a compressed model used to recognize at least a portion of the distorted speech utterance, wherein the adaptor component selectively adapts the parameters of the compressed model based at least in part upon the received distorted speech utterance.
|
16. A computer-readable data storage device residing in a mobile device that includes a speech recognition system comprising a plurality of compressed models, wherein the computer-readable data storage device comprises instructions that, when executed by a processor, cause the processor to perform acts comprising:
receiving a distorted speech utterance;
coarsely estimating an additive distortion mean vector corresponding to the distorted speech utterance based at least in part upon a portion of the received distorted speech utterance;
adapting parameters of a first subset of compressed models in the plurality of compressed models based at least in part upon the coarsely estimated additive distortion mean vector;
decoding the received distorted speech utterance using a second subset of compressed models in the plurality of compressed models;
re-estimating the additive distortion mean vector based at least in part upon the decoded speech utterance;
adapting parameters of the second subset of compressed models in the plurality of compressed models based at least in part upon the re-estimating of the additive distortion mean vector; and
decoding the received distorted speech utterance using at least one compressed model in the second subset of compressed models.
1. A speech recognition system comprising the following computer-executable components:
a receiver component that receives a distorted speech utterance;
a plurality of compressed models usable in connection with speech recognition;
an expander component that expands the plurality of compressed models;
an adaptor component in communication with the receiver component, wherein the adaptor component coarsely estimates an additive distortion mean vector corresponding to the distorted speech utterance based at least in part upon a portion of the distorted speech utterance received by the receiver component, wherein the adaptor component selectively adapts parameters of a subset of compressed models in the plurality of compressed speech models based at least in part upon the coarsely estimated additive distortion mean vector; and
a decoder component that decodes the received distorted speech utterance using a second subset of compressed models in the plurality of compressed models and outputs a decoded speech utterance, wherein subsequent to the decoder component outputting the decoded speech utterance, the adaptor component re-estimates the additive distortion mean vector based at least in part upon the decoded speech utterance, wherein subsequent to the adaptor component re-estimating the additive distortion mean vector, the adaptor component adapts parameters of the second subset of compressed models in the plurality of compressed models based at least in part upon re-estimating of the additive distortion mean vector, and wherein subsequent to the parameters of the second subset of compressed models in the plurality of compressed models being adapted, the decoder component decodes the received distorted speech utterance using at least one compressed model in the second subset of compressed models.
10. A method comprising the following computer-executable acts:
receiving a distorted speech utterance at a mobile device that includes a speech recognition system, the speech recognition system comprising a plurality of hidden markov models that have been compressed by way of subspace coding;
coarsely estimating an additive distortion mean vector based at least in part upon a plurality of frames in the distorted speech utterance that are free of human voice;
expanding each hidden markov model in the plurality of hidden markov models responsive to receiving the distorted speech utterance;
subsequent to expanding each hidden markov model in the plurality of hidden markov models, decoding the distorted speech utterance through utilization of a first subset of hidden markov models in the plurality of hidden markov models;
subsequent to decoding the distorted speech utterance through utilization of the first subset of hidden markov models, updating parameters in each hidden markov model in the first subset of hidden markov models based at least in part upon the additive distortion mean vector that has been coarsely estimated;
subsequent to updating the parameters of each hidden markov model in the first subset of hidden markov models, decoding the distorted speech utterance through utilization of a second subset of hidden markov models in the first subset of hidden markov models;
re-estimating the additive distortion mean vector based at least in part upon the decoding of the distorted speech utterance through utilization of the second subset of hidden markov models;
adapting parameters of each hidden markov model in the second subset of hidden markov models based at least in part upon the re-estimating of the additive distortion mean vector; and
compressing each hidden markov model in the second subset of hidden markov models through vector quantization subsequent to the adapting of the parameters of each hidden markov model in the second subset of hidden markov models.
2. The speech recognition system of
3. The speech recognition system of
4. The speech recognition system of
5. The speech recognition system of
6. The speech recognition system of
8. The system of
9. The system of
where gα(x, h, n)=C log(1+exp(C−1(n−x−h)+2α·exp(C−1(n−x−h)/2)),
where y, x, n, and h are vector-valued distorted speech, clean speech, additive distortion, and convolutive distortion in the received distorted speech utterance, respectively;
C is a non-square discrete cosine transform (DCT) matrix;
C−1 is an inverse DCT matrix; and
α=[α(1), α(2), . . . α(l), . . . α(L)]T is a phase-factor vector for L Mel filter banks.
11. The method of
12. The method of
estimating a convolutive distortion mean vector corresponding to the distorted speech utterance;
updating the parameters in each hidden markov model in the first subset of hidden markov models based at least in part upon the convolutive distortion mean vector;
re-estimating the convolutive distortion mean vector based at least in part upon the decoding of the distorted speech utterance through utilization of the second subset of hidden markov models; and
adapting parameters of each hidden markov model in the second subset of hidden markov models based at least in part upon the re-estimating of the additive distortion mean vector and the re-estimating of the convolutive distortion mean vector.
13. The method of
14. The method of
where gα(x, h, n)=C log(1+exp(C−1(n−x−h)+2α·exp(C−1(n−x−h)/2)),
where y, x, n, and h are vector-valued distorted speech, clean speech, additive distortion, and convolutive distortion in the received distorted speech utterance, respectively;
C is a non-square discrete cosine transform (DCT) matrix;
C−1 is an inverse DCT matrix; and
α=[α(1), α(2), . . . α(l), . . . α(L)]T is a phase-factor vector for L Mel filter banks.
17. The computer-readable data storage device of
18. The computer-readable data storage device of
19. The computer-readable data storage device of
where gα(x, h, n)=C log(1+exp(C−1(n−x−h)+2α·exp(C−1(n−x−h)/2)),
where y, x, n, and h are vector-valued distorted speech, clean speech, additive distortion, and convolutive distortion in the received distorted speech utterance, respectively;
C is a non-square discrete cosine transform (DCT) matrix;
C−1 is an inverse DCT matrix; and
α=[α(1), α(2), . . . α(l), . . . α(L)]T is a phase-factor vector for L Mel filter banks.
20. The computer-readable data storage device of
recognizing at least one word in the distorted speech utterance; and
performing a computing task responsive to recognizing the at least one word in the distorted speech utterance.
|
Speech recognition has been the subject of a significant amount of research and commercial development. For example, speech recognition systems have been incorporated into mobile telephones, desktop computers, automobiles, and the like in order to provide a particular response to speech input provided by a user. For instance, in a mobile telephone equipped with speech recognition technology, a user can speak a name of a contact listed in the mobile telephone and the mobile telephone can initiate a call to the contact. Furthermore, many companies are currently using speech recognition technology to aid customers in connection with identifying employees of a company, identifying problems with a product or service, etc.
As noted above, speech recognition systems have been incorporated into mobile devices, such as mobile telephones. Robust speech recognition systems, however, typically employ models that require a relatively large amount of storage and/or processing resources—resources that are constrained due to the size of mobile devices. As a result, speech recognition systems in mobile devices have been associated with reduced functionality (in comparison to robust speech recognition systems) and/or relatively poor performance, particularly in noisy environments.
The following is a brief summary of subject matter that is described in greater detail herein. This summary is not intended to be limiting as to the scope of the claims.
Technologies pertaining to speech recognition in general, and technologies pertaining to adapting parameters of compressed models used in speech recognition systems in mobile devices in particular, are described herein. In an example, a speech recognition system can include a plurality of compressed models, wherein at least one of the compressed models can be a Hidden Markov Model.
In an example, a speech utterance can be received at a mobile device (or other device with memory and/or processing constraints) through use of one or more microphones. The speech utterance can have various distortions, including additive distortions and convolutive distortions. At least one of the plurality of compressed models in the speech recognition system can be adapted based at least in part upon the distorted speech utterance.
In an example, coarse estimates of various parameters pertaining to uttered speech can be ascertained through analysis of a received, distorted speech utterance. For instance, an additive distortion mean vector can be estimated by analyzing samples of a first plurality of frames (speech free) of the received distorted speech utterance. Such additive distortion mean vector, for example, can be used to initially adapt at least a first subset of compressed models in the plurality of compressed models or parameters thereof. The received distorted speech utterance can then be decoded through use of the plurality of compressed models, and thereafter at least one of the various parameters estimated above can be more accurately estimated (re-estimated) based at least in part upon results of decoding the speech utterance. A second subset of compressed models in the plurality of compressed models can then be adapted based at least in part upon the at least one re-estimated parameter. In another example, each of the plurality of compressed models can be adapted based at least in part upon the at least one re-estimated parameter.
Other aspects will be appreciated upon reading and understanding the attached figures and description.
Various technologies pertaining to speech recognition will now be described with reference to the drawings, where like reference numerals represent like elements throughout. In addition, several functional block diagrams of example systems are illustrated and described herein for purposes of explanation; however, it is to be understood that functionality that is described as being carried out by certain system components may be performed by multiple components. Similarly, for instance, a component may be configured to perform functionality that is described as being carried out by multiple components.
With reference to
The system 100 includes a receiver component 102 that receives a distorted speech utterance from an individual. Thus, the receiver component 102 can be in communication with a microphone or series of microphones (not shown). The distorted speech utterance can include additive and convolutive distortions. In an example, an additive distortion can be or include background noise, such as a fan running in the background, road noise from an automobile, etc. A convolutive distortion can be channel noise, such as a change in position of a microphone, an alteration from a hand-held to a hands-free microphone, or other suitable channel noise. As noted above, the distorted speech utterance can include both additive and convolutive distortions.
The system 100 further includes an adaptor component 104 that can adapt parameters of a compressed model 106 that is used in connection with recognizing at least a portion of the distorted speech utterance. For instance, the adaptor component 104 can adapt parameters of the compressed model 106 based at least in part upon the distorted speech utterance received by the receiver component 102. Pursuant to an example, the adaptor component 104 can be configured to jointly compensate for additive and convolutive distortions in the received speech utterance when adapting the parameters of the compressed model 106.
In an example, and as will be described in greater detail below, the compressed model 106 can be a compressed Hidden Markov Model (HMM). The HMM can be trained using clean speech and/or speech that includes one or more distortions. Further, the Hidden Markov Model can be compressed using Subspace Coding (SSC). It is to be understood, however, that other compression techniques are also contemplated and are intended to fall under the scope of the hereto-appended claims. In yet another example, the adaptor component 104 can jointly take into consideration additive and convolutive distortion in connection with adapting parameters of the compressed model 106.
Furthermore, the adapter component 104 can utilize various techniques for adapting the compressed model 106 (and other compressed models) in connection with conserving storage (e.g., memory) and/or computing resources. For instance, as will be described herein, the adaptor component 104 can adapt parameters of the compressed model 106 only if the compressed model 106 is used in connection with recognizing at least a portion of the distorted speech utterance received by the receiver component 102.
Referring now to
For example, the distorted speech utterance can be referred to as y[m], and can be generated from a clean speech signal x[m] with noise (e.g., additive distortion) n[m] and the channel's impulse response (e.g., convolutive distortion) according to the following:
y[m]=x[m]*h[m]+n[m] (1)
y, x, n, and h are the vector-valued distorted speech, clean speech, additive distortion, and convolutive distortion, respectively, all in the Mel-frequency cepstral coefficients (MFCC) domain.
Such a model can be used to ascertain an additive distortion mean vector μn and a convolutive mean distortion vector μh (e.g., in the Mel-frequency cepstral coefficients (MFCC) domain).
In another example, the model 202 can be a nonlinear phase-sensitive model of multiple distortions in uttered speech. As noted above, Equation (1) can be used to represent a distorted speech utterance. With discrete Fourier transformation (DFT), the following equivalent relations can be established in the frequency domain:
Y[k]=X[k]H[k]+N[k], (2)
where k is a frequency-bin index in DFT given a fixed-length time window. The power spectrum of the distorted speech can then be the following:
|Y[k]|2=|X[k]|2|H[k]|2+|N[k]|2+2|X[k]∥H[k]∥N[k]|cos θk, (3)
where θk denotes an (random) angle between the two complex variables N[k] and (X[k]H[k]).
By applying a set of Mel-scale filters (L in total) to the power spectrum in Equation (3), the l-th Mel filter-bank energies can be obtained for distorted speech, clean speech, additive distortion, and convolutive distortion, respectively, as follows:
where the l-th filter can be characterized by the transfer function Wk(l)≧0(Σk Wk(l)=1).
The phase factor α(l) of the l-th Mel filter bank can be:
Given the above, the following relation can be obtained in the Mel filter-bank domain for the l-th Mel filter bank output:
|{tilde over (Y)}(l)|2=|{tilde over (X)}(l)|2|{tilde over (H)}(l)|l+|Ñ(l)|2+2{tilde over (α)}(l){tilde over (X)}(l)∥{tilde over (H)}(l)∥Ñ(l)| (9)
Further, a phase-factor vector for all the L Mel filter-banks can be defined as follows:
α=[α(1),═(2), . . . ═(l), . . . α(L)]T (10
A logarithm can be taken of both sides of Equation (9) and non-square discrete cosine transform (DCT) matrix C can be multiplied to both sides of Equation (9) for all the L Mel filter banks, the following nonlinear, phase-sensitive distortion model can be obtained in the cepstral domain:
y=x+h+C log(1+exp(C−1(n−x−h))+2α·exp(C−(n−x−h)/2))=x+h+gα(x,h,n), (11)
where gα(x,h,n)=
C log(1+exp(C−1(n−x−h)+2α·exp(C−1(n−x−h)/2)) (12)
and C−1 is the (pseudo) inverse DCT matrix, and y, x, n, and h are the vector-valued distorted speech, clean speech, additive distortion, and convolutive distortion, respectively, all in the Mel-frequency cepstral coefficients (MFCC) domain. The • operation for two vectors can denote an element-wise product, and each exponentiation of a vector above may also be an element-wise operation. Again, such a model can be used to ascertain an additive distortion mean vector μn and a convolutive mean distortion vector μh (e.g., in the Mel-frequency cepstral coefficients (MFCC) domain).
The adaptor component 104 can adapt parameters of the compressed model 106 based at least in part upon the output of the model 202. For instance, the adaptor component 104 can adapt parameters of the compressed model 202 based at least in part upon the additive distortion mean vector μn and the convolutive mean distortion vector μh.
Pursuant to an example, the adaptor component 104 can linearize output of the model 202, wherein the model is nonlinear but does not contemplate phase. For instance, the adaptor component 104 can use a vector Taylor series (VTS) algorithm to output a first order approximation of x, n, and h. In an example, for a given additive distortion mean vector μn and convolutive mean distortion vector μh, a matrix G(.) that depends on μx for a k-th Gaussian in a j-th state in the compressed model 106 can be defined as follows:
where C can be a non-square discrete cosine transform (DCT) matrix, C−1 can be a (pseudo) inverse DCT matrix, and diag(.) can refer to a diagonal covariance matrix with its diagonal component value being equal to the value of the vector in the argument. Each division of a vector can also be an element-wise operation.
The adaptor component 104 can then adapt Gaussian mean vectors in the compressed model 106 for the k-th Gaussian in the j-th state for instance, using the following algorithm:
μy,jk≈μx,jk+μh+C log(1+exp(C−1(μn−μx,jk−μh))) (14)
Further, the adaptor component 104 can adapt a covariance matrix in the compressed model 106 using the following algorithm:
Σy,jk≈G(j,k)Σx,jkG((j,kT+(I−G(j,k))Σn(I−G(j,k))T (15)
where Σx,jk is a covariance matrix for clean speech for the k-th Gaussian in the j-th state of the compressed model 106, and where Σn is a covariance matrix for additive distortion.
For the delta and delta/delta portions of MFCC vectors, the adaptor component 104 can use the following algorithms to adapt the mean vector and covariance matrix:
μΔy,jk≈G(j,k)μΔx,jk+(I−G(j,k)μΔn (16)
μΔΔy,jk≈G(j,k)μΔΔx,jk+(I−G(j,k)μΔΔn (17)
ΣΔy,jk≈G(j,k)ΣΔx,jkG(j,k)T+(I−G(j,k)Σn(I−G(j,k)T (18)
ΣΔΔy,jk≈G(j,k)ΣΔΔx,jkG(j,k)T+(I−G(j,k)ΣΔΔn(I−G(j,k))T (19)
As can be discerned, the example above (e.g., Equations (13)-(19)) describes the adaptor component 104 adapting a covariance matrix and delta and delta/delta portions of MFCC vectors without accounting for phase. It is to be understood, however, that the adaptor component 104 can consider phase when adapting such parameters.
For instance, as noted above, the adaptor component 104 can use a first-order VTS approximation with respect to x, n, and h. In an example, the adaptor component 104 can use an assumption that a phase-factor vector α is independent of x, n, and h, and the following can be obtained:
where diag(.) refers to a diagonal covariance matrix with its diagonal component value being equal to the value of the vector in the argument, μn is an additive distortion mean vector, μh is a convolutive distortion mean vector, and μx is a clean speech mean vector. Each division of a vector can also be an element-wise operation.
Continuing with the example above, for a given additive distortion mean vector μn and convolutive distortion mean vector μh, a value of G (.) can depend on the clean speech mean vector μx. Specifically, for the k-th Gaussian in the j-th state in the compressed model 106, the adaptor component 104 can determine an element of the G (.) matrix as follows:
Thereafter, the adaptor component 104 can obtain Gaussian mean vectors (the k-th Gaussian in the j-th state) of the desirably adapted compressed model 106 by taking an expectation of both sides of Equation (20):
μy,jkα≈μx,jk+μh+gα(μx,jk,μh,μn), (25)
which can be applied only to a static portion of the MFCC vector.
The adaptor component 104 can further estimate a covariance matrix Σy,jk,α in the desirably adapted compressed model 106 by determining a weighted sum of the covariance matrix of the compressed model 106 (prior to the parameters 110 therein being adapted (Σx,jk)) and the covariance matrix of distortion (Σn). In an example, the adaptor component 104 can determine the covariance matrix Σy,jk,α by taking a variance operation on both sides of Equation (20) as follows:
Σy,jk,α=Gα(j,k)Σx,jkGα(j,k)T+(I−Gα(j,k)Σn(I−Gα(j,k))T. (26)
Furthermore, the adaptor component 104 may not take into consideration convolutive distortion variance as such variance can be treated as a fixed, deterministic quantity in a given utterance. The adaptor component 104 may, for delta and delta/delta portions of MFCC vectors, use the following adaption formulas for the mean vector and covariance matrix in connection with adapting the parameters of the compressed model 106:
μΔy,jk,α≈Gα(j,k)μΔx,jk+(I−Gα(j,k)μΔn, (27)
μΔΔy,jk,α≈Gα(j,k)μΔΔx,jk+(I−Gα(j,k))μΔΔn)) (28)
ΣΔy,jk,α≈Gα(j,k)ΣΔΔx,jkGα(j,k)T+(I−Gα(j,k))ΣΔΔn(I−Ga(j,k))T (29)
ΣΔΔy,jk,αGα(j,k)ΣΔΔx,jkGα(j,k)T+(I−Gα(j,k)ΣΔΔn(I−Gα(j,k))T (30)
Thus, it can be discerned that the adaptor component 104 can adapt parameters of the compressed model 106 by considering phase corresponding to uttered speech. Furthermore, to improve performance of speech recognition using the compressed model 106, the adaptor component 104 can perform the following actions: a) adapt parameters of the compressed model 106 using initial estimates for the convolutive distortion mean vector μh, the additive distortion mean vector μn, and the diagonal covariance matrix diag(.); b) adapt parameters of the compressed model 106 based at least in part upon such initial estimates; c) decode the received speech utterance using the compressed model 106 with the adapted parameters; d) re-estimate parameters of the compressed model 106 based upon the received speech utterance and the adapted compressed model 106; and e) adapt parameters of the compressed model 106 based at least in part upon re-estimated parameters.
In an example, the adaptor component 104 can initialize the convolutive distortion mean vector μh. For instance, the adaptor component 104 can initialize the convolutive distortion mean vector μh by setting each element of the vector to zero. Furthermore, the adaptor component 104 can initialize the additive distortion mean vector μn using sample estimates from at least a first plurality of frames (speech-free) from the received distorted speech utterance. In addition, the adaptor component 104 can also use sample estimates from a last plurality of frames from the received distorted speech utterance in connection with initializing the additive distortion mean vector μn. Still further, the adaptor component 104 can initialize the diagonal covariance matrix diag(.) by using sample estimates from the first and/or last plurality of frames from the received distorted speech utterance.
As noted above, the adaptor component 104 can use the initialized convolutive distortion mean vector μh, the additive distortion mean vector μn, and the diagonal covariance matrix diag (.) to initially adapt parameters of the compressed model 106. The adaptor component 104 can then decode the received distorted speech utterance, and can re-estimate parameters used in the adaption algorithms noted above. In an example, the adaptor component 104 can estimate parameters pertaining to the convolution distortion mean, static and dynamic additive noise means, and static and dynamic additive noise variances. For instance, the adaptor component 104 can use an expectation-maximization algorithm in connection with re-estimating the aforementioned parameters using the first order VTS approximation.
For example, γt (j, k) can denote a posterior probability for the k-th Gaussian in the j-th state of the second model 108:
γt(j,k)=p(θt=j,εt=k|Y,
where θt can denote the state index at time frame t, εt can denote the Gaussian index at time frame t, and
The adaptor component 104 can estimate ΣΔn and ΣΔΔn in a similar manner as shown in Equation (36) by replacing static parameters with corresponding delta and delta/delta parameters. Furthermore, while the above equations consider phase, it is to be understood that phase need not be taken into consideration when using such algorithms.
Referring now to
Pursuant to an example, uncompressed model 304 can be a HMM that has been trained with clean speech and/or trained with “unclean” speech (e.g., speech that includes numerous distortions). Furthermore, the compressor component 302 can use any suitable compression technique to compress the uncompressed model 304 (e.g., to create the compressed model 308). In an example, the compressor component 302 can use a subspace coding (SSC) scheme. For instance, the uncompressed model 304 can include K Gaussians each with fixed dimension D and with a diagonal covariance matrix, and the compressor component 302 can perform quantization along each separate dimension of the Gaussians. Thus, the compressor component 302 can quantize dimension d of Gaussian k (mk[d], vk2[d]) into a two-dimensional vector (μn[d], σn2[d]). The compressor component 302 can also use a standard k-means clustering algorithm to design the codebook 310 with a conventional distortion measure for Gaussian models. The centroid of a cluster can be computed by uniform quantization. It is to understood, however, that the compressor component 302 can use any suitable compression technique and/or any suitable technique to design the codebook 310 in connection with compressing the uncompressed model 304 (resulting in the compressed model 308).
With reference now to
The adaptor component 104 can include an expander component 410 that can use the codebook 408 to expand one or more of the compressed models 404-406 for decoding and/or adaption of parameters thereof. The adaptor component 104 can additionally include a decoder component 412 that can use one or more of the compressed models 404-406 to decode the distorted speech utterance received by the receiver component 102.
The adaptor component 104 can use various techniques to adapt parameters of one or more of the compressed models 404-406, wherein a chosen technique can be based at least in part upon available memory and/or processing resources corresponding to a speech recognition system. In a first example, the adaptor component 104 can estimate various parameters corresponding to the received distorted speech utterance. As noted above, the adaptor component 104 can use sample estimates from a first plurality of frames of the received distorted speech utterance to estimate the various parameters prior to the distorted speech utterance being decoded. The expander component 410 can access the codebook 408 and expand the compressed models 404-406, and the adaptor component 104 can adapt each of the compressed models 404-406 using the estimated parameters. The decoder component 412 can decode the received distorted speech utterance using the adapted compressed models, and the adaptor component 104 can perform re-estimation as described above (e.g., using Equations (32)-(36)). Subsequent to the decoder component 412 decoding the distorted speech utterance, the adaptor component 104 can use the parameters determined by way of Equations (32)-(36) to again adapt parameters of each of the compressed models 404-406. Re-estimation and adaption may occur iteratively if desired. The received distorted speech utterance may then be decoded using a subset of the compressed models 404-406.
In a second example, the adaptor component 104 can again estimate various parameters corresponding to the received distorted speech utterance. The expander component 410 can expand each of the compressed models 404-406 using the codebook 408 (or a plurality of codebooks). The adaptor component 104 can use such estimates to initially adapt parameters of each of the compressed models 404-406. The decoder component 412 can decode the distorted speech utterance using a subset of the compressed models 404-406 (with adapted parameters). For instance, the decoder component 412 may observe a relatively small number of the compressed models 404-406 when decoding a particular speech utterance. To reduce computational resources, the adaptor component 104 can adapt parameters of models that are observed during decoding of the received distorted speech utterance while not adapting other, unobserved compressed models. Still further, the adaptor component 104 may adapt observed Gaussians in compressed models used by the decoder component 412 when decoding the distorted speech utterance but may not adapt unobserved Gaussians. The adaptor component 104, for instance, can use the adaption algorithms (16)-(19) in connection with adapting parameters of the subset of compressed models 404-406. The decoder component 412 may then decode the distorted speech utterance using the observed, adapted compressed models 404-406. After the compressed models 404-406 have been adapted, vector quantization (VQ) can be used to compress the models (after expansion) while retaining an original mapping relation in SSC. Pursuant to an example, data-driven VQ, uniform VQ, or other vector quantization technique can be used in connection with compressing adapted models.
In a third example, the adaptor component 104 can adapt a subset of the compressed models 404-406 without adapting each model in the compressed models 404-406 using estimates described in the first two examples. For instance, the decoder component 412 can decode the speech utterance using the compressed models 404-406, wherein the compressed models 404-406 have not been subject to adaption by the adaptor component 104. A subset of the compressed models 404-406 used by the decoder component 412 to decode the distorted speech utterance can be identified, and the adaptor component 104 can adapt parameters of such subset of the compressed models 404 (e.g., using initial estimates the convolutive distortion mean vector μh, the additive distortion mean vector μn, and the diagonal covariance matrix diag(.)) while not adapting parameters corresponding to compressed models not observed during decoding.
Subsequent to the adaptor component 104 adapting parameters of the subset of compressed models 404-406 as described above, the decoder component 412 can use such subset of compressed models 404-406 to decode the distorted speech utterance a second time. Thereafter, the adaptor component 104 can perform re-estimation as described above (e.g., using Equations (32)-(36)), and can adapt parameters of a subset of compressed models 404-406 observed during the second decoding of the speech utterance. The decoder component 410 can then decode the distorted speech utterance a third time. As with the second example, after a subset of compressed models 404-406 that have been observed during the third decoding have been adapted, vector quantization (VQ) can be used to compress the models while retaining an original mapping relation in SSC.
With reference now to
Moreover, the acts described herein may be computer-executable instructions that can be implemented by one or more processors and/or stored on a computer-readable medium or media. The computer-executable instructions may include a routine, a sub-routine, programs, a thread of execution, and/or the like. Still further, results of acts of the methodologies may be stored in a computer-readable medium, displayed on a display device, and/or the like.
Referring now to
With reference now to
At 608, each of the plurality of compressed models in the speech recognition system is adapted (e.g., parameters thereof are adapted) based at least in part upon the first set of parameters estimated at act 606. For example, Equations (13)-(19) can be used in connection with adapting each of the plurality of compressed models in the speech recognition system.
At 610, the distorted speech utterance received at 604 can be decoded, wherein a subset of the plurality of compressed models are observed when decoding the speech utterance. For instance, not all compressed models in a speech recognition system will be used during decoding.
At 612, a second set of parameters corresponding to the compressed models are estimated based at least in part upon the decoding act of 610. For instance, the second set of parameters can include a convolutive distortion mean vector, static and dynamic additive distortion mean vectors, and static and dynamic additive distortion variances. Furthermore, Equations (31)-(36) can be used in connection with estimating the aforementioned second set of parameters.
Referring now to
Now referring to
At 808, each of the plurality of compressed models in the speech recognition system is adapted (e.g., parameters thereof are adapted) based at least in part upon the first set of parameters estimated at act 806. For example, Equations (13)-(19) can be used in connection with adapting each of the plurality of compressed models in the speech recognition system.
At 810, the distorted speech utterance received at 604 can be decoded, wherein a subset of the plurality of compressed models are observed when decoding the speech utterance. For instance, as noted above, not all compressed models in the speech recognition system will be used during decoding.
At 812, a second set of parameters corresponding to the compressed models are estimated based at least in part upon the decoding act of 810. For instance, the second set of parameters can include a convolutive distortion mean vector, static and dynamic additive distortion mean vectors, and static and dynamic additive distortion variances. Furthermore, Equations (31)-(36) can be used in connection with estimating the aforementioned second set of parameters.
Now turning to
At 816, the distorted speech utterance received at 804 can be decoded using at least one of the compressed models adapted at 814. The methodology 800 ends at 818.
Now referring to
At 1008, a first set of parameters corresponding to the first subset of the plurality of compressed models can be coarsely estimated. As noted above, the first set of parameters can include a convolutive distortion mean vector, an additive distortion mean vector, and/or a diagonal covariance matrix (described above).
At 1010, the first subset of the plurality of compressed models (e.g., compressed models observed during the decoding act of 1006) in the speech recognition system can be adapted (e.g., parameters thereof are adapted) based at least in part upon the first set of parameters estimated at act 1008. For example, Equations (13)-(19) can be used in connection with adapting the subset of compressed models in the speech recognition system.
At 1012, the received distorted speech utterance is decoded a second time using the plurality of compressed models in the speech recognition system. A second subset of the plurality of compressed models can be observed during the act of decoding, wherein the second subset may include identical models in the first subset or may include at least one different model when compared to models in the first subset of compressed models.
Now referring to
At 1016, the second subset of compressed models is adapted based at least in part upon the second set of parameters estimated at 1014. For instance, the second subset of compressed models can be adapted through use of Equations (13)-(19) or similar algorithms.
At 1018, the received distorted speech utterance is decoded using the plurality of compressed models, wherein a third subset of the plurality of compressed models can be observed during the act of decoding. For instance, the third subset of compressed models can be substantially similar to the first subset of compressed models and/or the second subset of compressed models. In another example, the third subset of compressed models can be non-similar to the first subset of the compressed models and/or the second subset of compressed models. The methodology 1000 completes at 1020.
Referring now to
The methodology 1200 starts at 1202, and at 1204 a distorted speech utterance is received. At 1206, an additive distortion mean vector corresponding to the distorted speech utterance is coarsely estimated based at least in part upon a portion of the received distorted speech utterance.
At 1208, parameters of a first subset of compressed models in the plurality of compressed models are adapted based at least in part upon the coarsely estimated additive distortion mean vector.
At 1210, the received distorted speech utterance is decoded using a second subset of compressed models in the plurality of compressed models.
At 1212, the additive distortion mean vector is re-estimated based at least in part upon the decoded speech utterance.
At 1214, parameters of the second subset of compressed models in the plurality of compressed models are adapted based at least in part upon the re-estimated additive distortion mean vector.
At 1216, the received distorted speech utterance is decoded using at least one compressed model in the second subset of compressed models. The methodology completes at 1218.
While some of the methodologies above describe adapting models, it is to be understood that the methodologies can be adapted to adapt parameters in one or more models. For instance, when a speech utterance is decoded through use of a HMM, only a portion of Gaussians in the HMM may be observed. Thus, the methodologies above can be adapted such that subsets of Gaussians in a HMM are adapted (rather than all Gaussians in the HMM). Moreover, the methodologies can be adapted such that only a portion of a model observed during decoding is adapted (e.g., to save computing and/or memory resources).
Now referring to
The computing device 1300 additionally includes a data store 1308 that is accessible by the processor 1302 by way of the system bus 1306. The data store 1308 may include executable instructions, compressed models, etc. The computing device 1300 also includes an input interface 1310 that allows external devices to communicate with the computing device 1300. For instance, the input interface 1310 may be used to receive instructions from an external computer device, speech utterances from an individual, etc. The computing device 1300 also includes an output interface 1312 that interfaces the computing device 1300 with one or more external devices. For example, the computing device 1300 may display text, images, etc. by way of the output interface 1312.
Additionally, while illustrated as a single system, it is to be understood that the computing device 1300 may be a distributed system. Thus, for instance, several devices may be in communication by way of a network connection and may collectively perform tasks described as being performed by the computing device 1300.
As used herein, the terms “component” and “system” are intended to encompass hardware, software, or a combination of hardware and software. Thus, for example, a system or component may be a process, a process executing on a processor, or a processor. Additionally, a component or system may be localized on a single device or distributed across several devices.
It is noted that several examples have been provided for purposes of explanation. These examples are not to be construed as limiting the hereto-appended claims. Additionally, it may be recognized that the examples provided herein may be permutated while still falling under the scope of the claims.
Wu, Jian, Yu, Dong, Acero, Alejandro, Deng, Li, Li, Jinyu, Gong, Yifan
Patent | Priority | Assignee | Title |
10204619, | Oct 22 2014 | GOOGLE LLC | Speech recognition using associative mapping |
10229672, | Dec 31 2015 | GOOGLE LLC | Training acoustic models using connectionist temporal classification |
10403291, | Jul 15 2016 | GOOGLE LLC | Improving speaker verification across locations, languages, and/or dialects |
10706840, | Aug 18 2017 | GOOGLE LLC | Encoder-decoder models for sequence to sequence mapping |
10803855, | Dec 31 2015 | GOOGLE LLC | Training acoustic models using connectionist temporal classification |
11017784, | Jul 15 2016 | GOOGLE LLC | Speaker verification across locations, languages, and/or dialects |
11341958, | Dec 31 2015 | GOOGLE LLC | Training acoustic models using connectionist temporal classification |
11594230, | Jul 15 2016 | GOOGLE LLC | Speaker verification |
11769493, | Dec 31 2015 | GOOGLE LLC | Training acoustic models using connectionist temporal classification |
11776531, | Aug 18 2017 | GOOGLE LLC | Encoder-decoder models for sequence to sequence mapping |
8442821, | Jul 27 2012 | GOOGLE LLC | Multi-frame prediction for hybrid neural network/hidden Markov models |
8484022, | Jul 27 2012 | GOOGLE LLC | Adaptive auto-encoders |
9240184, | Nov 15 2012 | GOOGLE LLC | Frame-level combination of deep neural network and gaussian mixture models |
9552817, | Mar 19 2014 | Microsoft Technology Licensing, LLC | Incremental utterance decoder combination for efficient and accurate decoding |
9786270, | Jul 09 2015 | GOOGLE LLC | Generating acoustic models |
9858922, | Jun 23 2014 | GOOGLE LLC | Caching speech recognition scores |
9922654, | Mar 19 2014 | Microsoft Technology Licensing, LLC | Incremental utterance decoder combination for efficient and accurate decoding |
9953646, | Sep 02 2014 | BELLEAU TECHNOLOGIES, LLC | Method and system for dynamic speech recognition and tracking of prewritten script |
Patent | Priority | Assignee | Title |
5627939, | Sep 03 1993 | Microsoft Technology Licensing, LLC | Speech recognition system and method employing data compression |
5727124, | Jun 21 1994 | Alcatel-Lucent USA Inc | Method of and apparatus for signal recognition that compensates for mismatching |
5848384, | Aug 18 1994 | British Telecommunications public limited company | Analysis of audio quality using speech recognition and synthesis |
6006186, | Oct 16 1997 | Sony Corporation; Sony Electronics, Inc. | Method and apparatus for a parameter sharing speech recognition system |
6768979, | Oct 22 1998 | Sony Corporation; Sony Electronics Inc. | Apparatus and method for noise attenuation in a speech recognition system |
6907398, | Sep 06 2000 | Degussa AG | Compressing HMM prototypes |
7219057, | Sep 25 2000 | Koninklijke Philips Electronics | Speech recognition method |
7236930, | Apr 12 2004 | Texas Instruments Incorporated | Method to extend operating range of joint additive and convolutive compensating algorithms |
20030115055, | |||
20040181408, | |||
20040230424, | |||
20070033027, | |||
20070033028, | |||
20070033034, | |||
20070088552, | |||
20080300875, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Sep 16 2008 | Deng, Li | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 021569 | /0434 | |
Sep 16 2008 | YU, DONG | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 021569 | /0434 | |
Sep 16 2008 | ACERO, ALEJANDRO | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 021569 | /0434 | |
Sep 18 2008 | LI, JINYU | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 021569 | /0434 | |
Sep 18 2008 | WU, JIAN | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 021569 | /0434 | |
Sep 22 2008 | GONG, YIFAN | Microsoft Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 021569 | /0434 | |
Sep 23 2008 | Microsoft Corporation | (assignment on the face of the patent) | / | |||
Oct 14 2014 | Microsoft Corporation | Microsoft Technology Licensing, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 034564 | /0001 |
Date | Maintenance Fee Events |
Jan 20 2016 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Mar 30 2020 | REM: Maintenance Fee Reminder Mailed. |
Sep 14 2020 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Aug 07 2015 | 4 years fee payment window open |
Feb 07 2016 | 6 months grace period start (w surcharge) |
Aug 07 2016 | patent expiry (for year 4) |
Aug 07 2018 | 2 years to revive unintentionally abandoned end. (for year 4) |
Aug 07 2019 | 8 years fee payment window open |
Feb 07 2020 | 6 months grace period start (w surcharge) |
Aug 07 2020 | patent expiry (for year 8) |
Aug 07 2022 | 2 years to revive unintentionally abandoned end. (for year 8) |
Aug 07 2023 | 12 years fee payment window open |
Feb 07 2024 | 6 months grace period start (w surcharge) |
Aug 07 2024 | patent expiry (for year 12) |
Aug 07 2026 | 2 years to revive unintentionally abandoned end. (for year 12) |