NEWS
Personenerkennung: Aufruf Linux Script mit Parameter
-
@uwe72 Problem verstanden
Wenn du das "Programm" in einem Screen laufen lässt? Dann wartet der Screen auf die Eingabe des Dateinamens. Dann könntest du den Dateinamen per JS an den Screen schicken. -
@SBorg Kannst Du mir hier noch bitte 2-3 Sätze schreiben, was meinst Du mit Screen? Bin nicht der Held in Linux. Bzw. habe nun mal nach screen gegoogelt. Werde ich mir mal anschauen. Danke!
-
Gelöscht
-
@uwe72 Kein Problem, mag nur nicht unnütz eine Litanei schreiben wenn mein "Gegenüber" ev. nur einen Denkanstoß benötigte
Du öffnest testweise mal zwei Sessions mittels putty oä.
In die #2 gibst du einscreen -S test
und dann einfachdate
(aber diesmal ohne ENTER, der Cursor soll einfach hinter "date" stehen bleiben)
In die #1 nunscreen -S test -X stuff $'\n'
Du siehst was in #2 passiert istDu musst also in #2 nur dein Programm starten damit es auf die Bildeingabe wartet, dann kannst du #2 schließen (nicht per exit beenden, sonst wird auch der Screen geschlossen! )
In #1 wird dann mittelsscreen -S test -X stuff $'bild.jpg\n'
bild.jpg (\n ist der Code für ein ENTER) an #2 geschickt der es verarbeitet. "test" würde ich dann natürlich noch aussagekräftiger benennen. Wenn das soweit klappt musst du nur noch den Teil "Screen #2 mit 'Programm' starten" automatisieren, damit es auch automatisch nach einem Reboot wieder läuft
btw: mittels screen -ls kannst du dir alle geöffneten Screens anschauen
-
@SBorg Danke!!
Das klingt schon ein mal sehr vielversprechend. Funktioniert grundsätzlich auch:
Ich muss nun nur schauen, wie ich an das Ergebnis komme, denn das steht ja eigentlich in #2. ggf. lässt sich diese aber auch in eine Datei ausleiten.
-
-
@SBorg es funktioniert nun alles. Habe es so hingekriegt, dass es grundsätzlich funktioniert.
Gebe den Consolenoutput noch in eine Datei aus.
Diese Datei kann ich in iobroker wieder einlesen um an das Ergebnis (der Bildanalyse) zu kommen.
Muss mal schauen, was ich noch optimieren kann. Beispielsweise ohne den Umweg über die Datei zu gehen.
Danke auf alle Fälle!!
-
@uwe72 sagte in Personenerkennung: Aufruf Linux Script mit Parameter:
Beispielsweise ohne den Umweg über die Datei zu gehen.
Würde ich eigentlich als Parameter "-Q" verstehen, habe ich aber bis dato nicht hinbekommen.
-
@uwe72 sagte in Personenerkennung: Aufruf Linux Script mit Parameter:
Aber wie gesagt, weiß ich nicht wie ich nun laufend die Bilder übergeben kann.
Wenn es lokal läuft, kannst du mit dem
child_process
-Module undexec
einen Prozess starten und instdin
schreiben:
https://nodejs.org/api/child_process.html#child_process_subprocess_stdin
Das entspricht einer manuellen Eingabe auf der Konsole.Gebe den Consolenoutput noch in eine Datei aus.
Diese Datei kann ich in iobroker wieder einlesen um an das Ergebnis (der Bildanalyse) zu kommen.Und da kommst du über
stdout
dran. -
@AlCalzone mit "lokal" meinst Du, die "Bilderkennungssoftware" und "iobroker" laufen auf dem selben "Rechner"?
-
@uwe72 genau
-
Danke Euch beiden mal @SBorg @AlCalzone !!
Hab schon ein mal dank Euch dazu gelernt. Bin noch nicht ganz am Ziel, aber Bauchgefühl, sollte vollends möglich sein.
@AlCalzone: Hab die Sachen auf unterschiedlichen Rechnern. Da kann und möchte ich auch nichts ändern. iobroker läuft auf einem leistungsstarkem NUC und die Bilderkennung auf einem Jetson Nano.
@SBorg Läuft grundsätzlich, nur komme ich noch nicht an den Konsolenoutput ran von #2. Versuche gerade, dass #2 die Konsole in eine Datei schreibt. Über NFS-Server-/Client lese ich im iobroker den Inhalt ein. Das ist noch ein wenig umständlich und #1 liest schneller ein als #2 schreibt. Kann zwar ein timeout vor dem einlesen einbauen, aber da verliere ich auch Zeit. Ist alles noch ein wenig "umständlich"
Aber ich gebe noch nicht auf
-
@uwe72 Ich habe das hier gefunden, was ähnlich aussieht wie der Code in deinem ursprünglichen Code:
https://stackoverflow.com/a/51886884/10179833Du kannst also auch per SSH in stdin schreiben und aus stdout lesen.
-
@AlCalzone Sehr gut! Danke schon einmal. Werde ich mir heute Abend anschauen!
-
Kam etwas heraus?
Schafft der Jetson Nano auch mehrere Kameras(-Bilder) nach Objekten/Personen überwachen? -
@Solear Nein das schafft er nicht.
habe nun 2 jetson nano. auf einem läuft die personenerkennung der Haustüre-Kamera.
Beim 2. Jetson Nano laufen nacheinander die Erkennung von 3 weiteren Kameras aus dem Gartenbereich. aber eben sequentiell. Das reicht mir trotzdem noch.
Eine Detection dauert ca. 475ms.
Habe noch ein Restproblem. Ab und zu schafft mein iobroker nicht das Bild von der Kamera zu holen, sieht man an den Stellen wo der Bereich unter der roten Linie liegt. Das muss ich noch irgendwie lösen. Aber insgesamt läuft es gut.
-
@uwe72 kannst du das Ganze etwas mehr erläutern? Momentan nutze ich Zoneminder für die Personenerkennung in einem LXC Container. Die Erkennung Zoneminder -> iobroker ZM Adapter -> Telegram Nachricht ist aber "relativ" langsam. Die Personenerkennung an sich ist recht schnell, nur bis der ZM Adapter es mitbekommen hat und ich eine Nachricht bekomme, dauert recht lange.
Du nutzt also ein Script/Programm für die Erkennung, die auf einem Jetson Nano läuft richtig? Würdest du das Programm bereitstellen? -
@coyote helfe gerne weiter (soweit ich das kann), habe nur gerade wenig Zeit.
Basis für alles ist die reine PErsonenerkennung auf dem Jetson Nano unter Linux. Habe mich da an dem orientiert.
https://pjreddie.com/darknet/install/In Iobroker rufe ich dann per Script "jede Sekunde" die Personenerkennung auf dem jetson auf. Verbinde mich dazu per Script auf den Jetson auf die Konsole und "schreibe da" programmatisch den "Befehl" zur Personenerkennung und übergebe dabei das kurz zuvor neue geladene Bild von der Kamera. Dann lese ich programmatisch die Konsole aus und schaue ob eine Person dabei war. Falls ja, starte ich nachfolgende Aktionen (Ausgabe Alexa, Senden Bild nach Telegram, Ablage Bild Server,...)
Das mal grobe Vorgehensweise.
VT der Lösung: Man bekommt Alarme ohne Bewegungsmelder
NT der Lösung: Bauchschmerzen habe ich, da jede Sekunde was auf die Festplatte (SSD) geschrieben wird, dass diese bald defekt wird?!Kannst Du noch 2-3 Sätze zu Zoneminder schreiben? Vielleicht ist dies ja sogar die bessere Alternative, die ich nicht kannte. Auf welcher Basis erfolgt eine Personenerkennung bzw. Alarmerkennung? Reiner Bildvergleich?
-
@uwe72 ok, schaue ich mir mal an.
Zu Zoneminder und ZMEventnotification schau mal hier: https://zmeventnotification.readthedocs.io/en/latest/guides/hooks.html
Dort ist alles gut erklärt. War meiner Meinung nach ein langer Installationsprozess, aber funktioniert. Hätte es nur gerne etwas schneller, aber ich denke das liegt eher an Zoneminder -> iobroker ZMAdapter.
Erkennung läuft bei Zoneminder auch mit OpenCV, aber wie genau die Erkennung funktioniert bzw ob es reiner Bildvergleich ist, kann ich dir gerade nicht sagen -
@coyote Danke dir. Habe nur mal ganz schnell drüber gescrollt. Vielleicht ist dein Weg sogar der bessere. Ich schaue mir dies definitv mal an! Kannte ich nicht bis jetzt.