Spaces:
Sleeping
Sleeping
import streamlit as st | |
import cv2 | |
import numpy as np | |
import requests | |
from mmdet.apis import init_detector, inference_detector | |
import mmcv | |
import torch | |
from mmdet.utils.contextmanagers import concurrent | |
from pprint import pprint | |
from PIL import Image | |
import datetime | |
def IoU(bbox1, bbox2): | |
x1_left, y1_top, x1_right, y1_bot = bbox1[0], bbox1[1], bbox1[2], bbox1[3] | |
x2_left, y2_top, x2_right, y2_bot = bbox2[0], bbox2[1], bbox2[2], bbox2[3] | |
x_left = max(x1_left, x2_left) | |
x_right = min(x1_right, x2_right) | |
y_top = max(y1_top, y2_top) | |
y_bot = min(y1_bot, y2_bot) | |
inter = (x_right - x_left) * (y_bot - y_top) | |
if x_right < x_left or y_bot < y_top: | |
return 0.0 | |
area1 = (x1_right - x1_left) * (y1_bot - y1_top) | |
area2 = (x2_right - x2_left) * (y2_bot - y2_top) | |
union = area1 + area2 - inter | |
IoU = inter / union | |
return IoU | |
def file(): | |
inputimg = st.file_uploader("Upload your image") | |
if inputimg is not None: | |
inputimg = Image.open(inputimg) | |
inputimg = np.array(inputimg) | |
inputimg = cv2.cvtColor(inputimg, cv2.COLOR_BGR2RGB) | |
cv2.imwrite('demo_file.jpg', inputimg) | |
return inputimg | |
def webcam(): | |
inputimg = st.camera_input("Take a picture") | |
if inputimg is not None: | |
inputimg = Image.open(inputimg) | |
inputimg = np.array(inputimg) | |
inputimg = cv2.cvtColor(inputimg, cv2.COLOR_BGR2RGB) | |
cv2.imwrite('demo_webcam.jpg', inputimg) | |
return inputimg | |
def phonecam(): | |
if st.button("Take picture"): | |
url = 'http://192.168.114.78:8080//photo.jpg' | |
img_resp = requests.get(url) | |
img_arr = np.array(bytearray(img_resp.content), dtype=np.uint8) | |
inputimg = cv2.imdecode(img_arr, -1) | |
cv2.imwrite('demo_phonecam.jpg', inputimg) | |
return inputimg | |
def detect(inputimg, model): | |
if model == 'f': | |
config_file = './configs/fasterrcnn.py' | |
checkpoint_file = './models/fasterrcnn.pth' | |
# Specify the path to model config and checkpoint file | |
else: | |
config_file = './configs/yolov3.py' | |
checkpoint_file = './models/yolov3.pth' | |
# build the model from a config file and a checkpoint file | |
model = init_detector(config_file, checkpoint_file, device='cuda:0') | |
if (inputimg == 'Webcam'): | |
img = 'demo_webcam.jpg' # or img = mmcv.imread(img), which will only load it once | |
elif (inputimg == 'File'): | |
img = 'demo_file.jpg' | |
elif (inputimg == 'Phone'): | |
img = 'demo_phonecam.jpg' | |
start = datetime.datetime.now() | |
result = inference_detector(model, img) | |
end = datetime.datetime.now() | |
time = end - start | |
time_mcs = time.microseconds | |
total_people, incorrect, withmask,withoutmask = 0, 0, 0, 0 | |
list_objects = [] | |
isRemove = [] | |
for k in [1,2,3]: | |
for i in result[k]: | |
temp = i | |
temp = np.append(temp, k) | |
list_objects.append(temp) | |
isRemove.append(0) | |
for i in range(len(list_objects) - 1): | |
for j in range(i + 1, len(list_objects)): | |
bbox1 = [list_objects[i][0], list_objects[i][1], list_objects[i][2], list_objects[i][3]] | |
bbox2 = [list_objects[j][0], list_objects[j][1], list_objects[j][2], list_objects[j][3]] | |
if abs(IoU(bbox1, bbox2)) > 0.7: | |
if list_objects[i][4] > list_objects[j][4]: | |
isRemove[j] = 1 | |
else: | |
isRemove[i] = 1 | |
# print("IoU", abs(IoU(bbox1, bbox2))) | |
if list_objects[i][4] < 0.4: | |
isRemove[i] = 1 | |
if list_objects[j][4] < 0.4: | |
isRemove[j] = 1 | |
selected_list = [] | |
for i in range(len(list_objects)): | |
if isRemove[i] == 0: | |
selected_list.append(list_objects[i]) | |
for i in selected_list: | |
if i[5] == 1: | |
incorrect += 1 | |
elif i[5] == 2: | |
withmask += 1 | |
elif i[5] ==3: | |
withoutmask += 1 | |
total_people += incorrect + withmask + withoutmask | |
img = cv2.imread(img) | |
for i in selected_list: | |
if i[5] == 1: | |
color = (255, 0, 0) | |
text = "Mask weared incorrect" | |
elif i[5] == 2: | |
color = (0, 255, 0) | |
text = "With mask" | |
elif i[5] == 3: | |
color = (0, 0, 255) | |
text = "Without mask" | |
text += ": " + str(round(i[4], 2)) | |
x1, y1 = i[0], i[1] | |
x2, y2 = i[2] - 1, i[3] - 1 | |
x1, y1, x2, y2 = round(x1), round(y1), round(x2), round(y2) | |
img = cv2.rectangle(img, (x1, y1), (x2, y2), color, 3) | |
img = cv2.putText(img, text, (x1, y1-10), cv2.FONT_HERSHEY_SIMPLEX, 0.7, color, 2) | |
output ="result_demo.jpg" | |
return img, total_people, incorrect, withmask, withoutmask, time_mcs/1000 | |
st.title("Face Mask Detection App") | |
file_page, webcam_page, phonecam_page = st.tabs(["File", "Webcam", "Phone's camera"]) | |
with file_page: | |
inputimg_file = file() | |
if inputimg_file is not None: | |
st.image(cv2.cvtColor(inputimg_file, cv2.COLOR_BGR2RGB)) | |
frcnn, yolov3 = st.columns(2) | |
with frcnn: | |
result_rcnn, total, inc, withm, withoutm, time = detect('File', 'f') | |
st.image(cv2.cvtColor(result_rcnn, cv2.COLOR_BGR2RGB)) | |
st.write("Faster R-CNN") | |
st.write("Tổng số người có trong bức ảnh: ", total) | |
st.write("Tổng số người không đeo khẩu trang: ", withoutm) | |
st.write("Tổng số người đeo khẩu trang sai cách: ", inc) | |
st.write("Tổng số người đeo khẩu trang: ", withm) | |
st.write("Tỉ lệ số người không đeo khẩu trang: ", round(withoutm/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang sai cách: ", round(inc/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang: ", round(withm/total, 2)) | |
st.write("Thời gian thực thi (miliseconds): ", time) | |
with yolov3: | |
result_yolov3, total, inc, withm, withoutm, time = detect('File', 'y') | |
st.image(cv2.cvtColor(result_yolov3, cv2.COLOR_BGR2RGB)) | |
st.write("YOLOv3") | |
st.write("Tổng số người có trong bức ảnh: ", total) | |
st.write("Tổng số người không đeo khẩu trang: ", withoutm) | |
st.write("Tổng số người đeo khẩu trang sai cách: ", inc) | |
st.write("Tổng số người đeo khẩu trang: ", withm) | |
st.write("Tỉ lệ số người không đeo khẩu trang: ", round(withoutm/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang sai cách: ", round(inc/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang: ", round(withm/total, 2)) | |
st.write("Thời gian thực thi (miliseconds): ", time) | |
with webcam_page: | |
inputimg_wc = webcam() | |
if inputimg_wc is not None: | |
st.image(cv2.cvtColor(inputimg_wc, cv2.COLOR_BGR2RGB)) | |
frcnn, yolov3 = st.columns(2) | |
with frcnn: | |
result_rcnn, total, inc, withm, withoutm, time = detect('Webcam', 'f') | |
st.image(cv2.cvtColor(result_rcnn, cv2.COLOR_BGR2RGB)) | |
st.write("Faster R-CNN") | |
st.write("Tổng số người có trong bức ảnh: ", total) | |
st.write("Tổng số người không đeo khẩu trang: ", withoutm) | |
st.write("Tổng số người đeo khẩu trang sai cách: ", inc) | |
st.write("Tổng số người đeo khẩu trang: ", withm) | |
st.write("Tỉ lệ số người không đeo khẩu trang: ", round(withoutm/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang sai cách: ", round(inc/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang: ", round(withm/total, 2)) | |
st.write("Thời gian thực thi (miliseconds): ", time) | |
with yolov3: | |
result_yolov3, total, inc, withm, withoutm, time = detect('Webcam', 'y') | |
st.image(cv2.cvtColor(result_yolov3, cv2.COLOR_BGR2RGB)) | |
st.write("YOLOv3") | |
st.write("Tổng số người có trong bức ảnh: ", total) | |
st.write("Tổng số người không đeo khẩu trang: ", withoutm) | |
st.write("Tổng số người đeo khẩu trang sai cách: ", inc) | |
st.write("Tổng số người đeo khẩu trang: ", withm) | |
st.write("Tỉ lệ số người không đeo khẩu trang: ", round(withoutm/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang sai cách: ", round(inc/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang: ", round(withm/total, 2)) | |
st.write("Thời gian thực thi (miliseconds): ", time) | |
with phonecam_page: | |
inputimg_pc = phonecam() | |
if inputimg_pc is not None: | |
st.image(cv2.cvtColor(inputimg_pc, cv2.COLOR_BGR2RGB)) | |
frcnn, yolov3 = st.columns(2) | |
with frcnn: | |
result_rcnn, total, inc, withm, withoutm, time = detect('Phone', 'f') | |
st.image(cv2.cvtColor(result_rcnn, cv2.COLOR_BGR2RGB)) | |
st.write("Faster R-CNN") | |
st.write("Tổng số người có trong bức ảnh: ", total) | |
st.write("Tổng số người không đeo khẩu trang: ", withoutm) | |
st.write("Tổng số người đeo khẩu trang sai cách: ", inc) | |
st.write("Tổng số người đeo khẩu trang: ", withm) | |
st.write("Tỉ lệ số người không đeo khẩu trang: ", round(withoutm/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang sai cách: ", round(inc/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang: ", round(withm/total, 2)) | |
st.write("Thời gian thực thi (miliseconds): ", time) | |
with yolov3: | |
result_yolov3, total, inc, withm, withoutm, time = detect('Phone', 'y') | |
st.image(cv2.cvtColor(result_yolov3, cv2.COLOR_BGR2RGB)) | |
st.write("YOLOv3") | |
st.write("Tổng số người có trong bức ảnh: ", total) | |
st.write("Tổng số người không đeo khẩu trang: ", withoutm) | |
st.write("Tổng số người đeo khẩu trang sai cách: ", inc) | |
st.write("Tổng số người đeo khẩu trang: ", withm) | |
st.write("Tỉ lệ số người không đeo khẩu trang: ", round(withoutm/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang sai cách: ", round(inc/total, 2)) | |
st.write("Tỉ lệ số người đeo khẩu trang: ", round(withm/total, 2)) | |
st.write("Thời gian thực thi (miliseconds): ", time) | |