A Gentle Tutorial of the EM Algorithm and its Application to Parameter Estimation for Gaussian Mixture and Hidden Markov Models Abstract

Similar documents
Solution to Homework 2

INDIRECT INFERENCE (prepared for: The New Palgrave Dictionary of Economics, Second Edition)

Overview of Violations of the Basic Assumptions in the Classical Normal Linear Regression Model

CHAPTER 2 Estimating Probabilities

Statistical Machine Translation: IBM Models 1 and 2

COMP 250 Fall 2012 lecture 2 binary representations Sept. 11, 2012

MATH10212 Linear Algebra. Systems of Linear Equations. Definition. An n-dimensional vector is a row or a column of n numbers (or letters): a 1.

Linear Programming. March 14, 2014

Introduction to Matrix Algebra

MATRIX ALGEBRA AND SYSTEMS OF EQUATIONS

CS229 Lecture notes. Andrew Ng

2x + y = 3. Since the second equation is precisely the same as the first equation, it is enough to find x and y satisfying the system

Introduction to Algorithmic Trading Strategies Lecture 2

MATH 4330/5330, Fourier Analysis Section 11, The Discrete Fourier Transform

SOLVING LINEAR SYSTEMS

Conditional Random Fields: An Introduction

3. Mathematical Induction

Hardware Implementation of Probabilistic State Machine for Word Recognition

5.5. Solving linear systems by the elimination method

LS.6 Solution Matrices

Hidden Markov Models

1.7 Graphs of Functions

Linear Algebra Notes for Marsden and Tromba Vector Calculus

Linear Programming. April 12, 2005

Notes on Determinant

7 Gaussian Elimination and LU Factorization

Basics of Statistical Machine Learning

The Basics of Graphical Models

This unit will lay the groundwork for later units where the students will extend this knowledge to quadratic and exponential functions.

CS 2750 Machine Learning. Lecture 1. Machine Learning. CS 2750 Machine Learning.

Data Mining: Algorithms and Applications Matrix Math Review

Sensitivity Analysis 3.1 AN EXAMPLE FOR ANALYSIS

Optimal linear-quadratic control

Dirichlet Processes A gentle tutorial

Notes on Orthogonal and Symmetric Matrices MENU, Winter 2013

Continued Fractions and the Euclidean Algorithm

1 Solving LPs: The Simplex Algorithm of George Dantzig

SYSTEMS OF EQUATIONS AND MATRICES WITH THE TI-89. by Joseph Collison

Comp Fundamentals of Artificial Intelligence Lecture notes, Speech recognition

A Primer on Mathematical Statistics and Univariate Distributions; The Normal Distribution; The GLM with the Normal Distribution

Advanced Signal Processing and Digital Noise Reduction

The Method of Partial Fractions Math 121 Calculus II Spring 2015

Tagging with Hidden Markov Models

MUSICAL INSTRUMENT FAMILY CLASSIFICATION

Recursive Algorithms. Recursion. Motivating Example Factorial Recall the factorial function. { 1 if n = 1 n! = n (n 1)! if n > 1

1 Short Introduction to Time Series

December 4, 2013 MATH 171 BASIC LINEAR ALGEBRA B. KITCHENS

Lecture 3: Linear methods for classification

K80TTQ1EP-??,VO.L,XU0H5BY,_71ZVPKOE678_X,N2Y-8HI4VS,,6Z28DDW5N7ADY013

Analysis of a Production/Inventory System with Multiple Retailers

A hidden Markov model for criminal behaviour classification

Exponential Random Graph Models for Social Network Analysis. Danny Wyatt 590AI March 6, 2009

MATRIX ALGEBRA AND SYSTEMS OF EQUATIONS. + + x 2. x n. a 11 a 12 a 1n b 1 a 21 a 22 a 2n b 2 a 31 a 32 a 3n b 3. a m1 a m2 a mn b m

Basic numerical skills: EQUATIONS AND HOW TO SOLVE THEM. x + 5 = = (2-2) = = 5. x = 7-5. x + 0 = 20.

Lecture 13 - Basic Number Theory.

Lecture notes: single-agent dynamics 1

Markov Chain Monte Carlo Simulation Made Simple

Course: Model, Learning, and Inference: Lecture 5

Computational Geometry Lab: FEM BASIS FUNCTIONS FOR A TETRAHEDRON

MATHEMATICS FOR ENGINEERS BASIC MATRIX THEORY TUTORIAL 2

An Introduction to the Kalman Filter

1 The Brownian bridge construction

The equivalence of logistic regression and maximum entropy models

The CUSUM algorithm a small review. Pierre Granjon

A Detailed Price Discrimination Example

Principal components analysis

Preliminary Mathematics

The Characteristic Polynomial

8 Divisibility and prime numbers

Statistical Machine Learning from Data

Language Modeling. Chapter Introduction

Hidden Markov Models in Bioinformatics. By Máthé Zoltán Kőrösi Zoltán 2006

To give it a definition, an implicit function of x and y is simply any relationship that takes the form:

Probability and Statistics Prof. Dr. Somesh Kumar Department of Mathematics Indian Institute of Technology, Kharagpur

1.2 Solving a System of Linear Equations

a 11 x 1 + a 12 x a 1n x n = b 1 a 21 x 1 + a 22 x a 2n x n = b 2.

Matrices 2. Solving Square Systems of Linear Equations; Inverse Matrices

Machine Learning.

Multivariate Normal Distribution

=

PARTIAL LEAST SQUARES IS TO LISREL AS PRINCIPAL COMPONENTS ANALYSIS IS TO COMMON FACTOR ANALYSIS. Wynne W. Chin University of Calgary, CANADA

Introduction to General and Generalized Linear Models

Chapter 11 Number Theory

Lecture L3 - Vectors, Matrices and Coordinate Transformations

Introduction to Matrices for Engineers

Regression III: Advanced Methods

Multivariate Analysis (Slides 13)

99.37, 99.38, 99.38, 99.39, 99.39, 99.39, 99.39, 99.40, 99.41, cm

Partial Fractions. Combining fractions over a common denominator is a familiar operation from algebra:

Lecture 3: Finding integer solutions to systems of linear equations

Covariance and Correlation

Vieta s Formulas and the Identity Theorem

1 Teaching notes on GMM 1.

Bayesian probability theory

Regions in a circle. 7 points 57 regions

Section 4.1 Rules of Exponents

Matrix Algebra. Some Basic Matrix Laws. Before reading the text or the following notes glance at the following list of basic matrix algebra laws.

Solutions of Linear Equations in One Variable

5.3 The Cross Product in R 3

Solving Systems of Linear Equations

Transcription:

!!" # $&%('),.-0/12-35417698:4<;>= 12-@?>ABAC8ED.-03GFH-I -J&KL.M>I = NPO>3Q/>= M,%('>)>A('(RS$B$&%BTU8EVXWY$&A>Z[?('\RX%Y$]W>\U8E^7_a`bVXWY$&A>Z[?('\RX)>?BT(' A Gentle Tutorial of the EM Algorithm and its Application to Parameter Estimation for Gaussian Mixture and Hidden Markov Models Jeff A. Bilmes (bilmes@cs.berkeley.edu) International Computer Science Institute Berkeley CA, 94704 and Computer Science Division Department of Electrical Engineering and Computer Science U.C. Berkeley TR-97-021 April 1998 Abstract We describe the maximum-likelihood parameter estimation problem and how the Expectation- Maximization (EM) algorithm can be used for its solution. We first describe the abstract form of the EM algorithm as it is often given in the literature. We then develop the EM parameter estimation procedure for two applications: 1) finding the parameters of a mixture of Gaussian densities, and 2) finding the parameters of a hidden Markov model (HMM) (i.e., the Baum-Welch algorithm) for both discrete and Gaussian mixture observation models. We derive the update equations in fairly explicit detail but we do not prove any convergence properties. We try to emphasize intuition rather than mathematical rigor.

ii

1 Maximum-likelihood Recall the definition of the maximum-likelihood estimation problem. We have a density function that is governed by the set of parameters (e.g., might be a set of Gaussians and could be the means and covariances). We also have a data set of size, supposedly drawn from this distribution, i.e.,. That is, we assume that these data vectors are independent and identically distributed (i.i.d.) with distribution. Therefore, the resulting density for the samples is "! #$ % This function! #$ is called the likelihood of the parameters given the data, or just the likelihood function. The likelihood is thought of as a function of the parameters where the data is fixed. In the maximum likelihood problem, our goal is to find the that maximizes!. That is, we wish to find & where & argmax! '( % Often we maximize )-,! #$. instead because it is analytically easier. Depending on the form of this problem can be easy or hard. For example, if is simply a single Gaussian distribution where /012, then we can set the derivative of )3,! '(. to zero, and solve directly for / and 0 1 (this, in fact, results in the standard formulas for the mean and variance of a data set). For many problems, however, it is not possible to find such analytical expressions, and we must resort to more elaborate techniques. 2 Basic EM The EM algorithm is one such elaborate technique. The EM algorithm [ALR77, RW84, GJ95, JJ94, Bis95, Wu83] is a general method of finding the maximum-likelihood estimate of the parameters of an underlying distribution from a given data set when the data is incomplete or has missing values. There are two main applications of the EM algorithm. The first occurs when the data indeed has missing values, due to problems with or limitations of the observation process. The second occurs when optimizing the likelihood function is analytically intractable but when the likelihood function can be simplified by assuming the existence of and values for additional but missing (or hidden) parameters. The later application is more common in the computational pattern recognition community. As before, we assume that data is observed and is generated by some distribution. We call the incomplete data. We assume that a complete data set exists 45.6 and also assume (or specify) a joint density function: 78 9:; :< 9=>. Where does this joint density come from? Often it arises from the marginal density function and the assumption of hidden variables and parameter value guesses (e.g., our two examples, Mixture-densities and Baum-Welch). In other cases (e.g., missing data values in samples of a distribution), we must assume a joint relationship between the missing and observed values. 1

7 With this new density function, we can define a new likelihood function,! #$ 4 "! '(.6.6$, called the complete-data likelihood. Note that this function is in fact a random variable since the missing information 6 is unknown, random, and presumably governed by an underlying distribution. That is, we can think of! '(.6 6 for some function where and are constant and 6 is a random variable. The original likelihood! '( is referred to as the incomplete-data likelihood function. The EM algorithm first finds the expected value of the complete-data log-likelihood )-,.6 with respect to the unknown data 6 given the observed data and the current parameter estimates. That is, we define: # = )3,.6 2 = (1) Where are the current parameters estimates that we used to evaluate the expectation and are the new parameters that we optimize to increase. This expression probably requires some explanation. The key thing to understand is that and are constants, is a normal variable that we wish to adjust, and 6 is a random variable governed by the distribution :< =. The right side of Equation 1 can therefore be re-written as: ) -,.6$ = ) -, :; :; =! : (2) Note that :; = is the marginal distribution of the unobserved data and is dependent on both the observed data and on the current parameters, and " is the space of values : can take on. In the best of cases, this marginal distribution is a simple analytical expression of the assumed parameters and perhaps the data. In the worst of cases, this density might be very hard to obtain. Sometimes, in fact, the density actually used is : # :< = but this doesn t effect subsequent steps since the extra factor, is not dependent on. As an analogy, suppose we have a function $ of two variables. Consider % '& where % is a constant and & is a random variable governed by some distribution )(. Then %,(.- % '& 0/ 21 % : 3( : is now a deterministic function that could be maximized if desired. The evaluation of this expectation is called the E-step of the algorithm. Notice the meaning of the two arguments in the function # =54. The first argument corresponds to the parameters that ultimately will be optimized in an attempt to maximize the likelihood. The second argument 64 corresponds to the parameters that we use to evaluate the expectation. The second step (the M-step) of the EM algorithm is to maximize the expectation we computed in the first step. That is, we find: argmax # = = These two steps are repeated as necessary. Each iteration is guaranteed to increase the loglikelihood and the algorithm is guaranteed to converge to a local maximum of the likelihood function. There are many rate-of-convergence papers (e.g., [ALR77, RW84, Wu83, JX96, XJ96]) but we will not discuss them here. Recall that 8:9 ;=<?>A@'B CEDGFHID 1KJ ;=<?L@MONP QA<?L=B FR@S$L. In the following discussion, we drop the subscripts from different density functions since argument usage should should disambiguate different ones. 2

" & " # =, we find some A modified form of the M-step is to, instead of maximizing such that. This form of the algorithm is called Generalized EM (GEM) and is also guaranteed to converge. As presented above, it s not clear how exactly to code up the algorithm. This is the way, however, that the algorithm is presented in its most general form. The details of the steps required to compute the given quantities are very dependent on the particular application so they are not discussed when the algorithm is presented in this abstract form. ' = # = 3 Finding Maximum Likelihood Mixture Densities Parameters via EM The mixture-density parameter estimation problem is probably one of the most widely used applications of the EM algorithm in the computational pattern recognition community. In this case, we assume the following probabilistic model: % % % such that where the parameters are and each is a density function parameterized by %. In other words, we assume we have component densities mixed together with mixing coefficients. The incomplete-data log-likelihood expression for this density from the data is given by: )3,! #$. ) -, )3, % which is difficult to optimize because it contains the log of the sum. If we consider as incomplete, however, and posit the existence of unobserved data items 6 whose values inform us which component density generated each data item, the likelihood expression is significantly simplified. That is, we assume that for each, and if the sample was generated by the mixture component. If we know the values of 6, the likelihood becomes: )3,! #$.6. ") -, (.6 = ) -, ) -, %!!! which, given a particular form of the component densities, can be optimized using a variety of techniques. The problem, of course, is that we do not know the values of 6. If we assume 6 is a random vector, however, we can proceed. We first must derive an expression for the distribution #" of the unobserved data. Let s first guess at parameters for the mixture density, i.e., we guess that " " % " % " are the appropriate parameters for the likelihood! ' ".6. Given ", we can easily compute % " for each and $. In addition, the mixing parameters, can be though of as prior probabilities of each mixture component, that is component j. Therefore, using Bayes s rule, we can compute: = " %"!! "! 3 %"!! "& &! % "&.

and :; = " = " where : ' is an instance of the unobserved data independently drawn. When we now look at Equation 2, we see that in this case we have obtained the desired marginal density by assuming the existence of the hidden variables and making a guess at the initial parameters of their distribution. In this case, Equation 1 takes the form: # = " In this form, for, 7 since )3,! '( : :; = " )3, %!!! = = " % = = " 7 )3,!!! 7! )-, % = " = ) -, % = " (3) 7! = ' = " looks fairly daunting, yet it can be greatly simplified. We first note that 7 = = " # = "!! 7 =! = " 7 = = " = " = " = " = " (4). Using Equation 4, we can write Equation 3 as: )3, )3, %. = " = " ) -, %.> = " (5) To maximize this expression, we can maximize the term containing % independently since they are not related. and the term containing 4

