-
Notifications
You must be signed in to change notification settings - Fork 0
/
Transfer_vtc_to_nii.py
63 lines (48 loc) · 1.99 KB
/
Transfer_vtc_to_nii.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
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
Created on Thu Jul 28 01:52:21 2022
@author: gangxinli
"""
import os
import numpy as np
import nibabel as nb
import vtc
from Hook_header import *
# FILE = "/home/faruk/Documents/test_bvbabel/vtc_test.vtc"
# # =============================================================================
# # Load vmr
# header, data = vtc.read_vtc(FILE)
# # See header information
# pprint(header)
# # Export nifti
# basename = FILE.split(os.extsep, 1)[0]
# outname = "{}_bvbabel.nii.gz".format(basename)
# img = nb.Nifti1Image(data, affine=np.eye(4))
# nb.save(img, outname)
# print("Finished.")
def vtc_to_nii(path = "/Users/gangxinli/Desktop/Internship/Neuro/Neuro_ISC/Data/vtc_vmr"):
print("Transfering vtc file to nii file")
for root,dirs,files in os.walk(path):
for file in files:
if file.split(".")[-1] == 'vtc':
FILE = os.path.join(root,file)
header, data = vtc.read_vtc(FILE)
# Save nifti for testing
basename = FILE.split(os.extsep, 1)[0]
outname = "{}.nii".format(basename)
# Hook_header test
write_header(path = '/Users/gangxinli/Desktop/Internship/Neuro/Neuro_ISC/Data/VMP_Test/Hook_header_test/header',header=header)
#
# Export nifti (assign an identity matrix as affine with default header)
# np.eye(4)*n, n control the resoultion
n=header.get('Data type (1:short int, 2:float)')
print("resolution:"+str(n))
img = nb.Nifti1Image(data,affine=np.eye(4)*n)
# img = nb.Nifti1Image(data,affine=np.eye(4))
nb.save(img, outname)
print(os.path.join(root,file)+"\nComplete")
print("Convert Complete!")
return path
if __name__ =="__main__":
vtc_to_nii('/Users/gangxinli/Desktop/Internship/Neuro/Neuro_ISC/Data/11Sep/vtc_tal')