📄 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 vectorif 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 alphaif 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
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -