-
Notifications
You must be signed in to change notification settings - Fork 0
/
prof_concat_niimgs.py
74 lines (54 loc) · 1.71 KB
/
prof_concat_niimgs.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
"""Benchmark for concat_niimgs()
"""
import sys
sys.path.append("..")
import os
import os.path as osp
import glob
import nibabel
import nilearn.utils
import nilearn.datasets
import utils
def get_filenames():
adhd = nilearn.datasets.fetch_adhd(n_subjects=1)
filename = adhd["func"][0]
output_dir = "_prof_concat_niimgs"
# create output directory
if not osp.isdir(output_dir):
os.mkdir(output_dir)
# list of existing individual images in output_dir
images = glob.glob(osp.join(output_dir, "*.nii.gz"))
return filename, output_dir, images
def init():
filename, output_dir, _ = get_filenames()
print ("Creating nii files...")
fmri = nibabel.load(filename)
data = fmri.get_data()
affine = fmri.get_affine()
img_number = data.shape[3]
for n in xrange(img_number):
print("image %d / %d" % (n + 1, img_number))
img = nibabel.Nifti1Image(data[..., n], affine)
nibabel.save(img, osp.join(output_dir, "image_%.3d.nii.gz" % n))
def benchmark():
# Concatenate all individual images, time the operation
_, _, images = get_filenames()
if utils.cache_tools_available:
print("Invalidating cache...")
utils.dontneed(images)
print("Concatenating images...")
data = utils.timeit(profile(nilearn.utils.concat_niimgs))(images)
assert(data.shape[3] == len(images))
del data
print("Concatenating images...")
data = utils.timeit(profile(nilearn.utils.concat_niimgs))(images)
assert(data.shape[3] == len(images))
del data
if __name__ == "__main__":
kind = None
if len(sys.argv) == 2:
kind = sys.argv[1]
if kind == "init":
init()
else:
benchmark()