multirnd.m

来自「详细介绍了隐马尔科夫链的原理和matlab代码实现」· M 代码 · 共 48 行

M
48
字号
function r = multirnd(theta,k)%MULTIRND - Random vector from multinomial distribution.%   r = multirnd(theta,k) returns a vector randomly selected%   from the multinomial distribution with parameter vector%   theta, and count k (i.e. sum(r) = k).%%   Note: if k is unspecified, then it is assumed k=1.%%   Author: David Ross%%--------------------------------------------------------% Check the arguments.%--------------------------------------------------------error(nargchk(1,2,nargin));% make sure theta is a vectorif ndims(theta) > 2 | all(size(theta) > 1)    error('theta must be a vector');end% if theta is a row vector, convert it to a column vectorif size(theta,1) == 1    theta = theta';end% make sure k is a scalar?% if the number of samples has not been provided, set% it to oneif nargin == 1    k = 1;end%--------------------------------------------------------% Main...%--------------------------------------------------------n = length(theta);theta_cdf = cumsum(theta);r = zeros(n,1);random_vals = rand(k,1);for j = 1:k    index = min(find(random_vals(j) <= theta_cdf));    r(index) = r(index) + 1;end

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?