- - - ; ; 7 or To find the expression for, we introduce the Lagrange multiplier with the constraint that, and solve the following equation: )-, > = " = " Summing both sizes over, we get that resulting in: = " For some distributions, it is possible to get an analytical expressions for % as functions of everything else. For example, if we assume -dimensional Gaussian component distributions with mean / and covariance matrix, i.e., % / then 9 / 7 1 "! 1 (6) To derive the update equations for this distribution, we need to recall some results from matrix algebra. The trace of a square matrix tr $# is equal to the sum of # s diagonal elements. The trace of a scalar equals that scalar. Also, tr %# '& tr %# tr %&, and tr %#(& tr %&)# which implies that " # tr %#(& where & ". Also note that #$ indicates the determinant of a matrix, and that #, #$. We ll need to take derivatives of a function of a matrix $# with respect to elements of that matrix. Therefore, we define -. / / to be the matrix with $ entry -0-. / / where 5 is the -2143 $ entry of #. The definition also applies taking derivatives with respect to a vector. First, /6 %# 7#8. Second, it can be shown that when # is a symmetric matrix: # 5 :9<; if $ if >= $ where ; is the $ cofactor of #. Given the above, we see that: )3, # # 9<; #$ if $ #$ if >= $<? @# by the definition of the inverse of a matrix. Finally, it can be shown that: tr $#A& # & 7& Diag $& % diag %# 5

