cumulative_gaussian_inv.m

来自「国外的一个PLStoolbox,主要用于处理图象,也可以用来回归,欢迎使用」· M 代码 · 共 60 行

M
60
字号
%CUMULATIVE_GAUSSIAN_INV: the inverse function of the Cumulative Gaussian
%  distribution function. Since Cumulative Gaussian distribution function
%  D=(1+erf((x-mu)/(sigma*sqrt(2))))/2   ( cited from Eric W. Weisstein.
%  "Normal Distribution." From MathWorld--A Wolfram Web Resource. 
%  http://mathworld.wolfram.com/NormalDistribution.html ), we now have:
%  (x-mu)/(sigma*sqrt(2)) = erfinv(2*D-1), thus we can get:
%  x = sigma*sqrt(2)*erfinv(2*D-1)+mu
%
%  Usage: x = cumulative_gaussian_inv(D, mu, sigma)
%
function x = cumulative_gaussian_inv(D, mu, sigma)

   if nargin < 3, 
      sigma = 1;
   end

   if nargin < 2;
      mu = 0;
   end

   if prod(size(mu)) == 1				% mu is a scalar
      mu = mu*ones(size(D));
   end

   if prod(size(sigma)) == 1				% sigma is a scalar
      sigma = sigma*ones(size(D));
   end

   x = zeros(size(D));					% init output x

   idx = find(sigma <= 0 | D < 0 | D > 1);		% bad data

   if any(idx)
      x1 = NaN;
      x(idx) = x1(ones(size(idx)));
   end

   idx = find(sigma > 0 & D > 0  &  D < 1);

   if any(idx)
      x(idx) = sigma(idx) .* sqrt(2) .* erfinv(2 * D(idx) - 1) + mu(idx);
   end

   idx = find(D == 0);

   if any(idx)
      x1 = Inf;
      x(idx) = -x1(ones(size(idx)));
   end

   idx = find(D == 1);

   if any(idx)
      x1 = Inf;
      x(idx) = x1(ones(size(idx)));
   end

   return;						% cumulative_gaussian_inv

⌨️ 快捷键说明

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