Spaces:
Running
Running
Commit
·
ccea513
1
Parent(s):
ea0859d
del resize, change output
Browse files
app.py
CHANGED
@@ -1,6 +1,10 @@
|
|
1 |
import gradio as gr
|
2 |
import torch
|
3 |
from utils import *
|
|
|
|
|
|
|
|
|
4 |
|
5 |
torch.hub.download_url_to_file(
|
6 |
'https://github.com/aalto-ui/aim/raw/aim2/backend/data/tests/input_values/wikipedia.org_website.png',
|
@@ -10,54 +14,32 @@ torch.hub.download_url_to_file(
|
|
10 |
'aalto.fi_website.png')
|
11 |
|
12 |
|
|
|
13 |
def inference(img, template, angel):
|
14 |
color_image = cv2.imread(img.name, cv2.IMREAD_COLOR)
|
15 |
-
height, width, _ = color_image.shape
|
16 |
-
|
17 |
-
# Resize if it is bigeer than 960 * 800
|
18 |
-
if width > height:
|
19 |
-
if width > 960: # 3/4 * 1280
|
20 |
-
coef_div = width / 960.0
|
21 |
-
color_image = cv2.resize(color_image, dsize=(int(width / coef_div), int(height / coef_div)),
|
22 |
-
interpolation=cv2.INTER_CUBIC)
|
23 |
-
else:
|
24 |
-
if height > 800: # 800
|
25 |
-
coef_div = height / 800.0
|
26 |
-
color_image = cv2.resize(color_image, dsize=(int(width / coef_div), int(height / coef_div)),
|
27 |
-
interpolation=cv2.INTER_CUBIC)
|
28 |
|
29 |
HSV_image = cv2.cvtColor(color_image, cv2.COLOR_BGR2HSV)
|
30 |
selected_harmomic_scheme = HarmonicScheme(str(template), int(angel))
|
31 |
-
new_HSV_image =
|
32 |
|
33 |
# Compute shifted histogram
|
34 |
histo_1 = count_hue_histogram(HSV_image)
|
35 |
histo_2 = count_hue_histogram(new_HSV_image)
|
36 |
|
37 |
# Create Hue Plots
|
38 |
-
fig1 = plothis(histo_1,
|
39 |
fig_1_cv = get_img_from_fig(fig1)
|
40 |
-
fig2 = plothis(histo_2,
|
41 |
fig_2_cv = get_img_from_fig(fig2)
|
42 |
-
|
43 |
-
# Stack Hue Plots
|
44 |
-
vis = np.concatenate((fig_1_cv, fig_2_cv), axis=0)
|
45 |
# Convert HSV to BGR
|
46 |
result_image = cv2.cvtColor(new_HSV_image, cv2.COLOR_HSV2BGR)
|
47 |
|
48 |
-
|
49 |
-
|
50 |
-
|
51 |
-
x_center = (960 - width) // 2
|
52 |
-
y_center = (800 - height) // 2
|
53 |
-
# copy img image into center of result image
|
54 |
-
canvas[y_center:y_center + height, x_center:x_center + width] = result_image
|
55 |
|
56 |
-
# Combine
|
57 |
-
output = np.concatenate((vis, canvas), axis=1)
|
58 |
-
cv2.imwrite('output.png', output)
|
59 |
|
60 |
-
return ['
|
61 |
|
62 |
|
63 |
title = 'Color Harmonization'
|
@@ -66,6 +48,12 @@ article = "<p style='text-align: center'></p>"
|
|
66 |
examples = [['wikipedia.org_website.png'], ['aalto.fi_website.png']]
|
67 |
css = ".output_image, .input_image {height: 40rem !important; width: 100% !important;}"
|
68 |
|
|
|
|
|
|
|
|
|
|
|
|
|
69 |
gr.Interface(
|
70 |
inference,
|
71 |
[gr.inputs.Image(type='file', label='Input'),
|
@@ -73,10 +61,12 @@ gr.Interface(
|
|
73 |
default="X",
|
74 |
label="Template"),
|
75 |
gr.inputs.Slider(0, 359, label="Angle")],
|
76 |
-
[gr.outputs.Image(type='file', label='Color Harmonization of Output Image')
|
|
|
|
|
77 |
title=title,
|
78 |
description=description,
|
79 |
article=article,
|
80 |
examples=examples,
|
81 |
-
css=css,
|
82 |
).launch(debug=True, enable_queue=True)
|
|
|
1 |
import gradio as gr
|
2 |
import torch
|
3 |
from utils import *
|
4 |
+
import cv2
|
5 |
+
import numpy as np
|
6 |
+
import matplotlib.pyplot as plt
|
7 |
+
import io
|
8 |
|
9 |
torch.hub.download_url_to_file(
|
10 |
'https://github.com/aalto-ui/aim/raw/aim2/backend/data/tests/input_values/wikipedia.org_website.png',
|
|
|
14 |
'aalto.fi_website.png')
|
15 |
|
16 |
|
17 |
+
|
18 |
def inference(img, template, angel):
|
19 |
color_image = cv2.imread(img.name, cv2.IMREAD_COLOR)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
20 |
|
21 |
HSV_image = cv2.cvtColor(color_image, cv2.COLOR_BGR2HSV)
|
22 |
selected_harmomic_scheme = HarmonicScheme(str(template), int(angel))
|
23 |
+
new_HSV_image = selected_harmomic_scheme.hue_shifted(HSV_image, num_superpixels=-1)
|
24 |
|
25 |
# Compute shifted histogram
|
26 |
histo_1 = count_hue_histogram(HSV_image)
|
27 |
histo_2 = count_hue_histogram(new_HSV_image)
|
28 |
|
29 |
# Create Hue Plots
|
30 |
+
fig1 = plothis(histo_1, selected_harmomic_scheme, "Source Hue")
|
31 |
fig_1_cv = get_img_from_fig(fig1)
|
32 |
+
fig2 = plothis(histo_2, selected_harmomic_scheme, "Target Hue")
|
33 |
fig_2_cv = get_img_from_fig(fig2)
|
|
|
|
|
|
|
34 |
# Convert HSV to BGR
|
35 |
result_image = cv2.cvtColor(new_HSV_image, cv2.COLOR_HSV2BGR)
|
36 |
|
37 |
+
cv2.imwrite('fig_1_cv.jpg', fig_1_cv)
|
38 |
+
cv2.imwrite('fig_2_cv.jpg', fig_1_cv)
|
39 |
+
cv2.imwrite('result_image.jpg', result_image)
|
|
|
|
|
|
|
|
|
40 |
|
|
|
|
|
|
|
41 |
|
42 |
+
return ['result_image.jpg', 'fig_1_cv.jpg', 'fig_2_cv.jpg']
|
43 |
|
44 |
|
45 |
title = 'Color Harmonization'
|
|
|
48 |
examples = [['wikipedia.org_website.png'], ['aalto.fi_website.png']]
|
49 |
css = ".output_image, .input_image {height: 40rem !important; width: 100% !important;}"
|
50 |
|
51 |
+
title = 'Color Harmonization'
|
52 |
+
description = 'Compute Color Harmonization with Different Templates'
|
53 |
+
article = "<p style='text-align: center'></p>"
|
54 |
+
examples = [['wikipedia.org_website.png'], ['aalto.fi_website.png']]
|
55 |
+
# css = ".output_image, .input_image {height: 40rem !important; width: 100% !important;}"
|
56 |
+
|
57 |
gr.Interface(
|
58 |
inference,
|
59 |
[gr.inputs.Image(type='file', label='Input'),
|
|
|
61 |
default="X",
|
62 |
label="Template"),
|
63 |
gr.inputs.Slider(0, 359, label="Angle")],
|
64 |
+
[gr.outputs.Image(type='file', label='Color Harmonization of Output Image'),
|
65 |
+
gr.outputs.Image(type='file', label='Source Hue'),
|
66 |
+
gr.outputs.Image(type='file', label='Target Hue'),],
|
67 |
title=title,
|
68 |
description=description,
|
69 |
article=article,
|
70 |
examples=examples,
|
71 |
+
# css=css,
|
72 |
).launch(debug=True, enable_queue=True)
|