-
Notifications
You must be signed in to change notification settings - Fork 5
/
spm_P_Bonf.m
43 lines (39 loc) · 1.09 KB
/
spm_P_Bonf.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
function P = spm_P_Bonf(Z,df,STAT,S,n)
% Returns the corrected P value using Bonferroni
% FORMAT P = spm_P_Bonf(Z,df,STAT,S,n)
%
% Z - height {minium over n values}
% df - [df{interest} df{error}]
% STAT - Statistical field
% 'Z' - Gaussian field
% 'T' - T - field
% 'X' - Chi squared field
% 'F' - F - field
% n - number of conjoint SPMs
% S - Voxel count
%
% P - corrected P value - P(STAT > Z)
%
%___________________________________________________________________________
%
% spm_P_Bonf returns the p-value of Z corrected by the Bonferroni
% inequality.
%
% If n > 1 a conjunction probility over the n values of the statistic
% is returned
%
%___________________________________________________________________________
% Copyright (C) 2008 Wellcome Trust Centre for Neuroimaging
% Thomas Nichols
% $Id: spm_P_Bonf.m 1143 2008-02-07 19:33:33Z spm $
if STAT == 'Z'
P = 1 - spm_Ncdf(Z);
elseif STAT == 'T'
P = 1 - spm_Tcdf(Z,df(2));
elseif STAT == 'X'
P = 1 - spm_Xcdf(Z,df(2));
elseif STAT == 'F'
P = 1 - spm_Fcdf(Z,df);
end
P = S*P.^n;
P = min(P,1);