Dirichlet process

Dirichlet process

In probability theory, a Dirichlet process is a stochastic process that can be thought of as a probability distribution whose domain is itself a random distribution. That is, given a Dirichlet process \mathrm{DP}\left(H, \alpha\right), where H (the base distribution) is an arbitrary distribution and α (the concentration parameter) is a positive real number, a draw from \mathbf{DP} will return a random distribution (the output distribution) containing values drawn from H. That is, the support of the output distribution is the same as the base distribution. The output distribution will be discrete, meaning that individual values drawn from the distribution will sometimes repeat themselves even if the base distribution is continuous (i.e., if two different draws from the base distribution will be distinct with probability one). The extent to which values will repeat is determined by α, with higher values causing less repetition. If the base distribution is continuous, so that separate draws from it always return distinct values, then the infinite set of probabilities corresponding to the frequency of each possible value that the output distribution can return are distributed according to a stick-breaking process.

Note that the Dirichlet process is a stochastic process, meaning that technically speaking it is an infinite sequence of random variables, rather than a single random distribution. The relation between the two is as follows. Consider the Dirichlet process as defined above, as a distribution over random distributions, and call this process \operatorname{DP}_1(). We can call this the distribution-centered view of the Dirichlet process. First, draw a random output distribution from this process, and then consider an infinite sequence of random variables representing values drawn from this distribution. Note that, conditioned on the output distribution, the variables are independent identically distributed. Now, consider instead the distribution of the random variables that results from marginalizing out (integrating over) the random output distribution. (This makes all the variables dependent on each other. However, they are still exchangeable, meaning that the marginal distribution of one variable is the same as that of all other variables. That is, they are "identically distributed" but not "independent".) The resulting infinite sequence of random variables with the given marginal distributions is another view onto the Dirichlet process, denoted here \operatorname{DP}_2(). We can call this the process-centered view of the Dirichlet process. The conditional distribution of one variable given all the others, or given all previous variables, is defined by the Chinese restaurant process (see below).

Another way to think of a Dirichlet process is as an infinite-dimensional generalization of the Dirichlet distribution. The Dirichlet distribution returns a finite-dimensional set of probabilities (for some size K, specified by the parameters of the distribution), all of which sum to 1. This can be thought of as a finite-dimensional discrete distribution; i.e. a Dirichlet distribution can be thought of as a distribution over K-dimensional discrete distributions. Imagine generalizing a symmetric Dirichlet distribution, defined by a dimension K and concentration parameter α / K, to an infinite set of probabilities; the resulting distribution over infinite-dimensional discrete distributions is called the stick-breaking process (see below). Imagine then using this set of probabilities to create an infinite-dimensional mixture model, with each separate probability from the set associated with a mixture component, and the value of each component drawn separately from a base distribution H; then draw an infinite number of samples from this mixture model. The infinite set of random variables corresponding to the marginal distribution of these samples is a Dirichlet process with parameters H and α.

The Dirichlet process was formally introduced by Thomas Ferguson in 1973.[1]

Contents

Introduction

Consider a simple mixture model:


\begin{array}{lcl}
\theta_{1,\dots,K} &\sim& H() \\
\boldsymbol\beta &\sim& \operatorname{Dirichlet}(K, \alpha/K) \\
z_{1,\dots,N} &\sim& \operatorname{Categorical}(\boldsymbol\beta) \\
x_{i=1,\dots,N} &\sim& F(\theta_{z_i})
\end{array}

This is a basic generative model where the observations x_1,\dots,x_N are distributed according to a mixture of K components, where each component is distributed according to a single parametric family F(θ) but where different components have different values of θ, which is drawn in turn from a distribution H. Typically, H will be the conjugate prior distribution of F. In addition, the prior probability of each component is specified by \boldsymbol\beta, which is a size-K vector of probabilities, all of which add up to 1.

