forked from LIMO-EEG-Toolbox/limo_tools
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathlimo_max_correction.m
78 lines (68 loc) · 2.45 KB
/
limo_max_correction.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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
function [mask,p_val,max_th] = limo_max_correction(M,bootM,p,fig)
% correction for multiple testing using the max stat value
% since the type 1 error is the prob to make at least one error
% we can control the prob the make an error for the biggest value
% note this works for both bootstrapped data/tfce trandformed data under H0
%
% FORMAT [mask,p_val,max_th] = limo_max_correction(M,bootM,p,fig)
%
% INPUT
% M = 2D matrix of observed values
% bootM = 3D matrix of T^2 or F values for data bootstrapped under H0
% p = threshold to apply e.g. 5/100
% fig = 1/0 to plot the maximum stat un der H0
%
% OUTPUT
% mask is a binary matrix of the same size as M corresponding to a threshold
% p corrected for multiple comparisons
% p_val are the p-values obtained via the matrix bootM (non-corrected)
% max_th is the threshold controlling the type 1 FWER
%
% Cyril Pernet v1
% outsourced from limo_stat_values
% --------------------------------
% Copyright (C) LIMO Team 2016
if nargin == 3
fig = 1;
end
[a,b,nboot]=size(bootM);
if any(size(M)~=[a b])
error('dimension error: matrices of observed and bootstrap values are different')
end
% collect highest value for each boot
parfor boot=1:nboot
data = squeeze(bootM(:,:,boot));
maxM(boot) = max(data(:)); %
end
% get threshold
maxM(maxM==Inf) = [];
sortmaxM = sort(maxM);
nboot = length(sortmaxM);
U = round((1-p).*nboot);
max_th = sortmaxM(U);
mask = squeeze(M) >= max_th;
% get the equivalent bootstrapped p-value
smalest_pval = 1/nboot;
for row =1:a
for column=1:b
p_val(row,column) = 1- (sum(M(row,column) <= sortmaxM) / nboot);
if p_val(row,column) == 0; p_val(row,column) = smalest_pval; end
end
end
%% figure
if fig == 1
figure('Name','Correction by max: results under H0')
plot(sortmaxM,'LineWidth',3); grid on; hold on;
plot(min(find(sortmaxM==max_th)),max_th,'r*','LineWidth',5)
txt = 'threashold \rightarrow';
text(min(find(sortmaxM==max_th)),max_th,txt,'FontSize',12,'HorizontalAlignment','right');
[val,loc]=min(abs(sortmaxM-max(M(:))));
plot(loc,max(M(:)),'r*','LineWidth',5)
txt = sprintf('maximum');
txt = [txt '\rightarrow'];
text(loc,max(M(:)),txt,'FontSize',12,'HorizontalAlignment','right');
title('Maxima under H0','FontSize',12)
xlabel('sorted bootstrap iterations','FontSize',12);
ylabel('Freq.','FontSize',12)
box on; set(gca,'Layer','Top')
end