IOPaint/lama_cleaner/tests/test_interactive_seg.py

44 lines
1.4 KiB
Python
Raw Normal View History

2022-11-27 14:25:27 +01:00
from pathlib import Path
import cv2
import numpy as np
2023-03-22 05:57:18 +01:00
from lama_cleaner.plugins import InteractiveSeg, Click
2022-11-27 14:25:27 +01:00
current_dir = Path(__file__).parent.absolute().resolve()
2023-03-22 05:57:18 +01:00
save_dir = current_dir / "result"
2022-11-27 14:25:27 +01:00
save_dir.mkdir(exist_ok=True, parents=True)
img_p = current_dir / "overture-creations-5sI6fQgYIuo.png"
def test_interactive_seg():
interactive_seg_model = InteractiveSeg()
img = cv2.imread(str(img_p))
2023-03-22 05:57:18 +01:00
pred = interactive_seg_model.forward(
img, clicks=[Click(coords=(256, 256), indx=0, is_positive=True)]
)
2022-11-27 14:25:27 +01:00
cv2.imwrite(str(save_dir / "test_interactive_seg.png"), pred)
def test_interactive_seg_with_negative_click():
interactive_seg_model = InteractiveSeg()
img = cv2.imread(str(img_p))
2023-03-22 05:57:18 +01:00
pred = interactive_seg_model.forward(
img,
clicks=[
Click(coords=(256, 256), indx=0, is_positive=True),
Click(coords=(384, 256), indx=1, is_positive=False),
],
)
2022-11-27 14:25:27 +01:00
cv2.imwrite(str(save_dir / "test_interactive_seg_negative.png"), pred)
def test_interactive_seg_with_prev_mask():
interactive_seg_model = InteractiveSeg()
img = cv2.imread(str(img_p))
mask = np.zeros_like(img)[:, :, 0]
2023-03-22 05:57:18 +01:00
pred = interactive_seg_model.forward(
img, clicks=[Click(coords=(256, 256), indx=0, is_positive=True)], prev_mask=mask
)
2022-11-27 14:25:27 +01:00
cv2.imwrite(str(save_dir / "test_interactive_seg_with_mask.png"), pred)