gengamma.m
来自「Continuous Profile Models (CPM) Matlab T」· M 代码 · 共 34 行
M
34 行
function x = gengamma(alpha, beta)% return a Gamma random variable of mean alpha/beta and variance alpha/beta^2% http://www-sigproc.eng.cam.ac.uk/oldhomes/pl201/public_html/Matlab/gengamma.m% if alpha=1, then we get an exponential betaif (alpha==1) x = -log(1-rand(1,1))/beta; returnendflag=0; % test if alpha<1 or alpha>1if (alpha<1) flag=1; alpha=alpha+1;endgamma=alpha-1;eta=sqrt(2.0*alpha-1.0);c=.5-atan(gamma/eta)/pi;aux=-.5;while(aux<0) y=-.5; while(y<=0) u=rand(1,1); y = gamma + eta * tan(pi*(u-c)+c-.5); end v=-log(rand(1,1)); aux=v+log(1.0+((y-gamma)/eta)^2)+gamma*log(y/gamma)-y+gamma;end;if (flag==1) x = y/beta*(rand(1))^(1.0/(alpha-1));else x = y/beta;end
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?