From 6c70e560598c46f708739c03c041f38aba9f4672 Mon Sep 17 00:00:00 2001 From: Josh Hawkins <32435876+hawkeye217@users.noreply.github.com> Date: Sun, 20 Oct 2024 15:14:51 -0500 Subject: [PATCH] Misc bugfixes and improvements (#14460) * only save a fixed number of thumbnails if genai is enabled * disable cpu_mem_arena to save on memory until its actually needed * fix search settings pane so it actually saves to the config --- frigate/embeddings/maintainer.py | 18 ++++++++++++++++++ frigate/util/model.py | 8 +++++++- web/src/views/settings/SearchSettingsView.tsx | 5 ++++- 3 files changed, 29 insertions(+), 2 deletions(-) diff --git a/frigate/embeddings/maintainer.py b/frigate/embeddings/maintainer.py index c7060b9a6..7ce63e7f8 100644 --- a/frigate/embeddings/maintainer.py +++ b/frigate/embeddings/maintainer.py @@ -31,6 +31,8 @@ from .embeddings import Embeddings logger = logging.getLogger(__name__) +MAX_THUMBNAILS = 10 + class EmbeddingMaintainer(threading.Thread): """Handle embedding queue and post event updates.""" @@ -117,6 +119,15 @@ class EmbeddingMaintainer(threading.Thread): return camera_config = self.config.cameras[camera] + # no need to save our own thumbnails if genai is not enabled + # or if the object has become stationary + if ( + not camera_config.genai.enabled + or self.genai_client is None + or data["stationary"] + ): + return + if data["id"] not in self.tracked_events: self.tracked_events[data["id"]] = [] @@ -127,7 +138,14 @@ class EmbeddingMaintainer(threading.Thread): if yuv_frame is not None: data["thumbnail"] = self._create_thumbnail(yuv_frame, data["box"]) + + # Limit the number of thumbnails saved + if len(self.tracked_events[data["id"]]) >= MAX_THUMBNAILS: + # Always keep the first thumbnail for the event + self.tracked_events[data["id"]].pop(1) + self.tracked_events[data["id"]].append(data) + self.frame_manager.close(frame_id) except FileNotFoundError: pass diff --git a/frigate/util/model.py b/frigate/util/model.py index 685cd34ec..b1c85b100 100644 --- a/frigate/util/model.py +++ b/frigate/util/model.py @@ -85,8 +85,14 @@ class ONNXModelRunner: else: # Use ONNXRuntime self.type = "ort" + options = ort.SessionOptions() + if device == "CPU": + options.enable_cpu_mem_arena = False self.ort = ort.InferenceSession( - model_path, providers=providers, provider_options=options + model_path, + sess_options=options, + providers=providers, + provider_options=options, ) def get_input_names(self) -> list[str]: diff --git a/web/src/views/settings/SearchSettingsView.tsx b/web/src/views/settings/SearchSettingsView.tsx index a08816675..e00201946 100644 --- a/web/src/views/settings/SearchSettingsView.tsx +++ b/web/src/views/settings/SearchSettingsView.tsx @@ -84,7 +84,10 @@ export default function SearchSettingsView({ axios .put( - `config/set?semantic_search.enabled=${searchSettings.enabled}&semantic_search.reindex=${searchSettings.reindex}&semantic_search.model_size=${searchSettings.model_size}`, + `config/set?semantic_search.enabled=${searchSettings.enabled ? "True" : "False"}&semantic_search.reindex=${searchSettings.reindex ? "True" : "False"}&semantic_search.model_size=${searchSettings.model_size}`, + { + requires_restart: 0, + }, ) .then((res) => { if (res.status === 200) {