www.pudn.com > HMM1.zip > dirichletpdf.m
function p = dirichletpdf(x, alpha)
>DIRICHLETPDF Dirichlet probability density function.
> p = dirichletpdf(x, alpha) returns the probability of vector
> x under the Dirichlet distribution with parameter vector
> alpha.
>
> Author: David Ross
>-------------------------------------------------
> Check the input
>-------------------------------------------------
error(nargchk(2,2,nargin));
> enusre alpha is a vector
if min(size(alpha)) ~= 1 | ndims(alpha) > 2 | length(alpha) == 1
error('alpha must be a vector');
end
> ensure x is is a vector of the same size as alpha
if any(size(x) ~= size(alpha))
error('x and alpha must be the same size');
end
>-------------------------------------------------
> Main
>-------------------------------------------------
if any(x < 0)
p = 0;
elseif sum(x) ~= 1
disp(['dirichletpdf warning: sum(x)~=1, but this may be ' ...
'due to numerical issues']);
p = 0;
else
z = gammaln(sum(alpha)) - sum(gammaln(alpha));
z = exp(z);
p = z * prod(x.^(alpha-1));
end