-
Notifications
You must be signed in to change notification settings - Fork 48
/
Copy pathimage.py
44 lines (38 loc) · 1.16 KB
/
image.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
import numpy as np
import os
import random
from PIL import Image
def load(path):
return PIL2Chainer(Image.open(path))
def save(path, data, rescale=True):
Chainer2PIL(data, rescale).save(path)
def PIL2Chainer(img, scale=True):
img = np.array(img)
if len(img.shape) == 2:
img = img.astype(np.float32).reshape((1, img.shape[0], img.shape[1]))
else:
buf = np.zeros((img.shape[2], img.shape[0], img.shape[1]), dtype=np.uint8)
for i in range(3):
buf[i,::] = img[:,:,i]
img = buf.astype(np.float32)
if scale:
# img -= 128
img /= 256
return img
def Chainer2PIL(data, rescale=True):
data = np.array(data)
if rescale:
data *= 256
# data += 128
if data.dtype != np.uint8:
data = np.clip(data, 0, 255)
data = data.astype(np.uint8)
if data.shape[0] == 1:
buf = data.astype(np.uint8).reshape((data.shape[1], data.shape[2]))
else:
buf = np.zeros((data.shape[1], data.shape[2], data.shape[0]), dtype=np.uint8)
for i in range(3):
a = data[i,:,:]
buf[:,:,i] = a
img = Image.fromarray(buf)
return img