Incrementally regulated discriminative margins in MCE training for speech recognition

Information

  • Patent Application
  • 20080052075
  • Publication Number
    20080052075
  • Date Filed
    August 25, 2006
    18 years ago
  • Date Published
    February 28, 2008
    16 years ago
Abstract
A method and apparatus for training an acoustic model are disclosed. A training corpus is accessed and converted into an initial acoustic model. Scores are calculated for a correct class and competitive classes, respectively, for each token given the acoustic model. From this score a misclassification measure is calculated and then a loss function is calculated from the misclassification measure. The loss function also includes a margin value that varies over each iteration in the training. Based on the calculated loss function the acoustic model is updated, where the loss function with the margin value is minimized. This process repeats until such time as an empirical convergence is met.
Description

BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram of an exemplary speech recognition system.



FIG. 2 is a block diagram of a exemplary system used to train acoustic model



FIG. 3 is an example series of plots of sigmoid functions illustrating the MCE results for given tokens with and without the margin.



FIG. 4 is a plot of recognition error rates during an example training and testing where the margin is fixed.



FIG. 5 is a plot of recognition error rates where the margin increments from zero to −1.



FIG. 6 is a plot of recognition errors rates where the margin increments from 0.4 to −0.5.



FIG. 7 is a flow diagram illustrating the steps executed during training of the acoustic model according to one embodiment.





DETAILED DESCRIPTION


FIG. 1 is a block diagram illustrating exemplary speech recognition 100 according to one embodiment. The speech recognition system 100 includes a microphone 92, an analog-to-digital (A/D) converter 101, a training module 115, a feature extraction module 110, a lexicon storage module 130, an acoustic model 140, a tree search engine 120, and a language model 150. It should be noted that the entire system 100, or part of speech recognition system 100, can be implemented on any computer system or across multiple computer systems. For example, microphone 92 can preferably be provided as an input device to the computer through an appropriate interface, and through the A/D converter 101.


The training module 115 and the feature extraction module 110 can either be hardware modules in the computer system, or software modules stored in any information storage device. This information is accessible by a processing unit on the computer or any other suitable processor. In addition, the lexicon storage module 130, the acoustic model 140, and the language model 150 are also preferably stored in any of the memory devices contained on the computer. Furthermore, the tree search engine 120 is implemented in a processing unit (which can include one or more processors) or can be performed by a dedicated speech recognition processor employed by the computer.


In the embodiment illustrated in FIG. 1, during speech recognition, speech is provided as an input into system 100 in the form of an audible voice signal by the user to the microphone 92. The microphone 92 converts the audible speech signal into an analog electronic signal which is provided to the A/D converter 101. The A/D converter 101 converts the analog speech signal into a sequence of digital signals, which is provided to the feature extraction module 110. In one embodiment, the feature extraction module 110 is a conventional array processor that performs spectral analysis on the digital signals and computes a magnitude value for each frequency band of a frequency spectrum. The signals are, in one illustrative embodiment, provided to the feature extraction module 110 by the A/D converter 101 at a sample rate of approximately 16 kHz.


The feature extraction module 110 divides the digital signal received from the A/D converter 101 into frames that include a plurality of digital samples. In one embodiment, each frame is approximately 10 milliseconds in duration. The frames are then encoded by the feature extraction module 110 into a feature vector reflecting the spectral characteristics for a plurality of frequency bands. In the case of discrete and semi-continuous Hidden Markov Modeling, the feature extraction module 110 also encodes the feature vectors into one or more code words using vector quantization techniques and a code book derived from training data. Thus, the feature extraction module 110 provides, at its output, the feature vectors (or code words) for each spoken utterance. The feature extraction module 110 provides the feature vector (or code words) of a rate of one feature vector (or code word) approximately every 10 milliseconds.


Output probability distributions are then computed against Hidden Markov Models using the feature vector (or code words) of the particular frame being analyzed. These probability distributions are later used in executing a Viterbi or similar type of processing technique.


