[805160]: / cardiac_motion / utils / imageio_utils.py

Download this file

65 lines (49 with data), 1.7 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
"""
Utility functions to handle image IO.
Huaqi Qiu, Jan 2019.
"""
import nibabel as nib
import imageio
import os
import numpy as np
from PIL import Image
def upsample_image(image, size):
return np.array(Image.fromarray(image).resize((size, size)))
def save_nifti(ndarray, path, nim, verbose=False):
"""
Save a numpy array to a nifti file
Args:
ndarray: numpy array
path: destination path
nim: nibabel's nim object, to provide the nifti header
Returns:
N/A
"""
nim_save = nib.Nifti1Image(ndarray, nim.affine, nim.header)
nib.save(nim_save, path)
if verbose:
print("Nifti saved to: {}".format(path))
def save_gif(images, path, fps=20):
"""
Save numpy array to gif
Args:
images: numpy array of shape (H, W, Frames) for grayscale images
or (H, W, ch, Frames) for colored images
path: save destination file path
fps: frame rate of the gif
"""
images = images.astype(np.uint8)
frame_list = [upsample_image(images[..., fr], 300) for fr in range(images.shape[-1])]
imageio.mimwrite(path, frame_list, fps=fps)
def save_png(images, path_dir):
"""
Save numpy array to a series of PNG files
Args:
images: numpy array of shape (H, W, Frames) for grayscale images
or (H, W, ch, Frames) for colored images
path_dir: save destination directory path
"""
images = images.astype(np.uint8)
for fr in range(images.shape[-1]):
image = upsample_image(images[..., fr], 300)
imageio.imwrite(os.path.join(path_dir, 'frame_{}.png'.format(fr)), image)