NEWS
Zählen eines Zustandes
-
@chris-1 sagte in Zählen eines Zustandes:
Seh ich das so richtig?
nein!
Du kannst alles in einem Skript machen.
nur nicht außerhalb des Triggerbausteins.@Codierknecht hat es korrekt gesagt.
Dein Skript meldet beim Start wegen deines ausgewählten Datenpunktes (DP) im Trigger beim iobroker Controller an, dass es von diesem über jede Änderung dieses DP informiert werden will.
DANN startet dein Trigger alles, was innerhalb des Triggerbausteins an Befehlen steht -
@chris-1 sagte in Zählen eines Zustandes:
Also viele viele "kurze" Skripts statt wenigen mit allen möglichen Fallunterscheidungen
Nicht unbedingt (eher gar nicht).
Du musst in Ereignissen denken. Man braucht 'ne Weile, bis man sich daran gewöhnt hat.
Der Dreh- und Angelpunkt ist eigentlich immer, den richtigen Trigger zu definieren. Der legt fest, zu welchem Zeitpunkt das Ganze überhaupt loslegt. Und das ist oft gar nicht so einfach.
Der Rest kommt dann innerhalb ... -
@chris-1 sagte in Zählen eines Zustandes:
Das irritiert mich jetzt
ich glaube das ist aber der Knackpunkt für dein (fehlendes) Verständnis für Javascript
-
@homoran Ich beginne ja gerade das System dahinter zu verstehen
Es ist keine andere Welt,
sondern nur ein anderer Ansatz -
@chris-1 sagte in Zählen eines Zustandes:
ist was für morgen
Vielleicht fällt uns bis dahin ja noch ein schöner Vergleich ein, an dem man event-driven-development irgendwie anschaulicher erklären kann
-
@codierknecht Ich glaube, ich habe dies, zumindest im Ansatz, bereits verstanden - danke
Anstatt in zyklischen Skripten zu denken,
reagiere ich auf einen Trigger A und setze zB X auf falseIn einem Andere Skript reagiere ich auf Trigger X und agiere dann abhängig davon, ob auf true oder false gesetzt/geändert/... wurde
-
@Codierknecht
@paul53
@HomoranFachfrage an die Experten.
Gibt es eine definierte Zeit (1ms….1sek….?) in der die Bedingungen erfüllt sein müssen ?
Beispiel , ein Blockly mit vielen Und / Oder Bedingungen. -
@haselchen Gemäß oben "gelerntem?" dürfte es keine bestimmte Zeit geben, da (erst) nach Abarbeitung alles unmittelbar ausgeführt wird.
-
@haselchen sagte in Zählen eines Zustandes:
Gibt es eine definierte Zeit (1ms….1sek….?) in der die Bedingungen erfüllt sein müssen ?
Beispiel , ein Blockly mit vielen Und / Oder Bedingungen.In meiner Welt (Windows) nicht.
Zumindest gibt es da keine "vorgegebene" Zeit.
Ist natürlich auch ein bisschen abhängig von der Rechenleistung des Systems und ein paar anderen Faktoren, aber solche Vergleiche sind normalerweise in wenigen Mikrosekunden berechnet.
Da musst Du Dich schon extrem anstrengen und wirklich viel ineinander verschachteln, um das überhaupt messen zu können - geschweige denn zu bemerken.
Das "vorgegeben" habe ich bewußt in Anführungszeichen gesetzt: Wenn man's tatsächlich extrem übertreibt, könnten die Berechnungen so lange dauern, dass in der Zwischenzeit das Event schon ein weiteres Mal ausgelöst wird. Aber solche Dinge wie "Datenbankverbindungen innerhalb von Schleifen öffnen/schließen", "Dateien laden" und ähnliche Schweinereien machen wir ja hier eher nicht
Das ist aber alles eher theoretisch zu sehen. In der Praxis tritt der Fall nicht auf (berühmte letzte Worte) -
@chris-1 sagte
Anstatt in zyklischen Skripten zu denken,
reagiere ich auf einen Trigger A und setze zB X auf falseIn einem Andere Skript reagiere ich auf Trigger X und agiere dann abhängig davon, ob auf true oder false gesetzt/geändert/... wurde
Du denkst noch zu aufwändig. Wenn du in Trigger A den Wert von X änderst, kannst du sofort dahinter abhängig von der Änderung weiter machen. Dies muss aber im Trigger und hinter der Variablenänderung geschehen.
Als Beispiel ein Lichtschalter, der bei jedem Drücken die Helligkeit der Lampe um 20% erhöht:
- Trigger A wartet auf das Drücken des Schalters.
- Löst der Trigger aus, erhöhst du den Wert von X (Helligkeit) um 20%.
- Wenn X größer 100%, dann reduziere ihn auf 0%
- Übertrage den Wert X in die Lampe.
Die Punkte 2-4 sind aufeinanderfolgende Schritte, die aber alle innerhalb des Triggers liegen. Im Prinzip kannst du dutzende Aktionen reinschreiben, die dann alle nacheinander ausgeführt werden, sobald ein Ereignis den Trigger auslöst.
-
Diese Frage schwebt schon Ewigkeiten in meinem Kopf.
Trigger wird ausgelöst und manche andere Bedingungen in dem Blockly werden erst in 3,4 oder 5 Sekunden erfolgen .
Und da ist die Frage wie lange das Blockly wartet bis alles erfüllt ist nachdem der Trigger ausgelöst hat . -
@haselchen sagte in Zählen eines Zustandes:
Bedingungen in dem Blockly werden erst in 3,4 oder 5 Sekunden erfolgen
Was sollte so lange dauern?
Doch nicht etwa ein Trigger im Trigger? -
Die Auslösung eines BWM zum Beispiel.
-
@haselchen sagte in Zählen eines Zustandes:
Die Auslösung eines BWM zum Beispiel.
???? Die Auslösung ist doch in der Regel der Trigger
Und in der Behandlung desselben wird dann noch eine Reihe von Prüfungen durchgeführt, oder? -
@haselchen sagte in Zählen eines Zustandes:
Und da ist die Frage wie lange das Blockly wartet bis alles erfüllt ist nachdem der Trigger ausgelöst hat .
gar nicht.
Da musst du sogar aufpassen dass du ni ht in die asynchron Falle läufst und due Werte in dem Moment wo sie abgefragt werden (im DP) auch schon geschrieben sind.
Deswegen empfiehlt es sich immer mit Variablen zu arbeiten, die direkt nach dem Triggern gestzt werden, i Falle von der "Trigger variable" Wert sogar mit dem Wert arbeitet die zum triggern geführt hat.
Ansonsten werden bei Vergleich mit Wert von ID diese immer genau dann angefordert wenn das Skript an dieser Stelle ankommt.
Letzteres wird nur Millisekunden nach Triggerung sein, aber bis der Wert ankommt dauert etwas länger. -
@fredf
Hab mir den Adapter angeschaut. Dachte erst das ist was ich brauche aber da ich im Device Reminder Adapter nur den DP "switched off" und "in action" habe mit dem ich zuverlässig zählen kann und der Statistics adapter anscheinend nur true & false tählen kann scheint es nicht brauchbar zu sein. Also den zustand Steckdose ein, kann ich mit Statistics aufzeichnen und er zählt auch aber den DP Status Spülmaschine (siehe Bild) scheint er nicht zu erfassen, obwohl ich den aktiviert habe. Konnte da nur einen Namen angeben sonst nix. Bei der Steckdose konnte ich ein Hacken setzten bei Zählen... -
haste das Skript selbst gemacht oder wirklich im netz auf die schnelle gefunden?
Auf jeden Fall verstehe ich leider nicht viel.. Ich muss mich noch viel mit Blockly beschäftigen...
Dieser Thread hier allein hat so viele Infos das ich mir wohl den einen oder anderen Nachmittag wieder des Arsch platt sitzen werde um es zu studieren und wenigstens etwas schlauer zu werden.Ich habt es alle sowas von drauf... Wahnsinn...!
Paul, hab vesucht das nachzubastelt bei mir.
in der oberen Zeile die ID ist das der DP den ich erstellt habe? Der in dem gerade 0 steht. Da wo er reinschreiben soll?
In der Objekt ID wo in gelb Maschine an steht. Das ist doch bestimmt DP von dem Devise Reminder Adapter. Der wo "switched off" & "in acton" seht wenn die Maschine läuft oder aus ist. Kann ich denn da die werte nehmen die der Device Reminder Adapter mir gibt? Oder muss es ein true oder false wert sein? Wenn ich da nur auf änderung reagiere dann würde er ja zwei mal zählen oder?
Und in der unteren Objekt ID (im Blauen) ist doch wieder der DP in der reingeschrieben werden soll und um einen erhöht, oder?Sorry für meine Blödheit und das ich, in euren Augen, bestimmt richtig dämliche Fragen stelle. Ich hoffe ihr habt etwas Verständniss und Geduld mit mir.
-
@random-0 sagte: in der oberen Zeile die ID ist das der DP den ich erstellt habe? ... Da wo er reinschreiben soll?
Ja, ich dachte, dass der Variablenbezeichner aussagekräftig genug ist.
@random-0 sagte in Zählen eines Zustandes:
Oder muss es ein true oder false wert sein? Wenn ich da nur auf änderung reagiere dann würde er ja zwei mal zählen oder?
Ja. Wenn er aber einen String enthält, dann auf Änderung triggern und im Trigger einen String-Vergleich machen.
-
Danke die nochmal Paul. Hab es nachgebaut bei mir aber leider wird in dem DP nichts reingeschrieben wenn die Spülmaschine läuft.
Der Trigger (in action) an der Spülmaschine wird gesetzt aber in dem von mir erstellten DP bleibt eine 0 stehen.Hab alles gespeichert und das Skript aktiviert. Muss ich noch was tun, was ich übersehen habe, damit es funzt?
sieht so bei mir aus mir den Infos wie ich die DP´s gesetzt habe
mein erstellter DP
-
@random-0
Falsche Vergleichsvariable:zyklen
. Es muss der Wert des Trigger-Datenpunktes (unter "Trigger") verglichen werden.