Как извлечь контуры из сегментированного изображения HFS - PullRequest
1 голос
/ 07 октября 2019

Как получить контуры из вывода модели HFS? Я пытаюсь обнаружить пол. Любая помощь будет оценена.

HFS_OUTPUT

1 Ответ

1 голос
/ 08 октября 2019

Поскольку пол имеет определенный диапазон цветов, мы можем установить порог цвета, используя cv2.inRange(). Мы конвертируем изображение в формат HSV, затем используем нижний и верхний порог для генерации двоичной сегментированной маски

lower = np.array([0, 31, 182])
upper = np.array([57, 75, 209])

image image

Чтобы найти контур пола, мы можем простонайти контуры на изображении маски. Вот результат, когда пол выделен зеленым цветом

image

import numpy as np
import cv2

# Color threshold
image = cv2.imread('1.jpg')
original = image.copy()
hsv = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)
lower = np.array([0, 31, 182])
upper = np.array([57, 75, 209])
mask = cv2.inRange(hsv, lower, upper)
result = cv2.bitwise_and(original,original,mask=mask)

# Find floor contour on mask
cnts = cv2.findContours(mask, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if len(cnts) == 2 else cnts[1]
for c in cnts:
    cv2.drawContours(original,[c], -1, (36,255,12), 2)

cv2.imshow('mask', mask)
cv2.imshow('result', result)
cv2.imshow('original', original)
cv2.waitKey()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...