For example, if the observations are apartment prices and the K components represent different neighborhoods, then F might be a Gaussian distribution with unknown mean and unknown variance, with the mean and variance specifying the distribution of prices in that neighborhood. Then the parameter θ will be a vector of two values, a mean drawn from a Gaussian distribution and a variance drawn from an inverse gamma distribution, which are the conjugate priors of the mean and variance, respectively, of a Gaussian distribution.

Meanwhile, if the observations are words and the K components represent different topics, then F might be a categorical distribution over a vocabulary of size V, with unknown frequencies of each word in the vocabulary, specifying the distribution of words in each particular topic. Then the parameter θ will be a vector of V values, each representing a probability and all summing to one, drawn from a Dirichlet distribution, which is the conjugate prior of the categorical distribution.

Now imagine we consider the limit as K\to\infty. Conceptually this means that we have no idea how many components are present. The result will be as follows:


\begin{array}{lcl}
\theta_{1,\dots,\infty} &\sim& H() \\
\boldsymbol\beta &\sim& \operatorname{Stick}(1,\alpha) \\
z_{1,\dots,N} &\sim& \operatorname{Categorical}(\boldsymbol\beta) \\
x_{i=1,\dots,N} &\sim& F(\theta_{z_i})
\end{array}

In this model, conceptually speaking there are an infinite number of components, each with a separate parameter value, and a correspondingly infinite number of prior probabilities for each component, drawn from a stick-breaking process (see section below). Note that a practical application of such a model would not actually store an infinite number of components. Instead, it would generate the component prior probabilities one at a time from the stick-breaking process, which by construction tends to return the largest probability values first. As each component probability is drawn, a corresponding parameter value is also drawn. At any one time, some of the prior probability mass will be assigned to components and some unassigned. To generate a new observation, a random number between 0 and 1 is drawn uniformly, and if it lands in the unassigned mass, new components are drawn as necessary (each one reducing the amount of unassigned mass) until enough mass has been allocated to place this number in an existing component. Each time a new component probability is generated by the stick-breaking process, a corresponding parameter value is drawn from H.

Sometimes, the stick-breaking process is denoted as \operatorname{GEM}(), after the authors of this process, instead of \operatorname{Stick}().

Another view of this model comes from looking back at the finite-dimensional mixture model with mixing probabilities \boldsymbol\beta drawn from a Dirichlet distribution and considering the distribution of a particular component assignment zi conditioned on all previous components, with the mixing probabilities integrated out. Note that, conditioned on a particular value of \boldsymbol\beta, each zi is independent of the others, but marginalizing over \boldsymbol\beta introduces dependencies among the component assignments. It can be shown that

p(z_i = k|\mathbf{z}_{1,\dots,i-1},\alpha,K) = \frac{n_k + \alpha/K}{i - 1 + \alpha}

where k = 1 \dots K is a particular value of zi and nk is the number of times a topic assignment in the set \{z_1,\dots,z_{i-1}\} has the value k, i.e. probability of assigning an observation to a particular component is roughly proportional to the number of previous observations already assigned to this component.

Now consider the limit as K\to\infty. For a particular previously observed component k,

p(z_i = k|\mathbf{z}_{1,\dots,i-1},\alpha) = \lim_{K\to\infty} \frac{n_k + \alpha/K}{i - 1 + \alpha} = \frac{n_k}{i - 1 + \alpha}

That is, the probability of seeing an previously observed component is directly proportional to the number of times the component has already been seen. This is often expressed as the rich get richer.

For an unseen component k, nk = 0, and as K\to\infty the probability of seeing this component goes to 0. However, the number of unseen components approaches infinity. Consider instead the set of all unseen components\mathbf{Q}. Note that, if there are L components seen so far, |\mathbf{Q}| = K - L. Then, consider the probability of seeing any of these components:


