-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathmargincdf.m
61 lines (57 loc) · 2.2 KB
/
margincdf.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
% Copyright (C) 2016 Arno Onken
%
% This file is part of the Mixed Vine Toolbox.
%
% The Mixed Vine Toolbox is free software; you can redistribute it and/or
% modify it under the terms of the GNU General Public License as published
% by the Free Software Foundation; either version 3 of the License, or (at
% your option) any later version.
%
% This program is distributed in the hope that it will be useful, but
% WITHOUT ANY WARRANTY; without even the implied warranty of
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
% Public License for more details.
%
% You should have received a copy of the GNU General Public License along
% with this program; if not, see <http://www.gnu.org/licenses/>.
function c = margincdf(margin,x)
% MARGINCDF Univariate margin cumulative distribution function.
% C = MARGINCDF(MARGIN,X) returns the cumulative distribution function at
% the values in X of the univariate distribution specified in the struct
% MARGIN. The margin distribution is specified in the field MARGIN.dist
% which can be one of
% 'norm' for the Gaussian distribution,
% 'gam' for the gamma distribution,
% 'poiss' for the Poisson distribution,
% 'bino' for the binomial distribution, and
% 'nbin' for the negative binomial distribution.
% The parameter of the distribution is specified in the field
% MARGIN.theta. The size of this field depends on the distribution.
% X is a vector of length N, where N is the number of samples.
%
% C is an N-dimensional vector.
% Argument checks
if nargin < 2
error('margincdf: Usage c = margincdf(margin,x)');
end
if ~isstruct(margin)
error('margincdf: Argument "margin" must be a struct');
end
if ~isvector(x)
error('margincdf: Argument "x" must be a vector');
end
switch lower(margin.dist)
case 'norm'
c = normcdf(x,margin.theta(1),margin.theta(2));
case 'gam'
c = gamcdf(x,margin.theta(1),margin.theta(2));
case 'poiss'
c = poisscdf(x,margin.theta);
case 'bino'
c = binocdf(x,margin.theta(1),margin.theta(2));
case 'nbin'
c = nbincdf(x,margin.theta(1),margin.theta(2));
otherwise
error(['margincdf: Unknown margin distribution "' margin.dist '"']);
end
end