Upon receiving the code words from the feature extraction module 110, the tree search engine 120 accesses information stored in the acoustic model 140. The model 140 stores acoustic models such as Hidden Markov Models which represent speech units to be detected by the speech recognition system 100. In one embodiment, the acoustic model 140 includes the senone tree associated with each Markov state in a Hidden Markov Model. The Hidden Markov Model represents, in one illustrative embodiment, phonemes. Based on the senones in the acoustic model 140, the tree search engine 120 determines the most likely phonemes represented by the feature vectors (or code words) received from the feature extraction module 110 and hence representative of the utterance received from the user of the system.


The tree search engine 120 also accesses the lexicon stored in the module 130. The information received by the tree search engine 120 based on its accessing of the acoustic model 140 is used in searching the lexicon storage model 130 to determine a word that most likely represents the code words or feature vector received from the features extraction module 110. Also, the search engine 120 accesses the language model 150, which is illustratively a 60,000 word trigram language model, derived from the North American Business New Corpus. The language model 150 is also used in identifying the most likely word represented by the input speech. The most likely word is provided as output text of the speech recognition system 100.


Although described herein where the speech recognition system 100 uses HMM modeling and senone trees, it should be understood that the speech recognition system 100 can take many forms, and all that is required is that it provide as an output the text spoken by the user.



FIG. 2 is a detailed block diagram of a system 200 used to train acoustic model 140 in accordance with one illustrative embodiment. In one embodiment, portions of the training process are handled by training module 115 shown in FIG. 1 above. In this embodiment, system 200 can be used to generate a model that is customized to the user. This custom model is an exemplary description only, and other embodiments can use a general model for all speakers, or have a limited number of models to approximate the various general speakers.


System 200 includes a data store 202, and acoustic model training components 204a and 204b. It should be noted that components 204a and 204b can be the same component used by different portions of system 200, or they can be different components. In some embodiments components 204a and 204b are components of training module 115. System 200 also includes a model estimator 206, enrollment data 208, selection component 210 and optionally cohort data 212, which is data corresponding to selected cohort models.



FIG. 2 also shows that data store 202 includes pre-stored data 214 as well as incrementally corrected data 216. Pre-stored data 214 may illustratively be a wide variety of commercially available data sets which includes acoustic data and transcriptions indicative of input utterances. One example of the commercially available data can be the TIDIGITS corpus discussed later. The incrementally collected data 216 can include, for example, data from additional speakers which is collected at a later time. Enrollment data 208 is illustratively a set of three sentences, for example, collected from a user. In training the acoustic model, the acoustic model training component 204a accesses the pre-stored data 214 and trains the acoustic model 250. The user inputs for these samples are then received in the form of the enrollment data 208. Illustratively, enrollment data 208 not only includes an acoustic representation of the user input of the enrollment data, but an accurate transcription of the enrollment data as well. This transcription can be obtained by directing a user to speak a predetermined sentences or number string, and verifying they spoke the sentences or number string. Thus, it is possible to know exactly what words corresponded to the acoustic data. Alternatively, other methods of obtaining the transcription can be used as well. For example, the user's speech input to the speech recognition system can be input to the speech recognition system 100 to obtain the transcription.


Model estimator 206 then assesses intermittently collected data 216 which is data from a number of different speakers that may be used for cohort speakers. Based on the acoustic model 250 and the data 216, model estimator 206 estimates a plurality of different models 256.


Each possible model 256 is provided to the selection component 210. The selection component 210 compares the input samples (enrollment data 208) to the estimated models 256. The selection component 210 then selects the speakers that are closest to the enrollment data 208. This can be done using cohorts or any other predetermined similarity measure. Using this data 312, the acoustic model generation component 204b generates an Sr acoustic model 266.


In order to determine the best acoustic model using the available training data, the training system 200 uses minimum classification error (MCE) or similar discriminative training algorithms in developing the acoustic model 140. Conventional MCE learning minimizes the smooth sentence or string level error rate that is commonly associated with acoustic model training. In the present embodiments r=1, . . . ,R is used as an index for a token or string (e.g., a single sentence or utterance) in the training data 214. Each token consists of a “string” of a vector valued observation sequence (Xr=xr,1, . . . xr, Tr,) with the corresponding label (word) sequence (Sr=wr,1, . . . , wr,Nr,) That is, Sr denotes the correct label sequence for a token r. For the present embodiments use Sr to denote all possible label sequences for the r token, including the correct label sequence as Sr and all other incorrect label sequences. These correct and incorrect label sequences are useful in determining the relative closeness or accuracy of the acoustic model.


