Code covered by the BSD License

Generation of Random Variates

James Huntley (view profile)

generates random variates from over 870 univariate distributions

logn_cdf(x,mu,sigma)
```function p = logn_cdf(x,mu,sigma)
%LOGN_CDF Lognormal cumulative distribution function (cdf).
%   P = LOGN_CDF(X,MU,SIGMA) computes the lognormal cdf with mean MU and
%   standard deviation SIGMA at the values in X.
%
%   The size of P is the common size of X, MU and SIGMA. A scalar input
%   functions as a constant matrix of the same size as the other inputs.
%
%   Default values for MU and SIGMA are 0 and 1 respectively.

%   Reference:
%      [1]  Evans, Merran, Hastings, Nicholas and Peacock, Brian,
%      "Statistical Distributions, Second Edition", Wiley
%      1993 p. 102-105.

%   Copyright 1993-2000 The MathWorks, Inc.
%   \$Revision: 2.10 \$  \$Date: 2000/05/26 18:53:00 \$

if nargin < 3,
sigma = 1;
end

if nargin < 2;
mu = 0;
end

[errorcode x mu sigma] = distchck(3,x,mu,sigma);

if errorcode > 0
error('Requires non-scalar arguments to match in size.');
end

%   Initialize P to zero.
p = zeros(size(x));

% Return NaN if SIGMA and x are not positive.
p(sigma <= 0 | x < 0) = NaN;

% Express lognormal CDF in terms of the error function.
k = find(sigma > 0 & x > 0);
p(k) = 0.5 * (1 + erf((log(x(k)) - mu(k)) ./ (sigma(k) * sqrt(2))));

% Make sure that round-off errors never make P greater than 1.
p(p > 1) = 1;
```