-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdetection.py
More file actions
49 lines (40 loc) · 1.57 KB
/
detection.py
File metadata and controls
49 lines (40 loc) · 1.57 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
import cv2 as cv
import numpy as np
class ObjectDetector():
"""Класс, отвечающий за обнаружение объекта.
Attributes
-------
kernel : ndarray
RGB-цвет детектируемого объекта в виде массива с формой (1,3)
threshold : int
Порог принадлежности точки объекту
Methods
-------
detect(img)
Определяет обрамляющий прямоугольник объекта с данным цветом
"""
def __init__(self):
color = [0,127,255] # голубой
self.kernel = np.asarray([[color]])
self.threshold = 200
def detect(self, img):
"""Определяет обрамляющий прямоугольник объекта с данным цветом
Детектирование на основе цветового сопоставления по L1-норме
Parameters
----------
img : ndarray
Входное трёхканальное изображение с цветовой моделью RGB
Returns
-------
int
Координата по горизонтали
int
Координата по вертикали
int
Ширина
int
Высота
"""
map = 255 - np.mean(np.abs((img - self.kernel)), axis=2)
_, map = cv.threshold(map.astype(np.uint8), 200, 255, cv.THRESH_BINARY)
return cv.boundingRect(map)