In MCE, a loss function for a single utterance Xr is defined. An advantage to using a loss function is it has the property that its solution is close to zero if the string is correctly recognized and is close to one if the string has been incorrectly recognized. One example of a smooth function that achieves the property for the loss function is represented in the following sigmoid function.











l
r



(


d
r



(


X
r

,
Λ

)


)


=

1

1
+




-
α








d
r



(


X
r

,
Λ

)










Equation





1







In Equation 1 it is assumed that α=1 for simplicity in the exposition without a loss of generality. In Equation 1 dr(Xr,Λ) is also referred to as the misclassification measure, and Λ is the model parameter to be trained. For example, in one best MCE training only the top incorrectly recognized string is used as a “competitive candidate” for discriminative training, dr(Xr,Λ) is the log likelihood distance between the correct string Sr,c and the incorrect competitive string. That is represented as Equation 2.






d
r(Xr,Λ)=−log pΛ(Xr,Sr,c)+log pΛ(Xr,Sr,e)   Equation 2


Next Equation 2 is substituted into Equation 1 and results in Equation 3.











l
r



(


d
r



(


X
r

,
Λ

)


)


=



p
Λ



(


X
r

,

S

r
,
e



)





p
Λ



(


X
r

,


S

r
,
e


|
Λ


)


+


p
Λ



(


X
r

,


S

r
,
c


|
Λ


)








Equation





3







For more general N-best MCE training where the top N>1 incorrectly recognized strings are used as the competitive candidates, a soft-maximization function has been has been widely used. One example of this function is illustrated by Equation 4.











d
r



(


X
r

,
Λ

)


=



-
log








p
Λ



(


X
r

,

S
r


)



+

log



{


1

N
-
1








s
r

,


s
r



S
r






exp


[

η





log







p
Λ



(


X
r

,

s
r


)



]




}


1
η








Equation





4







The present embodiments have been approximated as a misclassification measure using a simpler form as illustrated by Equation 5 where wMCE(sr) is a non-negative waiting factor for the competitive string sr.











d
r



(


X
r

,
Λ

)


=



-
log








p
Λ



(


X
r

,

S
r


)



+

log






s
r

,


s
r



S
r









w
MCE



(

s
r

)


×




p
Λ



(


X
r

,

s
r


)










Equation





5







This results in a loss function for the N-best version of MCE becoming Equation 6, below, where the assignment of wMCE(sr)=1 is used for the correct string Sr.











l
r



(


d
r



(


X
r

,
Λ

)


)


=






s
r

,


s
r



S
r








w
MCE



(

s
r

)





p
Λ



(


X
r

,

s
r


)








s
r






w
MCE



(

s
r

)





p
Λ



(


X
r

,

s
r


)









Equation





6







where wMCE(sr) is a weighing factor of sr≠Sr,c


Next, in the MCE, the loss function at the super-string level is defined to be a sum of the loss functions of all individual string tokens. A super-string is a complete representation of the entire string used for training. This loss function is illustrated by Equation 7.











L
MCE



(
Λ
)


=




r
=
1

R








l
r



(


d
r



(


X
r

,
Λ

)


)







Equation





7







Next the present embodiment minimizes the super-string level loss function of the LMCE(Λ) is equivalent to the maximization of the following objective function illustrated as Equation 8.











O
MCE



(
Λ
)


=


R
-


L
MCE



(
Λ
)



=




r
=
1

R





p
Λ



(


X
r

,


S

r
,
c


|
Λ


)






s
r






w
MCE



(

s
r

)





p
Λ



(


X
r

,

s
r


)











Equation





8







The present embodiments implement an MCE algorithm that maximizes Equation 8, not through the use of the gradient ascend, as in the prior art, but by a special technique of optimization via growth transformation. This implementation results in an improved version of previous versions of this equation. The improvement lies in converting the super-string level objective function of the previous research into a normal string level objective function for MCE. This conversion is accomplished via a non-trivial mathematical framework, which results in a rational function that is then subject to optimization by growth transformation or an extended Baum-Welch algorithm. This framework requires the approximation of Equation 5 to the misclassification measure. In the present embodiments, using the growth transformation based optimization discussed below four iterations are sufficient to achieve empirical convergence. This is in contrast to the 40 or more iterations that are usually required by the gradient ascend method.


