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 + -
显示快捷键?