-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathvariance_homogeneity.m
93 lines (82 loc) · 2.75 KB
/
variance_homogeneity.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
79
80
81
82
83
84
85
86
87
88
89
90
91
function [h,CI] = variance_homogeneity(x,y,condition)
% Compares variances using a 95% percentile bootstrap CI.
%
% FORMAT: [h,CI] = variance_homogeneity(x,y)
% [h,CI] = variance_homogeneity(x,y,condition)
%
% INPUTS: x and y are two vectors of the same length
% condition = 0/1 (default=0) to condition x and y on each other
%
% OUTPUTS: h indicates if the data have the same variance (0) or not (1)
% CI is the 95% confidence interval of the difference between variances
%
% see also CONDITIONAL.
% Cyril Pernet v1
% ---------------------------------
% Copyright (C) Corr_toolbox 2012
if nargin == 2
condition = 1
end
if size(x)~=size(y)
error('X and Y must have the same size')
end
% computes
nboot = 600;
nm = length(x);
if nm < 40; l=6; u=593;
elseif nm >= 40 && nm < 80; l=7; u=592;
elseif nm >= 80 && nm < 180; l=10; u=589;
elseif nm >= 180 && nm < 250; l=13; u=586;
elseif nm >= 250; l=15; u=584; end
% boostrap
table = randi(nm,nm,nboot);
for B=1:nboot
% resample
a = x(table(:,B));
b = y(table(:,B));
if condition == 1
[values,variances]=conditional(a(:),b(:));
Diff(B) = variances(1) - variances(2);
else
Diff(B) = var(a) - var(b);
end
end
Diff = sort(Diff);
CI = [Diff(l+1) Diff(u)];
if sum(isnan(Diff)) ~=0
adj_nboot = nboot - sum(isnan(Diff));
adj_l = round((5/100*adj_nboot)/2);
adj_u = adj_nboot - adj_l;
CI = [Diff(adj_l+1) Diff(adj_u)];
end
% plot
figure('Name','Heteroscedasticity test');
set(gcf,'Color','w');
k = round(1 + log2(nboot));
[n,p] = hist(Diff,k);
bar(p,n,1,'FaceColor',[0.5 0.5 1]);
grid on; axis tight;
ylabel('frequency','Fontsize',14); hold on
plot(repmat(CI(1),max(hist(Diff,k)),1),[1:max(hist(Diff,k))],'r','LineWidth',4);
plot(repmat(CI(2),max(hist(Diff,k)),1),[1:max(hist(Diff,k))],'r','LineWidth',4);
if CI(1) < 0 && CI(2) > 0
h = 0;
if condition == 1
mytitle = sprintf('Test on conditional variances: \n data are homoscedastic 95%% CI [%g %g]',CI(1),CI(2));
xlabel('differences of conditional variances between X and Y','Fontsize',14);
else
mytitle = sprintf('Test on variances: \n data are homoscedastic 95%% CI [%g %g]',CI(1),CI(2));
xlabel('differences of variances between X and Y','Fontsize',14);
end
else
h = 1;
if condition == 1
mytitle = sprintf('Test on conditional variances: \n data are heteroscedastic 95%% CI [%g %g]',CI(1),CI(2));
xlabel('differences of conditional variances between X and Y','Fontsize',14);
else
mytitle = sprintf('Test on variances: \n data are heteroscedastic 95%% CI [%g %g]',CI(1),CI(2));
xlabel('differences of variances between X and Y','Fontsize',14);
end
end
title(mytitle,'Fontsize',14)
box on;set(gca,'Fontsize',14)