\begin{align}
p(z_i \in \mathbf{Q}|\mathbf{z}_{1,\dots,i-1},\alpha) & = \lim_{K\to\infty} \sum_{u\in\mathbf{Q}} \frac{\alpha/K}{i - 1 + \alpha} \\
& = \frac{\alpha}{i-1+\alpha} \lim_{K\to\infty} \frac{|Q|}{K} = \frac{\alpha}{i-1+\alpha} \lim_{K\to\infty} \frac{K-L}{K} = \frac{\alpha}{i-1+\alpha}
\end{align}

In other words:

  1. The probability of seeing an already-seen component is proportional to the number of times that component has been seen.
  2. The probability of seeing any unseen component is proportional to the concentration parameter α.

This process is termed a Chinese restaurant process (CRP). In terms of the CRP, the infinite-dimensional model can equivalently be written:


\begin{array}{lcl}
\theta_{1,\dots,\infty} &\sim& H() \\
z_{1,\dots,N} &\sim& \operatorname{CRP}(\alpha) \\
x_{i=1,\dots,N} &\sim& F(\theta_{z_i})
\end{array}

Note that we have marginalized out the mixing probabilities \boldsymbol\beta, and thereby produced a more compact representation of the model.

Now imagine further that we also marginalize out the component assignments z_{1,\dots,N}, and instead we look directly at the distribution of \phi_i = \theta_{z_i}. Then, we can write the model directly in terms of the Dirichlet process:


\begin{array}{lcl}
G &\sim& \operatorname{DP}_1(H,\alpha) \\
\phi_{1,\dots,N} &\sim& G \\
x_{i=1,\dots,N} &\sim& F(\phi_i)
\end{array}

\operatorname{DP}_1 represents one view (the distribution-centered view) of the Dirichlet process as producing a random, infinite-dimensional discrete distribution G with values drawn from H.

An alternative view of the Dirichlet process (the process-centered view), adhering more closely to its definition as a stochastic process, sees it as directly producing an infinite stream of \boldsymbol\phi values. Notating this view as \operatorname{DP}_2, we can write the model as


\begin{array}{lcl}
\phi_{1,\dots} &\sim& \operatorname{DP}_2(H,\alpha) \\
x_{i=1,\dots,N} &\sim& F(\phi_i)
\end{array}

In this view, although the Dirichet process generates an infinite stream of parameter values, we only care about the first N values. Note that some of these values will be the same as previously seen values, in a "rich get richer" scheme, as determined by the Chinese restaurant process.

Formal definition

A Dirichlet process over a set S is a stochastic process whose sample path (i.e. an infinite-dimensional set of random variates drawn from the process) is a probability distribution on S. The finite dimensional distributions are from the Dirichlet distribution: If H is a finite measure on S, α is a positive real number and X is a sample path drawn from a Dirichlet process, written as

X \sim \mathrm{DP}\left(\alpha, H\right)

then for any partition of S, say \left\{B_i\right\}_{i=1}^{n}, we have that

\left(X\left(B_1\right),\dots,X\left(B_n\right)\right) \sim \mathrm{Dirichlet}\left(\alpha H\left(B_1\right),\dots, \alpha H\left(B_n\right)\right)

The Chinese restaurant process

As shown above, a simple distribution, the so-called Chinese restaurant process, results from considering the conditional distribution of one component assignment given all previous ones in a Dirichlet distribution mixture model with K components, and then taking the limit as K goes to infinity. It can be shown, using the above formal definition of the Dirichlet process and considering the process-centered view of the process, that the conditional distribution of the component assignment of one sample from the process given all previous samples follows a Chinese restaurant process.

Suppose that J samples, \left\{\theta_j\right\}_{j=1}^{J} have already been obtained. According to the Chinese Restaurant Process, the \left(J+1\right)^{\mathrm{th}} sample should be drawn from

\theta_{J+1} \sim \frac{1}{H\left(S\right)+J} \left( H + \sum_{j=1}^{J}\delta_{\theta_j}\right)

where δθ is an atomic distribution centered on θ. Interpreting this, two properties are clear:

  1. Even if S is a countable set, there is a finite probability that two samples will have exactly the same value. Samples from a Dirichlet process are therefore discrete.
  2. The Dirichlet process exhibits a self-reinforcing property; the more often a given value has been sampled in the past, the more likely it is to be sampled again.

