forked from microsoft/DirectML
-
Notifications
You must be signed in to change notification settings - Fork 0
/
superres.py
101 lines (82 loc) · 4 KB
/
superres.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
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
#
# DirectML super-sesolution sample
# Based on the following model: https://github.com/onnx/models/tree/master/vision/super_resolution/sub_pixel_cnn_2016
#
import pydirectml as dml
import numpy as np
from PIL import Image, ImageOps
import sys
import os
argument_count = len(sys.argv)
image_file_path = "dog2.jpg"
tensor_data_path = "super_resolution_10_data"
batch_size = 1
# Get user image input path if any. If none, default to image_file_path value.
if (argument_count >= 2):
image_file_path = sys.argv[1]
if (not os.path.exists(image_file_path)):
print("File not found at: " + str(image_file_path))
sys.exit(1)
# Image preprocessing
img = Image.open(image_file_path)
img = ImageOps.fit(img, (224, 224), method = 0, bleed = 0, centering = (0.5, 0.5))
img_ycbcr = img.convert('YCbCr')
img_y_0, img_cb, img_cr = img_ycbcr.split()
img_ndarray = np.asarray(img_y_0)
img_4 = np.expand_dims(np.expand_dims(img_ndarray, axis=0), axis=0)
img_5 = img_4.astype(np.float32) / 255.0
# Create an executing device and build a model
device = dml.Device(True, True)
builder = dml.GraphBuilder(device)
data_type = dml.TensorDataType.FLOAT32
input = dml.input_tensor(builder, 0, dml.TensorDesc(data_type, [batch_size,1,224,224]));
flags = dml.TensorFlags.OWNED_BY_DML
# conv1
conv1_filter = dml.input_tensor(builder, 1, dml.TensorDesc(data_type, flags, [64, 1, 5, 5]))
conv1_bias = dml.input_tensor(builder, 2, dml.TensorDesc(data_type, flags, [1,64,1,1]))
conv1 = dml.convolution(input, conv1_filter, conv1_bias, start_padding = [2,2], end_padding = [2,2], fused_activation = dml.FusedActivation(dml.OperatorType.ACTIVATION_RELU))
# conv2
conv2_filter = dml.input_tensor(builder, 3, dml.TensorDesc(data_type, flags, [64,64,3,3]))
conv2_bias = dml.input_tensor(builder, 4, dml.TensorDesc(data_type, flags, [1,64,1,1]))
conv2 = dml.convolution(conv1, conv2_filter, conv2_bias, start_padding = [1,1], end_padding = [1,1], fused_activation = dml.FusedActivation(dml.OperatorType.ACTIVATION_RELU))
# conv3
conv3_filter = dml.input_tensor(builder, 5, dml.TensorDesc(data_type, flags, [32,64,3,3]))
conv3_bias = dml.input_tensor(builder, 6, dml.TensorDesc(data_type, flags, [1,32,1,1]))
conv3 = dml.convolution(conv2, conv3_filter, conv3_bias, start_padding = [1,1], end_padding = [1,1], fused_activation = dml.FusedActivation(dml.OperatorType.ACTIVATION_RELU))
conv4_filter = dml.input_tensor(builder, 7, dml.TensorDesc(data_type, flags, [9, 32, 3, 3]))
conv4_bias = dml.input_tensor(builder, 8, dml.TensorDesc(data_type, flags, [1,9,1,1]))
conv4 = dml.convolution(conv3, conv4_filter, conv4_bias, start_padding = [1,1], end_padding = [1,1], fused_activation = dml.FusedActivation(dml.OperatorType.ACTIVATION_RELU))
# Compile the expression graph into a compiled operator
op = builder.build(dml.ExecutionFlags.NONE, [conv4])
# Model inputs in the previously designated order
inputs = [
(conv1_filter,"conv1.weight.npy"),
(conv1_bias,"conv1.bias.npy"),
(conv2_filter,"conv2.weight.npy"),
(conv2_bias,"conv2.bias.npy"),
(conv3_filter,"conv3.weight.npy"),
(conv3_bias,"conv3.bias.npy"),
(conv4_filter,"conv4.weight.npy"),
(conv4_bias,"conv4.bias.npy")
]
input_bindings = []
input_bindings.append(dml.Binding(input, img_5))
for input, file_name in inputs:
input_bindings.append(dml.Binding(input, np.load(tensor_data_path + '/' + file_name)))
# Compute the result
output_data = device.compute(op, input_bindings, [conv4])
output_tensor = np.array(output_data[0])
output_tensor = np.reshape(output_tensor, [-1,1,3,3,224,224])
output_tensor = output_tensor.transpose((0, 1, 4, 2, 5, 3))
output_tensor = np.reshape(output_tensor, [-1,1,672,672])
for out in output_tensor[0]:
img_out_y = Image.fromarray(np.uint8((out.squeeze() * 255.0).clip(0,255)), mode='L')
final_img = Image.merge(
"YCbCr",
[
img_out_y,
img_cb.resize(img_out_y.size, Image.BICUBIC),
img_cr.resize(img_out_y.size, Image.BICUBIC),
]
).convert("RGB")
final_img.show()