Referring now to FIG. 3, FIG. 3 is a series of plots illustrating the MCE results for given tokens in a class as a function of d. Given a fixed classifier or recognizer which defines decision boundaries for all possible pairs of classes, a margin is defined for each training token as a difference between the score of the token by the correct class and that by the most competitive class. A positive difference gives a positive sample, and a negative difference gives a negative sample. A large (i.e., positive) margin implies a wide tolerance gap. A recognizer with a large margin gives more robust discrimination than that with a smaller margin. However, it may not give lower empirical error rates in the training data, especially for multi-class tasks such as speech recognition.


The concept of a margin interpreted as a tolerance gap is incorporated into the MCE calculation by using a negative incrementally adjusted parameter β(I)<0 in the more generalized definition of the loss function illustrated by Equation 1. By adding this margin into Equation 1 results in an additional exponential component to the denominator of Equation 1. This is illustrated in Equation 9.











l
r



(


d
r



(


X
r

,
Λ

)


)


=

1

1
+




-

ad


(


X
r

,
Λ

)



+

β


(
1
)










Equation





9







In essence, in the conventional MCE calculation, β has been set to zero. By setting β to zero Equation 9 reverts back to Equation 1. However, as the margin provided by β(I) is a component of loss function in Equation 9, it is possible to determine the empirical discrimination pattern. This is referred to as a discriminative margin.


In Equation 9, the “iteration” argument I of β(I) signifies that the actual value of β at iteration I is regulated by incremental adjustments from a smaller negative value to a larger one. Small negative values of β in early iterations provide small margins while not sacrificing a significant reduction in empirical errors in training. Once the error pattern adjusts to the new error pattern for each iteration, an increment of β from β(I) to β(I+1) at the next iteration will have a similarly small effect on the empirical errors while achieving relatively larger margins that help reduce test errors. Further, incrementally adjusted margins help bring incorrectly classified training tokens that are far away from the center of the sigmoid function across the center faster than without using such margins. This is because the slopes of the sigmoid corresponding to these tokens are small and thus would be moved slowly by traditional MCE without incremental margins.



FIG. 3 illustrates a two-class special case for the use of discriminative margins in MCE. Tokens shaped as circles 310 are from class 1 and those represented as triangles 320 are from class 2. The graphs of the sigmoid function without a margin illustrated by 330 and 340 for classes 1 and 2, respectively, as currently achieved in conventional MCE, the circle token 332 near d=0 for class 1 will contribute to the model adjustment since it incurs some loss and it is near the decision boundary 335 where the slope of the sigmoid function 336 is large. However, after model adjustment which moves that token to the left, the slope of the sigmoid 336 becomes significantly smaller and hence model adjustments stop. An identical process applies to the triangle tokens 342 near the d=0 decision boundary 345 for class 2 in plot 340.


After the margin is introduced as illustrated by the lower figures in 350 and 360 in FIG. 3, a shift in the sigmoid function 356, 366 to the left of the magnitude m for both the circle tokens 310 and the triangle tokens 320 can be moved to the left over the distance at least m units longer than in the earlier example. Further, when the shift of the sigmoid function is done incrementally, a greater final distance or discriminative margin can be achieved.


An example of the implementation of the techniques described above is illustrated below using a TIDIGITS corpus. This is done in a standard experimental setup that is consistent with previous approaches on this task. The TIDIGITS corpus contains utterances from 326 speakers (111 men, 114 women, and 101 children) that were collected from 21 distinct regions of the United States. There are a total of 11 words (digits) in this corpus vocabulary. Specifically the digits of 1 through 9 plus zero and the word “oh” representing an alternative pronunciation of the word zero. Each utterance is a connected digit string, with the number of digits in the string varying between 1 and 7. However, in the TIDIGITS corpus, there are no 6 digit strings. In the present example, only the adult portion of the corpus issues that makes up the standard training set of 8623 digit strings and a standard test set of 8700 digit strings.


