-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathsnpm_check_nperm.m
36 lines (34 loc) · 1.43 KB
/
snpm_check_nperm.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
function snpm_check_nperm(nPerm,TotPerm)
%
% Issue consistent warning messages about number of permutations
%
%
%_______________________________________________________________________
% Copyright (C) 2013 The University of Warwick
% Id: snpm_check_perm.m SnPM13 2013/10/12
% Thomas Nichols
% Use very arbitrary heuristic... if fewer than 100 permutations used
% *and* less than 90% of possible permutations considered, then issue a
% specific warning about variability of Monte Carlo variation.
str='';
if nPerm<100 && nPerm>=0.9*TotPerm
str = sprintf(['Very few (%d) permutations used, nonparametric P-values are very coarse (but exact).\n'...
'Smallest possible P-value is %0.4f.'],nPerm,1/nPerm);
id = 'SnPM:VeryFewPermsCoarseExactPValues';
elseif nPerm<100 && nPerm<0.9*TotPerm
str = sprintf(['Very few (%d) permutations used, nonparametric P-values are very coarse will vary \n'...
'substantially over repeated re-analyses.'...
'Smallest possible P-value is %0.4f.'],nPerm,1/nPerm);
id = 'SnPM:VeryFewPermsCoarseVaryingPValues';
elseif nPerm>10000
str = sprintf(['Many (%d) permutations used, analysis may take a very long time\n'...
'to complete. Consiser running fewer permutations.'],nPerm,1/nPerm);
id = 'SnPM:ManyPerms';
elseif nPerm>25000
str = sprintf(['%cInsane nummber of permutations requested (%d)!\n'...
'Are you sure!?'],7,nPerm);
id = 'SnPM:ManyManyPerms';
end
if ~isempty(str)
warning(id, str)
end