-
Notifications
You must be signed in to change notification settings - Fork 121
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Frigate reports incorrect occupancy in Home Assistant after restart #662
Comments
This is because the state is not retained which is not incorrect because otherwise you'd have the opposite problem - an object would show occupancy even if frigate wasn't running |
Sorry, maybe I'm not understanding. But Frigate is detecting an occupancy, the Add On says Clear. That is not the correct state.
That problem already exists in the current implementation. When frigate isn't running it is reporting Clear by default even if it's not actually clear. It's the opposite side of the coin, but still essentially the same issue. If Frigate isn't running, then I would expect the state should be Unavailable. I won't pretend to know what the solution is, but it is definitely reporting a state that is not the real, current state after a restart. When Home Assistant restarts, could Frigate re-send the current states to update the occupancy entities? |
To be clear I am saying retaining is not a solution because it would cause the other problem.
that would require frigate to be aware of home assistant and home assistant to communicate back to frigate which I am not sure is desirable. One solution might be to have an api in frigate that would send the current state for all objects. Then home assistant could call this api on startup to get its initial state. |
Yeah, that makes sense, I see what you mean now. I just implemented a workaround with an automation that triggers when Home Assistant starts. I have it publish an MQTT message to the frigate/restart topic. That works to newly detect all the objects and update the occupancy entities, but it takes extra time waiting for Frigate to start up. Not sure if there's an MQTT topic to request re-publishing of current states? If so, maybe that could automatically be published as part of the normal HACS Frigate Add On startup process so it stays in sync? And if there was a way to get the entities to show a state of Unavailable when Frigate isn't running, I think that would be ideal. I noticed the camera entities and sound levels already show Unavailable when Frigate is stopped. Maybe that could be extended to the occupancy entities, etc.? |
@NickM-27 I've been thinking about this some more, and am curious how all my other integrations maintain states after a restart. For example I have lots of sensors through zigbee2mqtt. When I restart home assistant my door sensors don't all default to reporting that they're open. My zwave locks don't default to reporting as unlocked. My Hue bulbs don't all default to showing an off state. Do other integrations retain messages? Or do they re-poll for states after restart? Are there plans for Frigate to do the same? |
Looks like zigbee2mqtt retains all their messages. Like I said I don't think that is a suitable solution for the way frigate works with mqtt. Object detection data is a lot more transient than the attributes of a zigbee device |
I see what you mean. Although, I will say that I am using object detection for things that are not transient, so it depends on the use case. Either way, I think occupancy sensors reporting accurate states after a restart would be a best practice. Is there a fix for this on the roadmap? |
There are a number of things that make the object count and occupancy sensors sub optimal currently. It will likely be rewritten and made better at some point, we are currently rewriting the frigate UI among many new features so I wouldn't expect this to be improved in 0.14 |
Understood. And thanks for being responsive and for all the work you do on this project - it's great stuff. I would definitely put my vote in for this to be moved up the priority list following the 0.14 release. These sensors get used in automations for many users and would love to see them fixed. |
@NickM-27 Thanks for an awesome 0.14 release! I wanted to check back on this issue. Is improving the way Frigate reports occupancy sensors so the state is accurate following a restart something that will be prioritized for the next major release? |
@soonerfan237 hey mate I'm definitely seeing this issue as well, thanks for raising it.
Mind sharing the automation/workaround for this? Would be good for myself/future travellers. |
@lucasteligioridis I changed the way I restart the add-on since I made that MQTT comment. Here's my current method. The automation triggers every time that Home Assistant starts. The action is "Home Assistant Supervisor: Restart add-on" with the Frigate add-on selected.
If you do want to use the MQTT method, here's the action section of the automation.
|
Thanks a heap @soonerfan237 |
Not sure if I can add this onto here or if I should open my own ticket but ever since 0.14 HA is falsely detecting occupancy in one of my zones while frigate does not have any events at the time stamps. Only at night it seems. We have our front doorbell camera set to go through our do not disturb if someone is at our front door...so 3+ false positives from HA with no video clips or recorded events is odd. I reviewed the footage at the timestamps in frigate. Looks like most of the timestamps was a car driving by on the road(it has been raining here so had some weird reflections. What I find odd is frigate did not even see this as a motion or detection event so I am not sure why HA thought is was worthy of an alert. |
@Nooton92 A couple days ago I got a notification that a person was detected in my house while I was away. My dog sometimes gets falsely detected as a person. So after I got home I went to send the false positive to Frigate+. But I never saw a detection/motion event in Frigate during that time. At the time, I figured it was just a random occurence, but now seeing your comment, there may be something more to it. Not sure how to reproduce it though. It could be that event thresholds set in yaml aren't being used the same in every part of the UI? If it happens again, I'll try to do some more digging. |
The occupancy sensors have less verification in order to be able to respond faster. This is working as expected. The /events or /reviews topic should be used for notifications |
@NickM-27 Interesting, didn't know that! Will switch to the /events topic going forward. Was this a recent change to occupancy sensors or has it always been like this? Can you expand the "less verification" comment? Is it bypassing threshold checks or something? |
No, this is how it has worked for quite a while |
Thanks! Is there documentation out there for what causes the occupancy sensors to be turned on? Or can you help me with an explanation? And follow up question - is the occupancy sensor behavior configurable? |
Good morning. I have also noticed that with the latest version of Frigate 0.14 and the version 5.3.0 of the integration, sometimes the "Occupancy Sensor" is activated but there is no recorded snapshot nor clip. With version 0.13 I had not experienced anything similar. Maybe it's just coincidence (?) but I see that other users report the same problem above. Inside the yard where the cameras are operating there is a big dog and sometimes Frigate recognizes him as a "person". But I don't have a snapshot to see exactly what has happened. |
There are a number of things that are different:
|
@NickM-27 following up on this topic.
I have switched my automations to use the /events topic, but I'm still getting notifications even when there are no detections seen in the Frigate UI. And I can confirm there was not actually a person within view of the camera. Here is my automation yaml. The trigger is an mqtt message on frigate/events. Then I have conditions to specify that it is a new detection. The object is a person. And the score is >=0.8. Am I making any errors here? My guess is that it's something to do with the minimum detection score, but I can't see what I'm missing.
|
we need to see the mqtt payload that triggered it to know why, but if I had to guess the object never moved which is a requirement for a snapshot, clip, review item to be saved |
I don't have the mqtt message saved. But my guess is that a shadow or something is getting detected and so its probably not moving. Is there an additional condition I can add to my automation to prevent it from triggering? |
you can check |
Thanks! I'll give that a shot. |
I came here looking for a bug and I think I found it 😅 Definitely there is something going on, today this issue happened to me (twice in 2 minutes, 7.13pm and 7.15pm), I got occupancy triggered in HA but nothing in Frigate's Review tab, this triggered the siren, alarming the neighborhood :P. There was no restart at all from any device. Running latest version of everything (HA and Frigate v0.14), I didn't run into this issue before (or if I got a falsy detection I was always able to see it on Frigate). I couldn't collect any MQTT log, I'll see if using /events I could fix it, wondering what Thanks! |
Wondering if there is a quick way to add a binary_sensor like |
I just wanted to jump back in this thread to say that I haven't had any more false triggers since adding the position_changes>0 condition to my automation. Although I agree with @gvillo that a simple binary_sensor that follows /events or /reviews would be the cleanest solution in the future. Here's my current automation yaml in case anyone wants to implement it on their side.
|
I would agree 100% with that: "a simple binary_sensor that follows /events or /reviews would be the cleanest solution in the future". In my case I take a different approach. I don't use the "position_changes>0" option but I look into the MQTT messages to see if Frigate has created a snapshot. So far it seems to be working οκ, but if anyone knows better I would like their opinion on the automation I am using:
|
@Belox86 > Hi everyone, going back to the original problem, i have a similar one. If i stop the frigate add-on from HA while is detecting one or more persons, when i start frigate again, the person count and occupancy sensors in HA are not cleared and retain the previous values. On the other hand, the "all count" and "all occupancy" are cleared. I'm using Frigate 0.14.0. Frigate is stopped by a script as follow (and started in the same way): I have exactly the same issue, anybody found a solution? |
I was trying to create my custom binary sensor but I couldn't make it work ok, hmmm wondering if Frigate can expose them based on mqtt events |
I once built a sensor as a template. In a quick test it worked.
|
Following because I just realized why my occupancy sensor was wrong so often as every restart of HA from a config change is clearing all of these. These object occupancy and object count sensors are useful but very unreliable. |
I ran into this issue last night. At some point, Frigate determined that there was motion on my back porch, so Home Assistant turned on the lights. Later Frigate stopped detecting motion, but for some reason, it seems that Home Assistant never picked up that message through MQTT (not sure if it was a failure of Frigate, MQTT or Home Assistant, it was 3AM and I wasn't about to go look into it). The end result is that the backyard lights never turned off. It seems like the issue here is that the messages for the status of the sensors is not retained in MQTT, because if Frigate went offline, the sensors would stick with their last status. This means that is Home Assistant fails to receive a message when it is sent, then the sensor state will become out of sync. There is no way (currently) for Home Assistant to tell Frigate to re-send all of it's statuses to fix this outside of either waiting for that particular sensor to change state again, or restarting Frigate. Neither of those are great options. The fix that I would propose covers a few changes that should result in a much more reliable situation for the integration sensors:
Thoughts? |
I don't think this makes sense because while they can be retained, they are still not necessarily correct if it is Frigate that changed not home assistant. It is just shifting the problem to a separate scenario.
Frigate does not update this topic when it stops, that is done by MQTT itself as a LWOT
this is already the case except it is not done before /available though I don't think that is important as /available is not used as the source of truth for all of the sensors availability. This would also not help the issue being discussed here where home assistant is restarted but Frigate is not
this already exists in Frigate as part of the recent UI rewrite and is most likely the solution that will be implemented as it will follow what the Frigate webUI already has implemented. |
This wouldn't fix things on it's own, but it would have to be done in conjunction with the other ideas to deal with the issue of the values being out of sync with reality.
That makes more sense! I forgot about MQTT LWOTs.
If the statuses are not being retained, then they don't need to be published before /available is updated, there is nothing there, so it's impossible for Home Assistant to have incorrect data at startup. As far as it being for when Frigate is restarted rather than when Home Assistant is restarted, that is true, but I was looking for ways to improve the overall reliability, not just one specific case.
This would be an easier solution, especially if that API endpoint already exists in Frigate. When this is implemented, can we have the interval that things are re-polled be configurable please? |
Version of the custom_component
5.1.0
Configuration
Describe the bug
The Frigate add on is not reporting the correct occupancy state after Home Assistant is restarted while an object is being tracked. For example, if Frigate is detecting a car in my garage, and then I restart Home Assistant, the occupancy sensor will become clear even though Frigate is still actively detecting the car in the garage. Here's a video showing the situation.
I think this is related to this issue:
#376
Debug log
The text was updated successfully, but these errors were encountered: