-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_hierarchical_group_clustering.m
executable file
·70 lines (59 loc) · 3.12 KB
/
run_hierarchical_group_clustering.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
% replicating Akiki & Abdallah, 2019 Group-derived consensus because the
% individual model is weird
% it uses genlouvain but we could switch that out for infomap or other
% models later
listname='washu120' %'washu120'
parcel_name ='Gordon'
ptseriesdir =[ '/data/wheelock/data1/datasets/WashU120/ptseries/']%eLABE/ptseries/Y3/'; % change this
niter = 100;
%'eLABE_Y0_healthy_term_N261'%'eLABE_Y2_N113_atleast600frames'% change this
cohortfile = dir(['/data/wheelock/data1/people/Cindy/BCP/ParcelCreationGradientBoundaryMap/cohortfiles/cohortfiles_',listname,'.txt']);
[subjects, cifti_files, surfdirL, surfdirR] = textread(fullfile(cohortfile.folder,cohortfile.name),'%s%s%s%s');
tmaskfile = dir(['/data/wheelock/data1/people/Cindy/BCP/ParcelCreationGradientBoundaryMap/tmasklist/tmasklist_',listname,'.txt']);
[tmasksubjects, tmaskfiles]=textread(fullfile(tmaskfile.folder,tmaskfile.name),'%s%s');
if ~isequal(tmasksubjects,subjects)
error('tmasklist subjects do not match cohortfile subjects');
end
stats.params.outputdir = '/data/wheelock/data1/people/Cindy/BrBx-HSB_infomap_cleanup/Results/Hierarchical_subject_clustering_Akiki_Abdallah';
%% Concatenate timeseries
ts = cell(1,length(subjects));
for i =1:length(subjects)
disp(subjects{i})
tic
%% state paths for subject
[~,subpath] = fileparts(cifti_files{i});
ptseries_path = fullfile(ptseriesdir,parcel_name,strrep(subpath,'dtseries','ptseries.nii'));
%% get censored ptseries
tmask = load(tmaskfiles{i}); % saved as txt
timeseries = ft_read_cifti_mod(ptseries_path);
%% concatenate
ts{i} = timeseries.data(:,tmask==1);
toc
end
ts_all = horzcat(ts{:});
%%
all_ci = cell(length(subjects),1);
parfor i = 1:length(subjects)
all_ci{i,1} = RMT_com(ts_all',1);%
end
save(save_fname);
return
%%
save_fname = '/data/wheelock/data1/people/Cindy/BrBx-HSB_infomap_cleanup/Results/Hierarchical_subject_clustering_Akiki_Abdallah/groupconcatenated_ts_removal_of_negative_edges/all_ci_washu120.mat'
all_ci_combined = horzcat(all_ci{:});
%% Plot the rsults
[Cons] = HierarchicalConsensus_Jeub(all_ci_combined,0.05); % consensus with Jeub et al. 2018 Scientific Reports
sorted_clusters = postprocess_ordinal_multilayer(Cons.SortCons); % sort across level to have some consistency across columns
sorted_clusters = remove_singleton(sorted_clusters,2); % order to 1-N
% Assign color to consensus
nameoption = 3;% 1: automatic, 3: using template
templatepath ='Gordon2017_17Networks.dlabel.nii';% 'Tu_eLABE_Y2_22Networks.nii'
parcelpath = '/data/wheelock/data1/parcellations/333parcels/Parcels_LR.dtseries.nii'
[CWro,Cons.SortConsRO] = assign_network_colors(sorted_clusters ,3,templatepath,parcelpath);
parcel_name ='Gordon'%'eLABE_Y2_prelim_072023_0.75'%'Gordon'% params.parcel_name
load(['Parcels_',parcel_name,'.mat'],'Parcels');
warning('off');
Explore_parcel_levels_HSB(Cons.SortConsRO,CWro.cMap,Parcels,Cons.levels,fullfile(stats.params.outputdir,'consensus'));
% Explore_parcel_levels_HSB(Cons.modeCons,CWro.cMap,Parcels,Cons.mean_kdenth);
close all;
Cons = Cons_metrics_HSB(Cons,stats); % get some stats for the consensus and plot the figure