Spaces:
Runtime error
Runtime error
gokaygokay
commited on
Update app.py
Browse files
app.py
CHANGED
@@ -160,44 +160,29 @@ def _blend(img1: np.ndarray, img2: np.ndarray, mask: np.ndarray) -> np.ndarray:
|
|
160 |
return img1 * mask + img2 * (1.0 - mask)
|
161 |
|
162 |
def laplacian_blend(img1: np.ndarray, img2: np.ndarray, mask: np.ndarray, depth: int, sigma: int) -> np.ndarray:
|
163 |
-
# Ensure both images have the same number of channels (3 for RGB)
|
164 |
-
if len(img1.shape) == 2:
|
165 |
-
img1 = cv2.cvtColor(img1, cv2.COLOR_GRAY2RGB)
|
166 |
-
if len(img2.shape) == 2:
|
167 |
-
img2 = cv2.cvtColor(img2, cv2.COLOR_GRAY2RGB)
|
168 |
-
|
169 |
-
# Ensure mask has 3 channels
|
170 |
-
if len(mask.shape) == 2:
|
171 |
-
mask = np.stack((mask,) * 3, axis=-1)
|
172 |
-
|
173 |
-
# Resize all images to the same size (use the size of img1)
|
174 |
-
h, w = img1.shape[:2]
|
175 |
-
img2 = cv2.resize(img2, (w, h))
|
176 |
-
mask = cv2.resize(mask, (w, h))
|
177 |
-
|
178 |
mask_gaus_pyramid = _gaus_pyramid(mask, depth, sigma)
|
179 |
img1_lap_pyramid, img2_lap_pyramid = _lap_pyramid(img1, depth, sigma), _lap_pyramid(img2, depth, sigma)
|
180 |
|
181 |
blended = [_blend(obj, bg, mask) for obj, bg, mask in zip(img1_lap_pyramid, img2_lap_pyramid, mask_gaus_pyramid)][::-1]
|
182 |
|
183 |
-
|
184 |
|
185 |
-
|
186 |
-
|
187 |
-
|
188 |
-
|
189 |
-
|
190 |
-
|
191 |
-
|
192 |
-
|
193 |
-
|
194 |
-
|
195 |
reconstructed_img = cv2.add(blended[d], gaussian_img)
|
196 |
|
197 |
-
|
198 |
-
|
199 |
-
|
200 |
-
return np.clip(
|
201 |
|
202 |
def get_image(img_path: str, mask: bool=False, scale: bool=True) -> np.array:
|
203 |
"""
|
@@ -251,7 +236,7 @@ with gr.Blocks(theme='bethecloud/storj_theme') as iface:
|
|
251 |
mask_img = gr.Image(label="Mask Image", type="numpy", height=300)
|
252 |
with gr.Row():
|
253 |
with gr.Column():
|
254 |
-
method = gr.Radio(["Laplacian", "Mixed Gradient"], label="Blending Method", value="Laplacian")
|
255 |
with gr.Column():
|
256 |
blend_button = gr.Button("Blend Images")
|
257 |
|
@@ -265,7 +250,7 @@ with gr.Blocks(theme='bethecloud/storj_theme') as iface:
|
|
265 |
|
266 |
gr.Examples(
|
267 |
examples=[
|
268 |
-
["img1.jpg", "img2.jpg", "mask1.jpg", "
|
269 |
["img3.jpg", "img4.jpg", "mask2.jpg", "Mixed Gradient"],
|
270 |
["img6.jpg", "img9.jpg", "mask3.jpg", "Laplacian"]
|
271 |
],
|
|
|
160 |
return img1 * mask + img2 * (1.0 - mask)
|
161 |
|
162 |
def laplacian_blend(img1: np.ndarray, img2: np.ndarray, mask: np.ndarray, depth: int, sigma: int) -> np.ndarray:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
163 |
mask_gaus_pyramid = _gaus_pyramid(mask, depth, sigma)
|
164 |
img1_lap_pyramid, img2_lap_pyramid = _lap_pyramid(img1, depth, sigma), _lap_pyramid(img2, depth, sigma)
|
165 |
|
166 |
blended = [_blend(obj, bg, mask) for obj, bg, mask in zip(img1_lap_pyramid, img2_lap_pyramid, mask_gaus_pyramid)][::-1]
|
167 |
|
168 |
+
h, w = blended[0].shape[:2]
|
169 |
|
170 |
+
img1 = cv2.resize(img1, (w, h))
|
171 |
+
img2 = cv2.resize(img2, (w, h))
|
172 |
+
mask = cv2.resize(mask, (w, h))
|
173 |
+
|
174 |
+
blanded_img = _blend(img1, img2, mask)
|
175 |
+
blanded_img = cv2.resize(blanded_img, blended[0].shape[:2])
|
176 |
+
|
177 |
+
imgs = []
|
178 |
+
for d in range(0, depth-1):
|
179 |
+
gaussian_img = _low_pass_filter(blanded_img.copy(), sigma)
|
180 |
reconstructed_img = cv2.add(blended[d], gaussian_img)
|
181 |
|
182 |
+
imgs.append(reconstructed_img)
|
183 |
+
blanded_img = cv2.pyrUp(reconstructed_img)
|
184 |
+
|
185 |
+
return np.clip(imgs[-1], 0, 1)
|
186 |
|
187 |
def get_image(img_path: str, mask: bool=False, scale: bool=True) -> np.array:
|
188 |
"""
|
|
|
236 |
mask_img = gr.Image(label="Mask Image", type="numpy", height=300)
|
237 |
with gr.Row():
|
238 |
with gr.Column():
|
239 |
+
method = gr.Radio(["Laplacian", "Poisson", "Mixed Gradient"], label="Blending Method", value="Laplacian")
|
240 |
with gr.Column():
|
241 |
blend_button = gr.Button("Blend Images")
|
242 |
|
|
|
250 |
|
251 |
gr.Examples(
|
252 |
examples=[
|
253 |
+
["img1.jpg", "img2.jpg", "mask1.jpg", "Poisson"],
|
254 |
["img3.jpg", "img4.jpg", "mask2.jpg", "Mixed Gradient"],
|
255 |
["img6.jpg", "img9.jpg", "mask3.jpg", "Laplacian"]
|
256 |
],
|