forked from EddyRivasLab/easel
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathesl_dirichlet.tex
63 lines (44 loc) · 2.63 KB
/
esl_dirichlet.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
The dirichlet module contains routines for using Beta, Gamma, and
Dirichlet densities. In particular, it implements mixture Dirichlet
priors, which are useful in a variety of parameter estimation tasks.
The Dirichlet PDF is:
\begin{equation}
P(\vec{p}) = \frac{\Gamma{\sum_i \alpha_i}}{\prod_i \Gamma(\alpha_i)} \prod_i p_i^{\alpha_i-1}
\end{equation}
\subsection{The dirichlet API}
The module implements one object, \ccode{ESL\_MIXDCHLET}, which holds
a mixture Dirichlet prior.
The API consists of the following functions:
\vspace{1em}
\begin{tabular}{ll}\hline
\multicolumn{2}{c}{\textbf{mixture Dirichlet priors}}\\
\ccode{esl\_mixdchlet\_Create()} & Allocates a new mixture Dirichlet.\\
\ccode{esl\_mixdchlet\_Destroy()} & Free's a mixture Dirichlet.\\
\ccode{esl\_mixdchlet\_MPParameters()} & Mean posterior probability parameter estimation.\\
\multicolumn{2}{c}{\textbf{Dirichlet, Gamma density routines}}\\
\ccode{esl\_dirichlet\_LogProbData()} & $\log P( \mbox{count vector} \mid \mbox{mixture Dirichlet}$.\\
\ccode{esl\_dirichlet\_LogProbProbs()} & $\log P( \mbox{prob vector} \mid \mbox{mixture Dirichlet}$.\\
\ccode{esl\_dirichlet\_LogGamma()} & $\log \Gamma(x)$.\\
\multicolumn{2}{c}{\textbf{Sampling code (requires augmentation w/ random)}}\\
\ccode{esl\_dirichlet\_\{D,F\}Sample()} & Sample a probability vector from a Dirichlet.\\
\ccode{esl\_dirichlet\_\{D,F\}SampleUniform()} & Sample a probability vector uniformly.\\
\ccode{esl\_dirichlet\_SampleBeta()} & Sample from Beta$(\theta_1, \theta_2$).\\
\multicolumn{2}{c}{\textbf{Input from file (requires augmentation w/ fileparser)}}\\
\ccode{esl\_mixdchlet\_Read()} & Input of a mixture Dirichlet from a file.\\ \hline
\end{tabular}
\subsection{Example of using the dirichlet API}
An example that reads a mixture Dirichlet prior from a file, samples a
probability vector from it, samples a count vector from the
probability vector, then infers which mixture component generated the
data and uses mean posterior estimation to reestimate the probability
vector from the counts:
\input{cexcerpts/dirichlet_example}
\subsection{Accessing information in the ESL\_MIXDCHLET object}
You may need to access the information in the \ccode{ESL\_MIXDCHLET}
object. The data fields inside this structure are:
\input{cexcerpts/dirichlet_mixdchlet}
\subsection{Augmentations}
The \ccode{esl\_dirichlet\_Sample*()} functions are only available
when the module is augmented with the \ccode{random} module.
The \ccode{esl\_dirichlet\_Read()} function is only available when the
module is augmented with the \ccode{fileparser} module.