-
Notifications
You must be signed in to change notification settings - Fork 1
/
GTA_SC.m
101 lines (79 loc) · 2.68 KB
/
GTA_SC.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
92
93
94
95
96
97
98
99
100
%% GTA analyses using BCT on SC matrices %
%
% Written by Hannelore Aerts
% (UGent, Faculty of Psychology, Department of Data Analysis)
% Date: 22/08/2018
%-------------------------------------------------------------------------%
data_path = '/home/hannelore/Documents/ANALYSES/TVB_post/subjects/';
results_path = '/home/hannelore/Documents/ANALYSES/TVB_post/results_GTA/';
cd(data_path);
sublist=dir('*');sublist=sublist(3:end-1,:);
m=length(sublist);
tm='thrA';
dm = 'Log';
scale = 68;
for index=2:m
%% Load data
subID=sublist(index).name;
disp(['Processing ' subID ' (scale' num2str(scale) ', ' tm ', dist' dm ')']);
load([subID '/TVBii_' subID '_G-Ji/TVBiiOutput_' tm '_scale' num2str(scale) '_dist' dm '.mat'], 'SC')
SC_dist=-log(SC); SC_dist(isinf(SC_dist)) = 0;
%% Graph measures -- general
% Density
density = density_und(SC);
%% Graph measures -- segregation
% Clustering coefficient (all weights must be between 0 and 1)
clust = clustering_coef_wu(SC);
clust_mean = mean(clust);
% Local efficiency (all weights must be between 0 and 1)
Eloc = efficiency_wei(SC, 1);
Eloc_mean = mean(Eloc);
% Modularity
M = nan(scale, 100);
Q = nan(100,1);
for i=1:100
[M(:,i), Q(i,:)] = community_louvain(SC, [],[], 'modularity');
end
[Q_max, Q_ind] = max(Q);
M_max = M(:,Q_ind);
%% Graph measures -- integration
% Global efficiency
Eglob = efficiency_wei(SC);
% Communicability
comm = expm(SC);
comm_mean = mean(comm(:));
%% Graph measures -- centrality
% Degree
degree = degrees_und(SC);
degree_mean = mean(degree);
% Strength
strength = strengths_und(SC);
strength_mean = mean(strength);
% Betweenness centrality --> input is connection lengths instead
% of connection weights
[EBC, BC] = edge_betweenness_wei(SC_dist);
EBC_mean = mean(EBC(:));
BC_mean = mean(BC);
% Participation coefficient
PC = participation_coef(SC, M_max);
PC_mean = mean(PC);
%% Save results
GTA_results(index, 1) = density;
GTA_results(index, 2) = clust_mean;
GTA_results(index, 3) = Eloc_mean;
GTA_results(index, 4) = Q_max;
GTA_results(index, 5) = Eglob;
GTA_results(index, 6) = comm_mean;
GTA_results(index, 7) = degree_mean;
GTA_results(index, 8) = strength_mean;
GTA_results(index, 9) = EBC_mean;
GTA_results(index, 10) = BC_mean;
GTA_results(index, 11) = PC_mean;
clear BC* EBC* Eglob Eloc* M* PC* Q* clust* comm* degree*
clear density i strength* SC*
cd(data_path)
end
cd(results_path);
clear index subID ans
save(['GTA_results_all']);
clear GTA_results