Taking the log of Equation 6, ignoring any constant terms (since they disappear after taking derivatives), and substituting into the right side of Equation 5, we get: ) -, /. = " )-, = / Taking the derivative of Equation 7 with respect to / with which we can easily solve for / / = " / to obtain: To find, note that we can write Equation 7 as: )3, = )3, = where / 6 /. = " Taking the derivative with respect to diag 9 = " = " = ", we get: 6 / = " (7) and setting it equal to zero, we get: = " tr = " diag where and where 1 diag, implies that. This gives = " tr 2 = " 8 diag / / = " diag = ". Setting the derivative to zero, i.e., = " 8 or = " = " = " 6 / / = " 6

Summarizing, the estimates of the new parameters in terms of the old parameters are as follows: = " / = " = " = " / = " 6 / Note that the above equations perform both the expectation step and the maximization step simultaneously. The algorithm proceeds by using the newly derived parameters as the guess for the next iteration. 4 Learning the parameters of an HMM, EM, and the Baum-Welch algorithm A Hidden Markov Model is a probabilistic model of the joint probability of a collection of random variables 2. The variables are either continuous or discrete observations and the variables are hidden and discrete. Under an HMM, there are two conditional independence assumptions made about these random variables that make associated algorithms tractable. These independence assumptions are 1), the hidden variable, given the hidden variable, is independent of previous variables, or: ( and 2), the observation, given the hidden variable, is independent of other variables, or: ( 2 ( = ( In this section, we derive the EM algorithm for finding the maximum-likelihood estimate of the parameters of a hidden Markov model given a set of observed feature vectors. This algorithm is also known as the Baum-Welch algorithm. is a discrete random variable with possible values. We further assume that the underlying hidden Markov chain defined by ( is time-homogeneous (i.e., is independent of the time ). Therefore, we can represent as a time-independent stochastic transition matrix # 5 $. The special case of time ; is described by the initial state distribution,. We say that we are in state $ at time if $. A is the state at particular sequence of states is described by 2 where time. A particular observation sequence is described as. The probability of a particular observation vector at a particular time for state $ is described by: $. The complete collection of parameters for all observation distributions is represented by &. There are two forms of output distributions we will consider. The first is a discrete observation assumption where we assume that an observation is one of 7 possible observation symbols %

