File size: 1,267 Bytes
9b4a05a
a1fac21
 
 
3243b25
 
000c87e
8638595
9b4a05a
3122c78
9b4a05a
 
3243b25
28c0062
 
a1fac21
a87b5fc
 
 
a1fac21
a87b5fc
 
a1fac21
a87b5fc
 
a1fac21
a87b5fc
 
 
a1f8014
e07aae5
 
a1f8014
a87b5fc
 
4bf66ef
a1fac21
9b4a05a
 
 
a1fac21
9090de4
129df37
9b4a05a
4bf66ef
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
import tensorflow as tf

import math
import numpy as np
from PIL import Image

from tensorflow.keras.preprocessing.image import img_to_array
from huggingface_hub import from_pretrained_keras
import gradio as gr

model = from_pretrained_keras("Dvjc1899/super-resolution")

def infer(image):
	image = np.resize(image, (100,100))
	img = Image.fromarray(image )
	ycbcr = img.convert("YCbCr")
	y, cb, cr = ycbcr.split()
	y = img_to_array(y)
	y = y.astype("float32") / 255.0

	input = np.expand_dims(y, axis=0)
	out = model.predict(input)

	out_img_y = out[0]
	out_img_y *= 255.0

	# Restore the image in RGB color space.
	out_img_y = out_img_y.clip(0, 255)
	out_img_y = out_img_y.reshape((np.shape(out_img_y)[0], np.shape(out_img_y)[1]))
	out_img_y = Image.fromarray(np.uint8(out_img_y), mode="L")
	out_img_cb = cb.resize(out_img_y.size, Image.BICUBIC)
	out_img_cr = cr.resize(out_img_y.size, Image.BICUBIC)
	out_img = Image.merge("YCbCr", (out_img_y, out_img_cb, out_img_cr)).convert(
		"RGB"
	)
	return (img,out_img)
	
iface = gr.Interface(
	fn=infer,
	title = "Super-resolution",
	inputs=gr.inputs.Image(label="Input Image"),
	outputs=[gr.outputs.Image(label="Resized 100x100 image"),
	gr.outputs.Image(label="Super-resolution 300x300 image")
	],
).launch(share = True)