In this example, the data was sampled at a rate of 16 kHz. Thirty-three dimensional acoustic vectors were composed of the normalized energy of 10 Mel-Frequency Cepstrum Coefficients (MFCC) and their first and second order time derivatives. In this example, the models used are head-body-tail CDHMM's with a different number of Gaussian mixture components for each state. This results in a total number of Gaussian mixture components used in this example of 3284, which is roughly the same as typically appears in a nine-state whole word CDHMMs with 32 Gaussian mixtures per state. These models were then trained using the Maximum Likelihood (ML) criterion. Then, MCE training methods discussed above, with and without incorporation discriminative margins are applied. Both were applied using the ML-trained models to initialize the MCE training. In this example, the word error rate and string error rate in the test set using the initial ML-trained models are 0.28% and 0/78%, respectively, using tuned insertion penalty of −14.5 and a language model weight of −13.25. During this MCE training, a value in Equation 9 was tuned to be 1/120, and all HMM model parameters (except transition probabilities) were updated. The setting in this example gives the best MCE baseline (i.e., no discriminative margin used or β(I)=0), with a word error rate of 0.23% and a string error rate of 0.68%. This represents the 17.86% relative word error rate reduction and 12.82% relative string error rate reduction over the initial ML-trained models.









TABLE 1







Summary of the Experimental Results












WER

SER
















Relative

Relative



Margin
Absolute
reduction
Absolute
Reduction







B = 0
0.23%
Baseline
0.68%
Baseline



Method 1
0.20%
13.04%
0.57%
16.18%



Method 2
0.20%
13.04%
0.57%
16.18%



Method 3
0.19%
17.39%
0.55%
19.12%










Next, the digit HMMs are trained in initializing from the ML models with incrementally regulated discriminative margins β(I)<0 in the MCE training paradigm. In this example, α remains the same at 1/120 and the calculations continue using three different methods for setting the equation that regulates β(I). These three methods were evaluated under otherwise identical experimental conditions.


In the first method, β(I) is set to a fixed value over the range of [−1, 0] in all iterations. That is, β(I) is set to be independent of the iteration number I. This resulted in an optimal result when setting β(I)=−0.8. The results are plotted in FIG. 4, where the recognition error rates (WER and SER) are shown as a function of the fixed margin value over MCE training iterations. These error rates for the training and test sets are plotted separately. In FIG. 4, line 40 represents the SER in training, line 420 represents the WER in training, line 430 represents the SER in testing and line 440 represents the WER in testing. The initial HMMs for the MCE training with each of the fixed β margin values are from the ML training. A total of 15 MCE growth-transformation iterations are used for each of the fixed β values.


In the second method, the margin β(I) is designed to change from neutral (no margin or β=0) to a margin of β=−1, with a step size of −0.1 during the MCE. That is, β(I)=−0.1*(I-1), for I=1, . . . ,11. FIG. 5 shows the WER and SER results (for both training and test sets) as a function of the incrementally reduced margin value. In FIG. 5, line 510 represents the SER in training, line 520 represents the WER in training, line 530 represents the SER in testing and line 540 represents the WER in testing. When the margin equals zero (as indicated by 511 in FIG. 5) the HMMs are initialized in the MCE training (4 iterations) from the ML-trained models. As the margin becomes incrementally reduced for iterations 1 to 11, the previously MCE-trained models serve as the initial models for each iteration and the additional 4 MCE iterations are used for each new margin value.


In the third method, the margin is set to change from 0.4 to −0.5, having a step size of −0.1 as well. In other words, β(I)=0.4−0.1*(I-1), for I=1, . . . ,10. FIG. 6 illustrates the results of this calculation in a format similar to the format discussed above with respect to FIGS. 4 and 5. In FIG. 6, line 610 represents the SER in training, line 620 represents the WER in training, line 630 represents the SER in testing and line 640 represents the WER in testing. However, the results in FIG. 6 show slightly lower errors.


An examination of the results in FIGS. 4-6 reveals a consistent trend related to the effects of increasing discriminative margin on the recognition errors. As the margin is enlarged, the number of errors tends to be reduced and then reverse the direction as the margin further increases. Thus, the largest margin does not correspond to the lowest error.



