-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathgraph_construct_test.py
104 lines (81 loc) · 4.69 KB
/
graph_construct_test.py
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
101
102
103
104
"""Tests for graph construction component."""
import unittest
import numpy as np
import graph_construct
from phenotype import Phenotype
subject_ids = [1192336, 1629877, 1677375, 1894259, 2875424, 2898110, 3766119, 4553519, 4581316, 4872190]
subject_ids_ukb = ['UKB{}'.format(i) for i in subject_ids]
sex = ['M', 'M', 'M', 'F', 'F', 'M', 'M', 'F', 'F', 'F']
fte = [np.nan, 15, 17, 15, 17, 16, 16, np.nan, np.nan, np.nan]
fi = [9, 4, 9, 6, 5, 4, 8, 6, 9, 5]
labels = [63, 71, 60, 75, 54, 60, 61, 58, 61, 65]
# Structural data
ct = graph_construct.collect_structural(subject_ids_ukb, 'cortical_thickness')
sa = graph_construct.collect_structural(subject_ids_ukb, 'surface_area')
gmv = graph_construct.collect_structural(subject_ids_ukb, 'volume')
euler = graph_construct.collect_euler(subject_ids_ukb)
class ConstructEdgeListTest(unittest.TestCase):
def testConstructEdgeList_SexSimilarity(self):
edge_list = graph_construct.construct_edge_list(subject_ids_ukb, [Phenotype.SEX])
true_edge_list = []
for i in range(len(subject_ids)):
for j in range(len(subject_ids)):
if i != j and sex[i] == sex[j]:
true_edge_list.append([i, j])
self.assertIsNone(np.testing.assert_array_equal(edge_list, np.transpose(true_edge_list)))
def testConstructEdgeList_FullTimeEducationSimilarity(self):
edge_list = graph_construct.construct_edge_list(subject_ids_ukb, [Phenotype.FULL_TIME_EDUCATION])
true_edge_list = []
for i in range(len(subject_ids)):
for j in range(len(subject_ids)):
if i != j and fte[i] == fte[j]:
true_edge_list.append([i, j])
self.assertIsNone(np.testing.assert_allclose(edge_list, np.transpose(true_edge_list), equal_nan=False))
def testConstructEdgeList_FluidIntelligenceSimilarity(self):
edge_list = graph_construct.construct_edge_list(subject_ids_ukb, [Phenotype.FLUID_INTELLIGENCE])
true_edge_list = []
for i in range(len(subject_ids)):
for j in range(len(subject_ids)):
if i != j and fi[i] == fi[j]:
true_edge_list.append([i, j])
self.assertIsNone(np.testing.assert_allclose(edge_list, np.transpose(true_edge_list), equal_nan=False))
def testConstructEdgeList_SexAndFluidIntelligenceSimilarity(self):
edge_list = graph_construct.construct_edge_list(subject_ids_ukb,
[Phenotype.SEX, Phenotype.FLUID_INTELLIGENCE],
similarity_threshold=1)
true_edge_list = []
for i in range(len(subject_ids)):
for j in range(len(subject_ids)):
if i != j and fi[i] == fi[j] and sex[i] == sex[j]:
true_edge_list.append([i, j])
self.assertIsNone(np.testing.assert_allclose(edge_list, np.transpose(true_edge_list), equal_nan=False))
def testConstructEdgeList_SexOrFluidIntelligenceSimilarity(self):
edge_list = graph_construct.construct_edge_list(subject_ids_ukb,
[Phenotype.SEX, Phenotype.FLUID_INTELLIGENCE],
similarity_threshold=0.5)
true_edge_list = []
for i in range(len(subject_ids)):
for j in range(len(subject_ids)):
if i != j and (fi[i] == fi[j] or sex[i] == sex[j]):
true_edge_list.append([i, j])
self.assertIsNone(np.testing.assert_allclose(edge_list, np.transpose(true_edge_list), equal_nan=False))
class ConstructPopulationGraphTest(unittest.TestCase):
def testConstructPopulationGraph_ToyGraph(self):
graph = graph_construct.construct_population_graph([Phenotype.SEX],
subject_ids=subject_ids_ukb,
age_filtering=False,
save=False)
actual_labels = graph.y.numpy().flatten()
self.assertTrue(np.array_equal(actual_labels, labels))
self.assertTrue(np.array_equal(graph.subject_index, subject_ids_ukb))
# Comparing structural data
actual_ct = graph.structural_data['cortical_thickness']
actual_sa = graph.structural_data['surface_area']
actual_gmv = graph.structural_data['volume']
actual_euler = graph.euler_data
self.assertTrue(np.array_equal(actual_ct, ct))
self.assertTrue(np.array_equal(actual_sa, sa))
self.assertTrue(np.array_equal(actual_gmv, gmv))
self.assertTrue(np.array_equal(actual_euler, euler))
if __name__ == '__main__':
unittest.main()