forked from brechmos/datastore-statistics
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathreader.py
More file actions
143 lines (104 loc) · 3.22 KB
/
reader.py
File metadata and controls
143 lines (104 loc) · 3.22 KB
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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
from pathlib import Path
import numpy as np
import pathlib
import imageio
import nibabel
import pydicom
class DataFile:
"""
Base class
Requires the definition of several methods and defines the static method that
instantitates the reader.
"""
def __init__(self):
pass
def get_data(self):
return None
def get_shape(self):
return None
def get_type(self):
return None
def __str__(self):
metrics = self.get_metrics()
return f'{self._filename}: min {metrics["min"]:0.1f}, mu {metrics["mean"]:0.1f}, med {metrics["median"]:0.1f} max {metrics["max"]:0.1f}'
@staticmethod
def get_reader(filename):
"""
Static method to return the correct reader object given the filename.
"""
# Convert to string, if needed
if isinstance(filename, str):
filename = Path(filename)
# Instantiate the Dicom reader
if filename.suffix == '.dcm':
return DICOM(filename)
# Instantiate the NIFTI reader
elif '.nii' in str(filename).lower():
return NII(filename)
# Instantiate the jpeg/png/tiff reader
elif filename.suffix in ['.jpeg', '.jpg', '.png', '.tiff', '.tif']:
return ImageIO(filename)
else:
raise('No related reader type')
def get_metrics(self):
"""
Return basic stats on the data.
"""
return {
'mean': np.mean(self.get_data()),
'std': np.std(self.get_data()),
'median': np.median(self.get_data()),
'min': np.min(self.get_data()),
'max': np.max(self.get_data()),
'p0.1': np.percentile(self.get_data(), 0.1),
'p99.9': np.percentile(self.get_data(), 99.9)
}
class ImageIO(DataFile):
"""
DICOM Class.
"""
def __init__(self, filename):
super().__init__()
self._filename = filename
self._object = imageio.imread(self._filename)
def get_type(self):
return 'imageio'
def get_data(self):
return self._object
def get_shape(self):
return self._object.shape
class DICOM(DataFile):
"""
DICOM Class.
"""
def __init__(self, filename):
super().__init__()
self._filename = filename
self._object = pydicom.dcmread(self._filename)
def get_type(self):
return 'dicom'
def get_data(self):
return self._object.pixel_array
def get_shape(self):
return self._object.pixel_array.shape
class NII(DataFile):
"""
NIFTI Class
"""
def __init__(self, filename):
super().__init__()
self._filename = filename
self._object = nib.load(self._filename)
def get_type(self):
return 'nii'
def get_data(self):
return self.get_fdata()
def get_shape(self):
return self.dataobj.shape
if __name__ == '__main__':
from pathlib import Path
directory = Path('tests/data')
filenames = list(directory.glob('*'))
for filename in filenames:
reader = DataFile.get_reader(filename)
print(reader.get_type(), reader.get_shape(), reader.get_metrics())