FIG. 4-6 also illustrates that the lowest test error rates do not always occur at the same margin value. The overall results using the three methods discussed above were summarized in Table 1 above. In this table, the relative error rate reduction is calculated based upon the MCE baseline where the discriminative margin is set to zero. Thus, we observe a 13.04% relative word error rate reduction and a 16.18% relative string error rate reduction over the baseline MCE models using the methods illustrated in FIGS. 4 and 5. However, by using the method illustrated in FIG. 6, the results achieved a 0.19% absolute word error rate and 0.55% absolute string error rate. This translates into a 17.39% relative word error rate reduction and a 19.12% relative string error rate reduction over the MCE baseline. This result far exceeds previous error rates that have been observed using standard MCE.


In conclusion, referring now to FIG. 7, a flow diagram is provided to briefly illustrate a process that is employed by one embodiment to train the acoustic model. First a training data corpus is accessed or otherwise provided to the training module 115. This is illustrated at step 710. Then the training module 115 calculates an initial acoustic model using the training corpus. This is illustrated at step 720. Once the initial acoustic model is created the system calculates scores for each token with regard to the correct class and the competing classes from the initial acoustic model. The calculation of this score can in some embodiments be accomplished through the use of Equation 4, above. This is illustrated at step 730. Once the scores have been calculated a value for the loss function is calculated based on Equation 9 above, including a value for the margin. This is illustrated at step 740. As discussed above the margin can be a fixed value, or can vary over each iteration of the training process. Once the value for the loss function has been calculated the parameters in the initial acoustic model are updated to create a revised acoustic model. This is illustrated at step 750. Steps 730 to 750 are repeated until either a predetermined number of iterations have passed or empirical convergence is achieved. Once the process is finished the final revised acoustic model is output at step 760.


Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.

Claims
  • 1. A method of training an acoustic model in a speech recognition system, comprising: accessing a training corpus;using the training corpus to calculate an initial acoustic model;calculating a plurality of scores for each token with regard to a correct class and a plurality of competing classes from the initial acoustic model;determining a value for a loss function based on the calculated scores, the loss function, and a margin;updating parameters in the current acoustic model to create a revised acoustic model based upon the loss value; andoutputting the revised acoustic model.
  • 2. The method of claim 1 further comprising: repeating the steps of calculating, determining and updating until an empirical convergence has been met for revised acoustic model.
  • 3. The method of claim 2 wherein the empirical convergence occurs after four iterations.
  • 4. The method of claim 1 wherein the margin is a fixed value.
  • 5. The method of claim 1 wherein the margin is a fixed value greater than zero.
  • 6. The method of claim 2 wherein the margin varies with each iteration.
  • 7. The method of claim 1 wherein the loss function is
  • 8. A system for training an acoustic model comprising: a training corpus;a training component; andwherein the training component is configured to generate the acoustic model based on the training corpus and a loss function that is calculated based on calculated scores of closeness and a margin.
  • 9. The system of claim 8 wherein the training component is configured to generate a series of revised acoustic models until an empirical convergence is achieved.
  • 10. The system of claim 8 further comprising: speaker independent data; andwherein the training component is configured to use the speaker independent data in conjunction with the training corpus to generate the acoustic model.
  • 11. The system of claim 10 wherein the training component generates a custom acoustic model for each speaker.
  • 12. The system of claim 8 wherein the margin is a fixed value
  • 13. The system of claim 8 wherein the margin is greater than zero
  • 14. The system of claim 9 wherein the margin varies with each iteration.
  • 15. The system of claim 8 wherein the loss function is defined as
  • 16. The system of claim 8 wherein the training component comprises two separate acoustic model training components.
  • 17. A speech recognition system configured to recognize a spoken utterance, comprising: a feature extraction module;a training module;a search engine;a lexicon;a language model;an acoustic model; andwherein the acoustic model is trained based off a training data set and a computed score of closeness processed through a loss function that includes a margin.
  • 18. The speech recognition system of claim 17 wherein a series of acoustic models are generated by multiple iterations of the training process, and where the iteration process continues until an empirical convergence is met.
  • 19. The speech recognition system of claim 18 wherein the margin of the loss function varies with each iteration.
  • 20. The speech recognition system of claim 18 wherein the margin is a fixed value.