The name "Chinese restaurant process" is derived from the following analogy: imagine an infinitely large restaurant containing an infinite number of tables, and able to serve an infinite number of dishes. The restaurant in question operates a somewhat unusual seating policy whereby new diners are seated either at a currently occupied table with probability proportional to the number of guests already seated there, or at an empty table with probability proportional to a constant. Guests who sit at an occupied table must order the same dish as those currently seated, whereas guests allocated a new table are served a dish at random according to the chef's taste. The distribution of dishes after J guests are served is a sample drawn as described above. The Chinese Restaurant Process is related to the Polya Urn sampling scheme for finite Dirichlet distributions.

The stick-breaking process

A third approach to the Dirichlet process is provided by the so-called stick-breaking process, which can be used to provide a constructive algorithm (the stick-breaking construction) for generating a Dirichlet process. Let \left\{\beta'_k\right\}_{k=1}^\infty be a set of random variables such that

\beta'_k \sim \mathrm{Beta}\left(1,\alpha\right)

where α is the normalisation constant for the measure H, so that H = αHnorm. Define \left\{\beta_k\right\}_{k=1}^\infty according to

\beta_k = \beta'_k\cdot\prod_{i=1}^{k-1}\left(1-\beta'_i\right)

and let \left\{\theta_k\right\}_{k=1}^{\infty} be a set of samples from Hnorm. The distribution given by the density f(\theta) = \sum_{k=1}^{\infty}\beta_k\cdot\delta_{\theta_k}(\theta) (where δ is the Dirac delta function), is then a sample from the corresponding Dirichlet process. This method provides an explicit construction of the non-parametric sample, and makes clear the fact that the samples are discrete.

