NEWS
G-Tag, IBeacon, Anwesenheitserkennung
-
@maik-0
Ah ich glaube jetzt verstehe ich erst die Logik von deinem Script. Gerade weil es nicht mehr aktualisiert wird, wird auf abwesend geschaltet. -
@marsmännchen
Genau, wenn der Wert 60 Sekunden nicht mehr aktualisiert wird, schaltet es auf Abwesenheit. Kann sein, das 60 Sekunden etwas knapp ist. Musst du vieleicht etwas höher setzen. -
@maik-0
Is natürlich die schönere Lösung als meine hilflose Zauberei.
Werd das gleich mal abpausen. Vielen Dank -
@Maik-0
Sorry will nicht nerven, aber:
Wenn ich, wie gerade eben, nicht anwesend bin, dann wird der Baustein ja nicht aktualisiert.
Wenn der Baustein nicht aktualisiert wird, schaltet die untere "falls-mache ->auf abwesend" überhaupt?Ab wann wird eigentlich aktualisiert?
Hintergrund ist nämlich das mein Status sich ändert obwohl nicht daheim, und "RSSI (null)db" ist.
Vielleicht hast du in der Yaml vom ESP32 was besseres stehen?Wie kann DAS sein?
im debug-log bekomme ich die Variable (roter Kreis) mit "false"
Und bei den Objekten schaltet der Datenpunkt (blauer Kreis) auf "true"!
Wo hab ich da was übersehen..... mal wieder.
Ich vermute weil der ESP32 auch meine Abwesenheit in form von "NaN" sendet.
Ok.bin scheinbar schon zu blöd zum abschauen... Erinnert mich an meine Schulzeit.
Hab glatt was vergessenGut, jetzt hab ich auch rausgefunden womit es zu tun hat.
Wenn der ble_tracker vom ESP32[16:35:10][D][sensor:113]: 'PatrickNut': Sending state nan dB with 0 decimals of accuracy
Sendet, wird logischerweise aktualisiert, und ich bin anwesend.
-
@marsmännchen
Unschön ist natürlich wenn das Script zum ersten Mal gestartet während du nicht zu hause bist, passiert nichts. Bis zum ersten Kontakt zum Beacon.
Dann würde ja beim weggehen der Timeout greifen.
Wenn sich aber dein Status ändert während du abwesend bist,
müsste ja auch ohne Kontakt zum Beacon der rssi Wert aktualisiert werden.
Das ist bei mir nicht der Fall. Etwas merkwürdig.
Alternativ wäre auch es auch noch möglich das über den ESPHome Presence Melder zu machen.
https://www.esphome.io/components/binary_sensor/ble_presence.html -
@maik-0
Ja, is scheinbar wirklich so, das er trotzdem ab und zu "state nan" sendet.
ich versuche das mit:Solch einem Konstrukt zu verhindern. mal sehn was passiert.
Sonst versuche ich mal ble_presence -
@marsmännchen
Du solltest aber den „stop timeout“ noch verschieben. Als ersten Befehl in
deine eingefügte if-Abfrage. Sonst stoppt er auch den timeout auch wenn
„state nan“ kommt. -
Hi
bin aktuell auf der Suche nach einer besseren Anwesenheitserkennung da die Smartphones (Android) über Wlan und TR064 teilweise erst nach >10Minuten erkannt werden, da die Geräte sich erst dann einloggen. Das ist für mich keine gute Lösung.Ihr habt jetzt viel mit den G-Tags getestet. Seit ihr damit zufrieden?
Bei der Lösung stelle ich mir andauernd die Frage ob man dies nicht über das Handy lösen kann (Bluetooth BLE)? Im Zug von Corona App etc. ist diese Funktion der Smartphones sehr aktuell und senden die nicht auch dauernd ohne Energiesparmodus Signale über BLE um sich zu erkennen zu geben?
-
@dieter_p Also wie du eine Unterhaltung weiter oben sehen kannst habe ich jetzt am Schlüsselbund einen beacon(heisst nut beacon) und in der Nähe der eingangstüre einen esp32 mit externer Antenne. Ich muss sagen das ist für mich die optimale Lösung. Erkennt zuverlässig und schnell. Soweit meine Erfahrung.
-
@marsmännchen
Danke fürs Feedback. Habe hier jetzt auch ein paar Beacons bestellt und einen ESP32. Damit wollte ich mal testen. Falls ich es noch sinnvoll schaffe die Smartphones auch mit zu scannen, kann eine redundante Lösung ja nicht schaden.Welche Software verwendest Du auf dem ESP32? Ich finde sehr viele Skripte und Github-Code. Bin da nicht so ein großer Freund und würde lieber eine ständig gepflegte Lösung verwenden. Glaube gelesen zu haben, dass Tasmota für diesen Zweck auch möglich ist?
Welche Reichweiten schaffst Du bei Dir um die Beacons zu erkennen und welche maximale Zeitverzögerung hast Du um gesichert Anwesenheit erkennen zu können?
Dein blockly oben deutet auf 60 Sekunden hin.
Würde ungern den Alarm der Alarmanlage noch länger verzögern. -
@dieter_p ich verwende esphome Adapter, die Reichweite ist so ca. 20meter.esp32 ist im innenraum, Eingangs Bereich. Die Zeit von 60sekunden ist ausreichend für mich. Habe noch nicht daran rumgespielt.Das auslesen des Handys mit Bluetooth stell ich mir mit esphome nicht viel anders vor, brauchst nur die Mac Adresse des Bluetooth.
-
@marsmännchen
Danke. Das klingt vielversprechend und wäre genau das was ich suche. -
Habe nun erste Versuche mit ESP32 und ESPHome gemacht aber scheine da noch ein Format Verständnis Problem zu haben. Meine Beacons sind noch nicht da aber auch sonst wäre die Android App "Beacon Simulator" eine schöne dauerhafte Ergänzung.
Kann mir jemand sagen was hier mit der UUID eines iBeacon gemacht wird?
Über Online Converter (Hex zu String o.ä.) oder die verschiedenen Typen UUID vs. GUID etc. bin ich nicht schlau draus geworden:Im Simulator/App benutzt:
Im Code von ESPHome jedoch so detektiert:
esp32_ble_tracker: on_ble_advertise: - then: # - if: # condition: # lambda: |- # for (auto data : x.get_manufacturer_datas()) { # return (strcmp(hexencode(data.data).c_str(), "02.15.2B.9E.6A.0A.14.92.41.74.AC.06.26.7B.BB.4B.B0.50.00.00.00.00.BF (23)") == 0); # } # return false; # then: - lambda: |- ESP_LOGD("ble_adv", "New BLE device"); ESP_LOGD("ble_adv", " rssi: %d", x.get_rssi()); ESP_LOGD("ble_adv", " Advertised manufacturer data:"); for (auto data : x.get_manufacturer_datas()) { ESP_LOGD("ble_adv", " - %s", hexencode(data.data).c_str()); if (strcmp(hexencode(data.data).c_str(), "02.15.2B.9E.6A.0A.14.92.41.74.AC.06.26.7B.BB.4B.B0.50.00.00.00.00.BF (23)") == 0) { ESP_LOGD("ble_adv", "in if"); } }
Oder kurz: wie wird aus iBeacon UUID:
2b9e6a0a-1492-4174-ac06-267bbb4bb050
02.15.2B.9E.6A.0A.14.92.41.74.AC.06.26.7B.BB.4B.B0.50.00.00.00.00.BF
Thx!
-
Lange rumprobiert und nun ist es nutzbar. Für Interessierte:
Der Code oben scheint mir nur bestimme Bestandteile des Bluetooth BLE Datenpakets auszufilter.
Nutzt man als Beispiel diesen Code in ESPHome:
esp32_ble_tracker: on_ble_advertise: - then: - lambda: |- bool redmi_note_9_pro_status = false; for (auto data : x.get_manufacturer_datas()) { if (strcmp(hexencode(data.data).c_str(), "02.15.49.01.F3.6B.E9.1A.44.B7.B3.62.FF.2E.B6.43.05.04.00.00.00.00.BF (23)") == 0) { ESP_LOGD("ble_adv", "redmi_note_9_pro found"); redmi_note_9_pro_status = true; } ESP_LOGD("ble_adv", " - %s", hexencode(data.data).c_str()); } id(redmi_note_9_pro).publish_state(redmi_note_9_pro_status); binary_sensor: - platform: template device_class: presence name: "Redmi Note 9 Pro BLE presence" id: redmi_note_9_pro filters: - delayed_off: 3s
Bekommt man im Logging Fenster viel mehr Informationen wie Manufacturer DATA wenn man mit der App Beacon Simulator sendet, aber auch die änderbare UUID. ACHTUNG! im Logging Fenster ist die UUID in umgekehrter Reihenfolge geschrieben!
[13:37:18][VV][esp32_ble_tracker:493]: Parse Result: [13:37:18][VV][esp32_ble_tracker:510]: Address: 5C:86:26:05:12:C0 (RANDOM) [13:37:18][VV][esp32_ble_tracker:512]: RSSI: -83 [13:37:18][VV][esp32_ble_tracker:513]: Name: '' [13:37:18][VV][esp32_ble_tracker:527]: Manufacturer data: 02.15.B3.6E.AB.BD.56.CA.48.6E.9E.F4.C9.2D.AC.F7.9B.5F.00.00.00.00.BF (23) [13:37:18][VV][esp32_ble_tracker:530]: iBeacon data: [13:37:18][VV][esp32_ble_tracker:531]: UUID: 5D9BF7AC-2DC9-F49E-6E48-CA56BDAB6EB3 [13:37:18][VV][esp32_ble_tracker:532]: Major: 0 [13:37:18][VV][esp32_ble_tracker:533]: Minor: 0 [13:37:18][VV][esp32_ble_tracker:534]: TXPower: -65 [13:37:18][VV][esp32_ble_tracker:543]: Adv data: 1A.FF.4C.00.02.15.B3.6E.AB.BD.56.CA.48.6E.9E.F4.C9.2D.AC.F7.9B.5F.00.00.00.00.BF (27) [13:37:18][D][ble_adv:070]: google_pixel_4a found [13:37:18][D][ble_adv:073]: - 02.15.B3.6E.AB.BD.56.CA.48.6E.9E.F4.C9.2D.AC.F7.9B.5F.00.00.00.00.BF (23)
So lässt sich mit diesem Code die richtigen "IDs" für das eigene Telefon finden und dann der Code in ESPHome anpassen, dass dort bei Präsenz der Datenpunkt in IObroker auch gesetzt wird.
Jetzt noch etwas mit der Delay_Off Zeit spielen, damit es weniger sensibel reagiert.
-
@dieter_p
Ich beobachte das ESPHome AddOn für den ioBroker schon lange bei Github, jedoch ist es bisher noch nicht in den "Stable"-Modus gewechselt, damit es im AddOn-Reporisitory auftaucht. Eine Anfrage über GitHub beim Entwickler ergab die Antwort, das er da noch zwei Änderungen machen muss und das war bereits vor einem Jahr. Direkt wollte ich mir das AddOn on Github nicht installieren, da ich mir mit sowas schon mal die aktuelle Produktivumgebung zerschossen hatte.Solange also das AddOn nicht regelmäßig gepflegt wird, behelfe ich mich selber mit Tasmota und einem ESP32, um die G-Tags zu tracken, funktioniert auch bisher ganz praktikabel in Kombination ioBroker ...
-
viele Wege führen nach Rom....
Mindestens seit Jan 2022 läuft das bei mir absolute Problemlos. Habe inzwischen auch klare Favoriten bei den Beacons gefunden. Bei den G-Tags konnte ich nie finden was drinsteckt und Nordic Data (nrf... Chips) Versionen haben mich im Vergleich bzgl. Batterielaufzeit nicht überzeugt und mit voller Sendeleistung ist der Feasycom FSC-BP103B mit Dialog Semiconductor Chip mein Favorit.
Bzgl. ESPHome bin ich nicht wirklich von der Implementierung angetan. Mir kommt das bzgl. installation mit benötigtem Python sehr "zusammengebastelt" vor, dass ich als Nichtwissender bei kleinsten Abweichungen schnell in Sackgassen laufe. Entsprechend stört mich auch, das im Fall von Updates für eines dieser Komponenten schon das ganze Konstrukt ins Wanken geraten kann. Ist halt irgendwie nicht "aus einem Guss" die ESPHome IOBroker Integration wie ich sie empfinde. Deswegen habe ich auch meine weiteren bestehenden ESPs auf ESPEasy weiter gelassen, da dies absolute gut läuft. ESPEasy war nur bzgl. BLE Erkennung schwierig etwas zu finden und dort umzusetzen.
-
Hallo zusammen
Ich habe da eine Frage zu den Einstellungen.
Meine iobroker installation habe ich von der Synology VM auf Proxmox umgezogen. Das ganze läuft dort auf einer VM unter Ubuntu. Irgendwie zickt seit daher der Radar2.0 Adapter.Ich benutze einen USB Dongle , diese tracken meinen Gigaset G-Tag.
Was muss ich bei den Einstellungen anwählen?
- hcitool lescan anstelle von "Noble" verwenden
Muss ich diese Option anwählen oder nicht?
Irgendwie geht es mit beiden, jedoch läuft es nicht so zuverlässlich. -
@dieter_p
Moin,
habe gerade folgende Aufgabe:
Momentan nutze ich homee, die Anwesenheit wird mir von einem Raspi-Z mit einer BLE-Software geliefert.
Als Beacons nutze ich die bekannten Gtags und bin eigentlich sehr zufrieden mit der Erkennung.
Nun bin ich auf homey umgestiegen der eigentlich BT on Board hat und auch eine App für die Presencemeldung via Beacons.
Meine Gtag funktionieren soweit - Aaaaber der homey hängt nicht so günstig wie der Raspi und soll wohl auch nicht so gut mit dem BT-Empfang sein (Ist aber ein Raspi CM4 drin).
Den homey kann ich leider nicht anders platzieren.
Also entweder ich besorge mir mal andere Beacons - der von dir erwähnte FSC-BP103B??
Ist der Empfang wirklich besser als der Gtag ?
Oder ich stelle meinen IOBroker an die Stelle wo der Raspi-Z steht und mache gleich die Presence-Geschichte darüber. Wäre dann ein Gerät weniger.
Wie funktioniert denn eigentlich der Radar2 - Adapter?
Ich muß für An und Abmeldung ein Webhook an den homey senden - geht das??
Danke für die Antwort - Grüße -
@friedhofsblond said in G-Tag, IBeacon, Anwesenheitserkennung:
@dieter_p
Also entweder ich besorge mir mal andere Beacons - der von dir erwähnte FSC-BP103B??
Ist der Empfang wirklich besser als der Gtag ?Den Direktvergleich habe ich wegen mangelnder G-Tags nie durchgeführt.
Ich hatte und habe nur den Eindruck, dass der verbaute DA14531 Chipsatz wirklich wie beworben sehr stromsparend ist.
Über die Konfiguration lässt sich auch die Sendeleistung bis 2dBm maximal einstellen. Für meine Zwecke war das ok/gut und liefert auch bessere Empfangswerte bei meinem Scanner/Empfänger.
Da das für mich aber alles "Feldversuche" sind bin ich sehr vorsichtig mit repräsentativen Aussagen.Mein FSC-BP103B ist aktuell auch nicht mehr in Betrieb und wurde gegen FSC-BP108 getauscht.
Als Problemquelle hat sich aber Mitlerweile der eingebaute PushButton herausgestellt. Drückt man den zu lange unbeabsichtigt, geht der Beacon aus. Das passiert am Schlüsselbund doch recht einfach. Hab den Push-Buttons nun Innen mit gerolltem Isolierband mechanisch "gesperrt" und seitdem funktioniert alles tip top.Den Radar2-Adapter habe ich mal kurz getestet, funktionierte aber da mein RPI örtlich nicht optimal steht, scanne ich lieber mit einen ESP32 direkt vor Ort und das klappt nun wieder einwandfrei!
-
@dieter_p sagte in G-Tag, IBeacon, Anwesenheitserkennung:
FSC-BP108
Moin,
Danke für den Bericht.
Wo hast du die Beacons bestellt - ich habe nur China gefunden ??
Ich wollte erstmal versuchen homey nativ mit einem stärkeren Beacon zu verbinden.
Ansonsten Plan B über den ioserver - da gibts aber auch wieder Baustellen mit dem NUC usw...PS: Die Gtags haben einen DA14580 Bluetooth Low Energy 4.2 SoC, die FSC einen DA14531 Ultra Low Power Bluetooth 5.1 SoC