Info |
---|
--R Robert (etwas gekürzt um das Zuviel an Bezug zu Kabel/Baukasten zu reduzieren) |
Struktur diese Kapitels
Seitenhierarchie | ||
---|---|---|
|
Einführung in das Baukasten-Denken
Die Custom-Logiken ermöglichen es dem Anwender, eigene - auch sehr komplexe - Logikaufgaben zu bewältigen. Die dafür benötigte Kodiersyntax ist an die Schalt- oder Digitaltechnik angelehnt. Sie basiert auf einzelnen Modulbausteinen.
Info |
---|
Nutzen Sie den Doc-Mode und den Logik Diagnosemonitor Custom Logiken wurden ursprünglich von ElabNET dazu genutzt, um Kunden schnell ggf. spezielle Logiken zur Verfügung zu stellen, ohne dass eine neue Firmware Version ausgerollt werden muss. Auf vielfachen Kundenwunsch, wurde diese Möglichkeit für alle Nutzer freigeschaltet. Dies ist ein Tool “von Experten für Experten”. Die Nutzung von Custom Logiken ist nicht schwierig, jedoch muss eine Verbindungsliste als json formatiert werden und dies setzt eine gewisse Sorgfalt voraus. Nutzen Sie den Doc-Modus sowie den Logik Diagnosemonitor (seit IP2 zur V4) für die Prüfung und Beobachtung Ihrer Logik. Überprüfen Sie insbesondere im Diagnosemonitor, ob es zur Abbrüchen, einem Stopp der Logik wegen zu häufiger Aufrufe pro Zeiteinheit und zur Berechnung ungültiger oder nicht darstellbarer Zahlen kommt um unerwünschte Ergebnisse zu vermeiden, |
Wer sich bisher noch nicht mit der Schalttechnik auseinander gesetzt hat, dem hilft vielleicht folgende Veranschaulichung mit “Logik-kästchen” (=Modulbaustein) und Verbindungskabel (=Variablen) weiter:
...
[Intern: PowerPoint-Datei, in der die Grafiken erstellt wurden]
...
Dieses Bild kann auf die Kodiersyntax übertragen werden:
Innerhalb einer Custom-Logik übernehmen die vordefinierten Modulbausteine die Funktion der Logik-Kästchen; sie haben je eine vorgegebene Anzahl von Ein- und Ausgängen und eine interne Funktion.
Als Kabelverbindungen dienen in der Custom-Logik die Variablen.
...
Dies führt zu folgendem Code (der hier didaktisch dargestellt wird, d.h. in der Praxis könnte er etwas verkürzt werden). Der Aufbau des Codes wird unter Die Struktur einer Custom-Logik erläutert.
Codeblock |
---|
{ "Input": [ ["Eingang 1 (Gruppe 1)","Status Eingang 1","$In1","a" ], ["Eingang 2 (Gruppe 1)","Status Eingang 2","$In2","a" ], ["Eingang 3 (Gruppe 2)","Status Eingang 3","$In3","a" ], ["Eingang 4 (Gruppe 2)","Status Eingang 4","$In4","a" ] ], "Output": [ ["Ausgang","Eine der beiden Gruppen ist TRUE","$Out","a" ] ], "Module": [ ["And",["$In1","$In2"],"$Gruppe1"], ["And",["$In3","$In4"],"$Gruppe2"], ["Or",["$Gruppe1","$Gruppe2"],"$Out"] ], "Level": [ ["$In1","bool",false], ["$In2","bool",false], ["$In3","bool",false], ["$In4","bool",false], ["$Gruppe1","bool",false], ["$Gruppe2","bool",false], ["$Out","bool",false] ] } |
...
Die Logikengine wird durch dieses Konzept sehr schnell. Der Code ist kompakt, da intern alles auf wenigen Grundschaltungen basiert, die jeweils nur wenige Codezeilen umfassen.
Die jeweiligen Modulbausteine sind kompakt und gut getestet/fehlerfrei.
Das Schaltmodul-Konzept ermöglicht den Doktormodus mit alle den vielen Fähigkeiten der Diagnose und des Eingriffes, die dieser bietet. Mit prozeduralen Sprachen wäre dies kaum realisierbar.
Struktur diese Kapitels
Seitenhierarchie | ||
---|---|---|
|