add detector processes

This commit is contained in:
Blake Blackshear 2020-11-01 09:56:33 -06:00
parent 36fbedab20
commit 514036f9d1
2 changed files with 37 additions and 9 deletions

View File

@ -1,18 +1,25 @@
import faulthandler; faulthandler.enable()
import os import os
import json import json
import yaml import yaml
import multiprocessing as mp import multiprocessing as mp
from playhouse.sqlite_ext import * from playhouse.sqlite_ext import *
from typing import Dict, List
from frigate.config import FRIGATE_CONFIG_SCHEMA from frigate.config import FRIGATE_CONFIG_SCHEMA
from frigate.edgetpu import EdgeTPUProcess
from frigate.http import create_app from frigate.http import create_app
from frigate.models import Event from frigate.models import Event
from frigate.mqtt import create_mqtt_client from frigate.mqtt import create_mqtt_client
class FrigateApp(): class FrigateApp():
def __init__(self, stop: mp.Event): def __init__(self):
self.stop = stop self.stop_event = mp.Event()
self.config = None self.config: dict = None
self.detection_queue = mp.Queue()
self.detectors: Dict[str: EdgeTPUProcess] = {}
self.detection_out_events: Dict[str: mp.Event] = {}
self.detection_shms: List[mp.shared_memory.SharedMemory] = []
def init_config(self): def init_config(self):
config_file = os.environ.get('CONFIG_FILE', '/config/config.yml') config_file = os.environ.get('CONFIG_FILE', '/config/config.yml')
@ -50,7 +57,18 @@ class FrigateApp():
) )
def start_detectors(self): def start_detectors(self):
pass for name in self.config['cameras'].keys():
self.detection_out_events[name] = mp.Event()
shm_in = mp.shared_memory.SharedMemory(name=name, create=True, size=300*300*3)
shm_out = mp.shared_memory.SharedMemory(name=f"out-{name}", create=True, size=20*6*4)
self.detection_shms.append(shm_in)
self.detection_shms.append(shm_out)
for name, detector in self.config['detectors'].items():
if detector['type'] == 'cpu':
self.detectors[name] = EdgeTPUProcess(self.detection_queue, out_events=self.detection_out_events, tf_device='cpu')
if detector['type'] == 'edgetpu':
self.detectors[name] = EdgeTPUProcess(self.detection_queue, out_events=self.detection_out_events, tf_device=detector['device'])
def start_detection_processor(self): def start_detection_processor(self):
pass pass
@ -75,10 +93,20 @@ class FrigateApp():
self.start_camera_capture_processes() self.start_camera_capture_processes()
self.start_watchdog() self.start_watchdog()
self.flask_app.run(host='0.0.0.0', port=self.config['web_port'], debug=False) self.flask_app.run(host='0.0.0.0', port=self.config['web_port'], debug=False)
self.stop()
def stop(self):
self.stop_event.set()
for detector in self.detectors.values():
detector.stop()
while len(self.detection_shms) > 0:
shm = self.detection_shms.pop()
shm.close()
shm.unlink()
if __name__ == '__main__': if __name__ == '__main__':
# register stop handler frigate_app = FrigateApp()
stop_event = mp.Event()
frigate_app = FrigateApp(stop_event)
frigate_app.start() frigate_app.start()
# main()

View File

@ -99,7 +99,7 @@ class LocalObjectDetector(ObjectDetector):
return detections return detections
def run_detector(detection_queue, out_events: Dict[str, mp.Event], avg_speed, start, tf_device): def run_detector(detection_queue: mp.Queue, out_events: Dict[str, mp.Event], avg_speed, start, tf_device):
print(f"Starting detection process: {os.getpid()}") print(f"Starting detection process: {os.getpid()}")
listen() listen()
frame_manager = SharedMemoryFrameManager() frame_manager = SharedMemoryFrameManager()