SAMv2-Mask-Generator / src /plot_utils.py
SauravMaheshkar's picture
feat: initial commit
bf29adc unverified
raw
history blame
2.49 kB
import numpy as np
import matplotlib.pyplot as plt
def show_mask(mask, ax, random_color=False, borders=True):
if random_color:
color = np.concatenate([np.random.random(3), np.array([0.6])], axis=0)
else:
color = np.array([30 / 255, 144 / 255, 255 / 255, 0.6])
h, w = mask.shape[-2:]
mask = mask.astype(np.uint8)
mask_image = mask.reshape(h, w, 1) * color.reshape(1, 1, -1)
if borders:
import cv2
contours, _ = cv2.findContours(mask, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_NONE)
# Try to smooth contours
contours = [
cv2.approxPolyDP(contour, epsilon=0.01, closed=True) for contour in contours
]
mask_image = cv2.drawContours(
mask_image, contours, -1, (1, 1, 1, 0.5), thickness=2
)
ax.imshow(mask_image)
def show_points(coords, labels, ax, marker_size=375):
pos_points = coords[labels == 1]
neg_points = coords[labels == 0]
ax.scatter(
pos_points[:, 0],
pos_points[:, 1],
color="green",
marker="*",
s=marker_size,
edgecolor="white",
linewidth=1.25,
)
ax.scatter(
neg_points[:, 0],
neg_points[:, 1],
color="red",
marker="*",
s=marker_size,
edgecolor="white",
linewidth=1.25,
)
def show_box(box, ax):
x0, y0 = box[0], box[1]
w, h = box[2] - box[0], box[3] - box[1]
ax.add_patch(
plt.Rectangle((x0, y0), w, h, edgecolor="green", facecolor=(0, 0, 0, 0), lw=2)
)
def show_masks(
image,
masks,
scores,
point_coords=None,
box_coords=None,
input_labels=None,
borders=True,
):
num_masks = len(masks)
num_cols = num_masks # Number of columns is equal to the number of masks
fig, axes = plt.subplots(1, num_cols, figsize=(5 * num_cols, 5))
if num_masks == 1:
axes = [axes] # Ensure axes is iterable when there's only one mask
for i, (mask, score) in enumerate(zip(masks, scores)):
ax = axes[i]
ax.imshow(image)
show_mask(mask, ax, borders=borders)
if point_coords is not None:
assert input_labels is not None
show_points(point_coords, input_labels, ax)
if box_coords is not None:
show_box(box_coords, ax)
if len(scores) > 1:
ax.set_title(f"Mask {i+1}, Score: {score:.3f}", fontsize=18)
ax.axis("off")
plt.tight_layout()
return plt