The name 'stick-breaking' comes from the interpretation of βk as the length of the piece of a unit-length stick assigned to the kth value. After the first k − 1 values have their portions assigned, the length of the remainder of the stick, \prod_{i=1}^{k-1}\left(1-\beta'_i\right), is broken according to a sample β'k from a beta distribution. In this analogy, β'k indicates the portion of the remainder to be assigned to the k-th value. The smaller α is, the less of the stick will be left for subsequent values (on average).

The Polya urn scheme

Yet another way to visualize the Dirichlet process and Chinese restaurant process is as a modified Polya urn scheme. Imagine that we start with an urn filled with α black balls. Then we proceed as follows:

  1. Each time we need an observation, we draw a ball from the urn.
  2. If the ball is black, we generate a new (non-black) color uniformly, label a new ball this color, drop the new ball into the urn along with the ball we drew, and return the color we generated.
  3. Otherwise, label a new ball with the color of the ball we drew, drop the new ball into the urn along with the ball we drew, and return the color we observed.

The resulting distribution over colors is the same as the distribution over tables in the Chinese restaurant process. Furthermore, when we draw a black ball, if rather than generating a new color, we instead pick a random value from a base distribution H and use that value to label the new ball, the resulting distribution over labels will be the same as the distribution over values in a Dirichlet process.

Applications of the Dirichlet process

Dirichlet processes are frequently used in Bayesian nonparametric statistics. "Nonparametric" here does not mean a parameter-less model, rather a model in which representations grow as more data are observed. Bayesian nonparametric models have gained considerable popularity in the field of machine learning because of the above-mentioned flexibility, especially in unsupervised learning. In a Bayesian nonparametric model, the prior and posterior distributions are not parametric distributions, but stochastic processes[2]. The fact that the Dirichlet distribution is a probability distribution on the simplex of non-negative numbers that sum to one makes it a good candidate to model distributions of distributions or distributions of functions. Additionally, the non-parametric nature of this model makes it an ideal candidate for clustering problems where the distinct number of clusters is unknown beforehand.

As draws from a Dirichlet process are discrete, an important use is as a prior probability in infinite mixture models. In this case, S is the parametric set of component distributions. The generative process is therefore that a sample is drawn from a Dirichlet process, and for each data point in turn a value is drawn from this sample distribution and used as the component distribution for that data point. The fact that there is no limit to the number of distinct components which may be generated makes this kind of model appropriate for the case when the number of mixture components is not well-defined in advance. For example, the infinite mixture of Gaussians model [3].

The infinite nature of these models also lends them to natural language processing applications, where it is often desirable to treat the vocabulary as an infinite, discrete set.

Related distributions

  • The Pitman–Yor distribution (also known as the 'two-parameter Poisson-Dirichlet process') is a generalisation of the Dirichlet process.
  • The hierarchical Dirichlet process extends the ordinary Dirichlet process for modelling grouped data.

External links

References

  1. ^ Ferguson, Thomas (1973). "Bayesian analysis of some nonparametric problems". Annals of Statistics 1 (2): 209–230. doi:10.1214/aos/1176342360. MR350949. 
  2. ^ Nils Lid Hjort, Chris Holmes, Peter Müller and Stephen G. Walker (2010). Bayesian Nonparametrics. Cambridge University Press. ISBN 0521513464. 
  3. ^ Rasmussen, Carl (2000). "The Infinite Gaussian Mixture Model" (PDF). Advances in Neural Information Processing Systems (NIPS) 12: 554–560. http://www.gatsby.ucl.ac.uk/~edward/pub/inf.mix.nips.99.pdf. 

Wikimedia Foundation. 2010.

Игры ⚽ Поможем написать реферат

Look at other dictionaries:

  • Dirichlet distribution — Several images of the probability density of the Dirichlet distribution when K=3 for various parameter vectors α. Clockwise from top left: α=(6, 2, 2), (3, 7, 5), (6, 2, 6), (2, 3, 4). In probability and… …   Wikipedia

  • Johann Peter Gustav Lejeune Dirichlet — Gustav Lejeune Dirichlet Johann Peter Gustav Lejeune Dirichlet Born 13 Fe …   Wikipedia

  • Chinese restaurant process — Not to be confused with Chinese restaurant syndrome. In probability theory, the Chinese restaurant process is a discrete time stochastic process, whose value at any positive integer time n is a partition Bn of the set {1, 2, 3,  …   Wikipedia

  • Generalized Dirichlet distribution — In statistics, the generalized Dirichlet distribution (GD) is a generalization of the Dirichlet distribution with a more general covariance structure and twice the number of parameters. Random variables with a GD distribution are neutral [R. J.… …   Wikipedia

  • Latent Dirichlet allocation — In statistics, latent Dirichlet allocation (LDA) is a generative model that allows sets of observations to be explained by unobserved groups which explain why some parts of the data are similar. For example, if observations are words collected… …   Wikipedia

  • Hunt process — In probability theory, a Hunt process is a strong Markov process which is quasi left continuous with respect to the minimum completed admissible filtration { F t } {tgeq 0}.ee also* Markov process * Markov chain * Shift of finite typeReferences*… …   Wikipedia

  • List of mathematics articles (D) — NOTOC D D distribution D module D D Agostino s K squared test D Alembert Euler condition D Alembert operator D Alembert s formula D Alembert s paradox D Alembert s principle Dagger category Dagger compact category Dagger symmetric monoidal… …   Wikipedia

  • Object categorization from image search — In computer vision, the problem of object categorization from image search is the problem of training a classifier to recognize categories of objects, using only the images retrieved automatically with an Internet search engine. Ideally,… …   Wikipedia

  • Concentration parameter — In probability theory and statistics, a concentration parameter is a special kind of numerical parameter of a parametric family of probability distributions. Concentration parameters occur in conjunction with distributions whose domain is a… …   Wikipedia

  • Multivariate Pólya distribution — The multivariate Pólya distribution, named after George Pólya, also called the Dirichlet compound multinomial distribution, is a compound probability distribution, where a probability vector p is drawn from a Dirichlet distribution with parameter …   Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”