& 2. In this case, if, then $. The second form of probably distribution we consider is a mixture of multivariate Gaussians for each state where /. We describe the complete set of HMM parameters for a given model by: $# &. There are three basic problems associated with HMMs: 1. Find for some 2 for this since it is much more efficient than direct evaluation. &. We use the forward (or the backward) procedure 2. Given some and some, find the best state sequence The Viterbi algorithm solves this problem but we won t discuss it in this paper. that explains. 3. Find & argmax. The Baum-Welch (also called forward-backward or EM for HMMs) algorithm solves this problem, and we will develop it presently. In subsequent sections, we will consider only the first and third problems. The second is addressed in [RJ93]. 4.1 Efficient Calculation of Desired Quantities One of the advantages of HMMs is that relatively efficient algorithms can be derived for the three problems mentioned above. Before we derive the EM algorithm directly using the function, we review these efficient procedures. Recall the forward procedure. We define 2 which is the probability of seeing the partial sequence 2 and ending up in state at time. We can efficiently define recursively as: 1. % 2. 5 % 3. The backward procedure is similar: which is the probability of the ending partial sequence at time. We can efficiently define as: 1. 2. = 5 3. 8 given that we started at state

We now define which is the probability of being in state at time for the state sequence. Note that: ( = $ Also note that because of Markovian conditional independence > 2 so we can define things in terms of and as = We also define $ which is the probability of being in state at time and being in state $ at time be expanded as: or as: $ $ 5 = 5 5. This can also If we sum these quantities across time, we can get some useful values. I.e., the expression is the expected number of times in state and therefore is the expected number of transitions away from state for. Similarly, is the expected number of transitions from state to state $ for. These follow from the fact that and - 0/ - - $ 0/ - where is an indicator random variable that is when we are in state at time, and $ is a random variable that is when we move from state to state $ after time. 9!/ $ 0/

& Jumping the gun a bit, our goal in forming an EM algorithm to estimate new parameters for the HMM by using the old parameters and the data. Intuitively, we can do this simply using relative frequencies. I.e., we can define update rules as follows: The quantity (8) is the expected relative frequency spent in state at time 1. The quantity 5 (9) is the expected number of transitions from state to state $ relative to the expected total number of transitions away from state. And, for discrete distributions, the quantity (10) is the expected number of times the output observations have been equal to while in state relative to the expected total number of times in state. For Gaussian mixtures, we define the probability that the component of the mixture generated observation as is a random variable indicating the mixture component at time for state. where From the previous section on Gaussian Mixtures, we might guess that the update equations for this case are: observation sequences the being of length, the update equations be- When there are come: / / / / 10

and / 5 / These relatively intuitive equations are in fact the EM algorithm (or Balm-Welch) for HMM parameter estimation. We derive these using the more typical EM notation in the next section. 4.2 Estimation formula using the function. We consider 2 to be the observed data and the underlying state sequence 2 to be hidden or unobserved. The incomplete-data likelihood function is given by ( whereas the complete-data likelihood function is (. The function therefore is: 4 )-, ( 4 where 4 are our initial (or guessed, previous, etc.) 1 estimates of the parameters and where is the space of all state sequences of length. Given a particular state sequence, representing ( 4 is quite easy. I.e., The 4 function then becomes: )3, 4 ( ) -, 5 5 7 7 4 )3, ( 4 (11) Since the parameters we wish to optimize are now independently split into the three terms in the sum, we can optimize each term individually. The first term in Equation 11 becomes ) -, ( 4 )-, 4 since by selecting all, we are simply repeatedly selecting the values of, so the right hand side is just the marginal expression for time. Adding the Lagrange multiplier, using the constraint that, and setting the derivative equal to zero, we get: ) -, 4 9 For the remainder of the discussion any primed parameters are assumed to be the initial, guessed, or previous parameters whereas the unprimed parameters are being optimized. Note here that we assume the initial distribution starts at D instead of D for notational convenience. The basic results are the same however. 11

& Taking the derivative, summing over to get, and solving for, we get: ( 4 ( 4 The second term in Equation 11 becomes: )-, 5 7 4 = ) -, 5 $ 4 because for this term, we are, for each time looking over all transitions from to $ and weighting that by the corresponding probability the right hand side is just sum of the joint-marginal for time and. In a similar way, we can use a Lagrange multiplier with the constraint = 5 to get: 5 The third term in Equation 11 becomes: ) -, $ 4 4 ( 4 ) -, because for this term, we are, for each time, looking at the emissions for all states and weighting each possible emission by the corresponding probability the right hand side is just the sum of the marginal for time. For discrete distributions, we can, again, use use a Lagrange multiplier but this time with the constraint = $. Only the observations that are equal to contribute to the probability value, so we get: ( 4 4 4 4 7 1 ) 4 ) 4 For Gaussian Mixtures, the form of the function is slightly different, i.e., the hidden variables must include not only the hidden state sequence, but also a variable indicating the mixture component for each state at each time. Therefore, we can write as: )3, ( ( where is the vector that indicates the mixture component for each state at each time. If we expand this as in Equation 11, the first and second terms are unchanged because the parameters are independent of which is thus marginalized away by the sum. The third term in Equation 11 becomes: -, ( -, > This equation is almost identical to Equation 5, except for an addition sum component over the hidden state variables. We can optimize this in an exactly analogous way as we did in Section 3, and we get: ( ( 12 4 4 4

and / ( ( / 4 4 / ( ( 4 4 As can be seen, these are the same set of update equations as given in the previous section. The update equations for HMMs with multiple observation sequences can similarly be derived and are addressed in [RJ93]. References [ALR77] A.P.Dempster, N.M. Laird, and D.B. Rubin. Maximum-likelihood from incomplete data via the em algorithm. J. Royal Statist. Soc. Ser. B., 39, 1977. [Bis95] C. Bishop. Neural Networks for Pattern Recognition. Clarendon Press, Oxford, 1995. [GJ95] [JJ94] [JX96] [RJ93] [RW84] [Wu83] Z. Ghahramami and M. Jordan. Learning from incomplete data. Technical Report AI Lab Memo No. 1509, CBCL Paper No. 108, MIT AI Lab, August 1995. M. Jordan and R. Jacobs. Hierarchical mixtures of experts and the em algorithm. Neural Computation, 6:181 214, 1994. M. Jordon and L. Xu. Convergence results for the em approach to mixtures of experts architectures. Neural Networks, 8:1409 1431, 1996. L. Rabiner and B.-H. Juang. Fundamentals of Speech Recognition. Prentice Hall Signal Processing Series, 1993. R. Redner and H. Walker. Mixture densities, maximum likelihood and the em algorithm. SIAM Review, 26(2), 1984. C.F.J. Wu. On the convergence properties of the em algorithm. The Annals of Statistics, 11(1):95 103, 1983. [XJ96] L. Xu and M.I. Jordan. On convergence properties of the em algorithm for gaussian mixtures. Neural Computation, 8:129 151, 1996. 13