DE10038441B4 - "Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen" - Google Patents

"Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen" Download PDF

Info

Publication number
DE10038441B4
DE10038441B4 DE2000138441 DE10038441A DE10038441B4 DE 10038441 B4 DE10038441 B4 DE 10038441B4 DE 2000138441 DE2000138441 DE 2000138441 DE 10038441 A DE10038441 A DE 10038441A DE 10038441 B4 DE10038441 B4 DE 10038441B4
Authority
DE
Germany
Prior art keywords
flow chart
mcc
user
language
programming
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
DE2000138441
Other languages
English (en)
Other versions
DE10038441A1 (de
Inventor
Regina Schmitt
Peter Wagner
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Siemens AG
Original Assignee
Siemens AG
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Siemens AG filed Critical Siemens AG
Priority to DE2000138441 priority Critical patent/DE10038441B4/de
Priority to US09/911,585 priority patent/US6981226B2/en
Priority to US09/912,128 priority patent/US7302676B2/en
Priority to US09/911,586 priority patent/US7000191B2/en
Priority to DE50112950T priority patent/DE50112950D1/de
Priority to EP01118072A priority patent/EP1184758B1/de
Priority to EP01118071A priority patent/EP1184757B1/de
Priority to DE50114712T priority patent/DE50114712D1/de
Priority to DE50112949T priority patent/DE50112949D1/de
Priority to EP01118073A priority patent/EP1184759B1/de
Publication of DE10038441A1 publication Critical patent/DE10038441A1/de
Application granted granted Critical
Publication of DE10038441B4 publication Critical patent/DE10038441B4/de
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B19/00Programme-control systems
    • G05B19/02Programme-control systems electric
    • G05B19/04Programme control other than numerical control, i.e. in sequence controllers or logic controllers
    • G05B19/05Programmable logic controllers, e.g. simulating logic interconnections of signals according to ladder diagrams or function charts
    • G05B19/056Programming the PLC

Landscapes

  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Engineering & Computer Science (AREA)
  • Automation & Control Theory (AREA)
  • Programmable Controllers (AREA)
  • Stored Programmes (AREA)

Abstract

Verfahren für die Programmierung von industriellen Steuerungen, insbesondere Bewegungssteuerungen, bei dem einem Anwender mit einem grafischen Editor Kontrollstrukturen und Funktionsblöcke zum Verknüpfen zu einem auf einer Anzeigeeinrichtung visualisierbaren Flow Chart (MCC) zur Verfügung gestellt werden, mit den Schritten:
a) aus dem Flow Chart wird eine textuelle Sprache (ST) erzeugt,
b) die textuelle Sprache (ST) wird in einen prozessorunabhängigen Zwischencode kompiliert,
c) der prozessorunabhängige Zwischencode wird auf die Steuerung geladen,
d) der prozessorunabhängige Zwischencode wird in ablauffähigen Prozessorcode umgesetzt,
wobei dem Anwender im Flow Chart-Editor, in Abhängigkeit von der zugrundeliegenden Maschinen- bzw. Hardwarekonfiguration adäquate Sprachmechanismen zur Verfügung gestellt werden,
dadurch gekennzeichnet,
dass durch Markierungen in der textuellen Sprache eine Rückübersetzung in Flow Chart-Notation möglich ist.

Description

  • Die Erfindung bezieht sich zum einen auf ein Verfahren für die Programmierung von industriellen Steuerungen, insbesondere Bewegungssteuerungen, wobei der Anwender mit einem graphischen Editor Kontrollstrukturen und Funktionsblöcke zu einem auf einer Anzeigeeinrichtung visualisierbaren Flow Chart verknüpft.
  • Ferner bezieht sich die Erfindung auf eine Einrichtung für die Programmierung von industriellen Steuerungen, insbesondere Bewegungssteuerungen, wobei vom Anwender mit einem graphischen Editor Kontrollstrukturen und Funktionsblöcke zu einem auf einer Anzeigeeinrichtung visualisierbaren Flow Chart verknüpfbar sind.
  • Im industriellen Umfeld ist es bekannt, sowohl für die Steuerung eines technischen Prozesses als auch für die Steuerung der Bewegung einer Verarbeitungs- bzw. Produktionsmaschine graphische Eingabehilfsmittel sowie einen Bildschirm zur Visualisierung zu verwenden (Hans D. Kief: "NC/CNC Handbuch", 2000, Hansa Verlag, Seite 254, Bild 7 bzw. Seite 327, Bild 6). Grundelemente grafischer Struktur-, Fluss- und Ablaufpläne sind in der Norm DIN 66 001 aufgeführt.
  • In "Visuelle Sprachen – ein unaufhaltsamer Trend in der Industrie" (Josef Hübl, SPS/IPC/Drives – Tagungsband, Seite 88 - 95, 23. - 25. November 1999, Nürnberg, Verlag Hüthig GmbH, Heidelberg) ist außerdem angegeben, dass Kontrollfluss- bzw. Datenflussdiagramme für die Steuerung von Automatisierungsaufgaben mit Hilfe graphischer Editoren erstellt werden.
  • Aus der US 5,504,902 ist bekannt, dass eine graphische Sprache in eine textbasierte Sprache umgewandelt wird, und diese in eine niedrigere Sprache weiterverwandelt wird und dann in einem Speicher gespeichert wird und einer Steuerung zugeführt wird.
  • Aus der US 5,508,909 ist es bekannt, dass die textbasierte Sprache und die graphische Sprache in zwei Richtungen ineinander gegenseitig übersetzt werden können.
  • Ein Beispiel für eine textbasierte Sprache ist die Sprache gemäß der Norm IEC 6-1131, die für Deutschland als DIN EN 61131-3 ins deutsche Normenwerk übernommen wurde. Im Beiblatt 1 zu dieser DIN-Norm finden sich Details zu dieser Sprache.
  • Die EP 0 383 506 B1 betrifft ein Verfahren zur gegenseitig ausschließenden Betriebsmittelsteuerung, bei dem ein Graph erzeugt wird und in einer Speichervorrichtung festgehalten wird, wobei der Graph Knoten umfasst, denen Tasks, die in einen Prozessablauf integriert sind, und ein kritisches Betriebsmittel, das sich mindestens einer der Tasks aneignen kann, zugeordnet sind.
  • Die US 5,485,620 offenbart ein System zum Simultanverarbeiten von sequentiellen und kontinuierlichen Programmen.
  • Die heutzutage existierenden graphischen Eingabehilfsmittel und graphischen Editoren für die Programmierung von industriellen Steuerungen unterstützen dediziert die Programmierung der Steuerung eines technischen Prozesses (SPS-Funktionalität) oder die Programmierung der Steuerung der Bewegung einer Verarbeitungs- bzw. Produktionsmaschine. Die Programmerstellung für beide Anwendungsgebiete wird von existierenden Flow Chart-Editoren jeweils nicht adäquat unterstützt.
  • Ein weiterer Nachteil der heutzutage bei der Programmierung industrieller Automatisierungsaufgaben eingesetzten Flow Chart-Editoren ist, dass die mit ihnen erzeugten Diagramme direkt in ablauffähigen Prozessorcode umgesetzt werden oder dass aus den Diagrammen ASCII-Code erzeugt wird, der dann im jeweiligen Zielsystem laufzeitintensiv interpretiert werden muss. Neben der dadurch resultierenden Unflexibilität bezüglich der Portierung und Übertragung der Programme auf andere Anlagen oder Maschinen bedeutet dieser Mechanismus als weiteren Nachteil für den Anwender nur eingeschränkte Debugging-Möglichkeiten.
  • Außerdem liegen zusätzliche Nachteile existierender Flow Chart-Editoren im meist starren und unflexiblen Sprachvorrat an für den Anwender verwendbaren Icons und in der fest vorgegebenen sequentiellen Abarbeitungsreihenfolge der Icons bzw. der entsprechenden Funktionsblöcke. Auch bieten existierende Flow Chart-Editoren häufig nur wenig Möglichkeiten zur Formulierung von Synchronisationsmechanismen, die aber insbesondere für die Programmierung von Applikationen in der industriellen Automatisierung sehr oft benötigt werden.
  • Der Erfindung liegt daher die Aufgabe zugrunde, ein Verfahren gemäß Oberbegriff von Anspruch 1 und/oder eine Einrichtung gemäß Oberbegriff von Anspruch 16 zu schaffen, wobei einem Anwender sowohl für die Programmierung der Steuerung von technischen Prozessen (SPS-Funktionalität) als auch für die Programmierung von Bewegungssteuerungen (Motion-Funktionalität) Unterstützung gegeben wird. Dem Anwender soll dabei größtmöglichste Flexibilität bei der Programmierung angeboten werden, insbesondere soll er dabei durch adaptive Mechanismen unterstützt werden.
  • Gemäß der Erfindung wird diese Aufgabe für ein Verfahren der eingangs genannten Art dadurch gelöst, dass folgende Schritte aufeinander folgend durchgeführt werden:
    • a) aus dem Flow Chart wird eine textuelle Sprache erzeugt,
    • b) die textuelle Sprache wird in einen prozessorunabhängigen Zwischencode kompiliert,
    • c) der prozessorunabhängige Zwischencode wird auf die Steuerung geladen,
    • d) der prozessorunabhängige Zwischencode wird in ablauffähigen Prozessorcode umgesetzt,
    wobei dem Anwender im Flow Chart-Editor, in Abhängigkeit von der zugrundeliegenden Maschinen- bzw. Hardwarekonfiguration adäquate Sprachmechanismen zur Verfügung gestellt werden.
  • Erfindungsgemäß ist durch Markierungen in der textuellen Sprache eine Rückübersetzung in Flow Charts-Notation möglich.
  • Dadurch, dass aus den Flow Chart-Diagrammen in einem Zwischenschritt eine textuelle Sprache erzeugt wird, hat der Anwender die Möglichkeit, bereits auf dieser Ebene der textuellen Sprache Plausibilitätsüberprüfungen durchzuführen. Er kann aber auch weitere Sprachelemente, die in der textuellen Sprache vorliegen, zu seiner Anwendung hinzubinden. Dadurch, dass die textuelle Sprache in einem weiteren Zwischenschritt in einen prozessorunabhängigen Zwischencode kompiliert wird, bleibt die angesprochene Flexibilität für den Anwender weiterhin erhalten. Auch auf dieser Zwischencodeebene kann der Anwender Plausibilitätschecks bzw. ein Debugging durchführen. Der letztendlich in der Steuerung ablaufende Prozessorcode wird aus dem prozessorunabhängigen Zwischencode generiert, dadurch wird das Target der Anwendung erst zu einem sehr späten Zeitpunkt festgelegt. Durch die Zwischenschritte bei der Codegenerierung können außerdem sehr leicht unterschiedliche Ziel-Hartwaren bedient werden.
  • Ein weiterer Vorteil der vorliegenden Erfindung liegt darin, dass aus der zugrunde liegenden Maschinenkonfigurierung bzw. Maschinenprojektierung aktuelle und adäquate Sprachmechanismen abgeleitet werden, die im Flow Chart-Editor, in Form von Icons, dem Anwender zur Verfügung gestellt werden. Dadurch wird einem Anwender eine Programmierumgebung zur Verfügung gestellt, die auf die zugrunde liegende Hardware abgestimmt ist und somit optimal den vorliegenden Anforderungen und Randbedingungen genügt. Der Sprachvorrat des Flow Chart-Editors adaptiert sich somit selbständig an die vorhandenen HW-Gegebenheiten (z.B. die zugrunde liegende Maschinenkonfiguration).
  • Durch die Verwendung von syntaktischen und geometrischen Informationen, die in Form von Markierungen erfolgen, ist es möglich, aus der textuellen Sprache in die Flow Chart-Notation eine Rückübersetzung vorzunehmen. Diese Rückübersetzungsmöglichkeit hat für den Anwender den Vorteil, dass Änderungen, die auf der Ebene der textuellen Sprache eingegeben werden, unmittelbar im Flow Chart-Editor in der Flow Chart-Notation nachgezogen werden können und somit für den Anwender in den Flow Chart-Diagrammen sichtbar sind. Solche rückübersetzten Programme kann der Anwender dann auf der Graphikebene mit Hilfe des Flow Chart-Editors weiterbearbeiten und daraus im weiteren Vorgehen Steuerungscode erzeugen.
  • Eine erste vorteilhafte Ausgestaltung der Erfindung liegt darin, dass aus anwenderdefinierten Unterprogrammen der textuellen Sprache automatisch entsprechende graphische Elemente in der Flow Chart-Notation generiert werden, welche die Funktionsschnittstelle der entsprechenden Unterprogramme enthalten. Dadurch ist es möglich, dass aus schon vorhandenen Unterprogrammen der textuellen Sprache oder aus zusätzlichen Unterprogrammen, die in die textuelle Sprache eventuell vom Maschinenbauer eingebracht wurden, automatisch Icons und die dazugehörigen Masken vom System generiert werden und dem Anwender im Flow Chart-Editor zur Verfügung gestellt werden. Die Funktionsschnittstelle und die Übergabeparameter der Unterprogramme der textuellen Sprache werden dabei automatisch für die Flow Chart Icons generiert. Durch diesen Mechanismus lassen sich leicht von OEM-Kunden (Original Equipment Manufacturer) schon in textueller Sprache vorliegende Unterprogramme in den Flow Chart-Editor übernehmen. Damit wird dem Endanwender für seine Flow Chart-Programmierung ein angepass ter und erweiterter Sprachvorrat an Icons zur Verfügung gestellt.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass die automatisch generierten grafischen Elemente vom Anwender als Sprachelemente des Flow Charts verwendet werden. Dadurch, dass der Anwender die automatisch generierten Icons als normale Sprachelemente des Flow Chart-Editors verwenden kann, wird der ihm zur Verfügung stehende Sprachvorrat an Flow Chart-Elementen, d.h. an Icons, erweitert. Somit wird die Flexibilität und Ausdrucksmöglichkeit bezüglich der Programmierung von Applikationen für den Anwender erhöht.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass als textuelle Sprache Structured Text nach IEC 6-1131 verwendet wird. Dadurch, dass mit IEC 6-1131 eine genormte Sprache auf der Ebene der textuellen Sprache verwendet wird, ist der Austausch bzw. die Kopplung mit anderen Programmiersystemen sehr leicht möglich. Außerdem wird durch die Verwendung von IEC 6-1131 als Zwischensprache die Portierung auf unterschiedliche Zielsysteme sehr erleichtert.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass ein Anwender zum Formulieren von Bedingungen beliebig zwischen den Darstellungsformen textuelle Sprache, Kontaktplan (KOP) und/oder Funktionsplan (FUP) wechseln kann. Dadurch, dass auf der Structured Text-Ebene IEC 6-1131 als textuelle Sprache verwendet wird, können auch andere Darstellungsformen von IEC 6-1131 neben der textuellen Sprache, nämlich Kontaktpläne und/oder Funktionspläne, verwendet werden. Ein Anwender hat somit die Flexibilität, innerhalb dieser Sprachen der SPS-Welt, nämlich Structured Text, Kontaktplan (KOP) oder Funktionsplan (FUP), beliebig zu wechseln. Diese Flexibilität ist insbesondere für die Formulierung von Bedingungen ein großer Vorteil für den Anwender, denn er kann sich die Darstellungs- bzw. Beschreibungsform wählen, in der er die meiste Erfahrung hat, oder die dem zugrunde liegenden Problem angemessen ist. üblicherweise verwendet ein Anwender für die Darstellung von binären Verknüpfungen Kontaktpläne (KOP) und/oder Funktionspläne (FUP) und für die Formulierung von arithmetischen Berechnungen Structured Text.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation als Sprachelemente mindestens eine Schleife und/oder mindestens eine Parallelverzweigung vorhanden sind. In den heutzutage gängigen Flow Chart-Editoren werden Schleifen und oft auch Verzweigungen mit Hilfe von Sprungmarken dargestellt. Durch die Verwendung von Sprüngen (Goto-Problematik!) und die dazugehörigen Zielmarken wird die Programmgestaltung aber sehr unübersichtlich und schwer nachvollziehbar. Dadurch, dass dem Anwender als eigene Sprachelemente Schleifen und Parallelverzweigung zur Verfügung stehen, wird die Programmerstellung und auch die Lesbarkeit der Programme erheblich vereinfacht.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass innerhalb der jeweiligen Parallelverzweigung die einzelnen Befehle im selben Interpolatortakt gestartet werden. Dadurch, dass alle Zweige des Sprachkonstrukts Parallelverzweigung im selben Interpolatortakt bedient werden, ist eine quasi parallele Abarbeitung der in den einzelnen Zweigen des Parallelverzweigungs-Konstrukts enthaltenen Befehle möglich. Neben der sequentiellen wird somit auch die parallele Abarbeitung von Befehlen ermöglicht und durch adäquate Sprachmechanismen in der Programmierumgebung für den Anwender unterstützt.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation die Funktionsblöcke durch Maskeneingabe parametriert werden. Dadurch wird für den Anwender die Eingabe von Parametern in einer übersichtlichen und leicht verständlichen Form ermöglicht. Für jeden Typ von Funktionsblock existieren Standardmasken, die einem Anwender nur die für den aktuellen Typ möglichen Parametereingaben erlauben. Die Gefahr von fehlerhaften Eingaben wird durch diese Kontextsensitivität reduziert.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation Funktionsblöcke zu Modulen zusammengefasst werden, die wiederum als Funktionsblöcke erscheinen. Dadurch wird die Übersichtlichkeit des Programmablaufs im Flow Chart für den Anwender erhöht. Ein Anwender kann nämlich logisch zusammengehörende Funktionsblöcke zu einem Modul zusammenfassen und kapseln, wobei dieses Modul wiederum als Funktionsblock im Flow Chart-Editor, d.h. als Icon, erscheint. Durch diesen Mechanismus der Zusammenfassung und Kapselung wird aber nicht nur die Übersichtlichkeit im Ablauf erhöht, auch der Programmablauf lässt sich dadurch strukturieren.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation ineinander geschachtelte Module möglich sind. Das heißt, ein Modul kann wiederum als Element ein oder mehrere Module enthalten. Module können sozusagen wiederum als Unterprogramme in anderen Modulen verwendet werden, dadurch wird die Übersichtlichkeit und die Struktur des Programmablaufs im Flow Chart erhöht.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation dem Anwender in den Funktionsblöcken für die Variablenzuweisung jeweils mehrere Zuweisungen möglich sind. Dadurch, dass der Anwender in einem Funktionsblock, d.h. in einem Icon, mehrere Variablenzuweisungen nacheinander eingeben kann und nicht für jede Variablenzuweisung einen neuen Funktionsblock benötigt, wird zum einen die Übersichtlichkeit erhöht, zum anderen wird aber auch das Programmierprinzip der hohen Kohäsion unterstützt, da der Anwender seine Variablenzuweisungen, die sinnvollerweise zu diesem Funktionsblock gehören, auch in diesem einen Funktionsblock gebündelt vornehmen kann.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation die Funktionsblöcke, die Funktionen repräsentieren, die eine Zeitdauer beanspru chen, Weiterschaltbedingungen enthalten. Funktionen, die eine Zeitdauer beanspruchen, sind z.B. Referenzpunktfahren, Beschleunigen oder Achspositionieren. Solche Funktionen bzw. ihr Zusammenwirken können Anwender mit Hilfe der Weiterschaltbedingungen synchronisieren. Einem Anwender steht somit mit Hilfe der Weiterschaltbedingungen ein Synchronisationsmechanismus zur Verfügung, der es ihm erlaubt, komplexe Bewegungen und Zusammenhänge mehrerer Achsen zu synchronisieren.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass die grafischen Elemente des Flow Charts automatisch positioniert werden. Wenn ein Anwender ein neues Icon im Flow Chart-Editor darstellen will, wird es automatisch an der Stelle positioniert, die als nächstes dem logischen Programmablauf entspricht. Dadurch, dass ein Anwender die generierten Icons nicht selbst positionieren muss, wird seine Arbeitseffizienz gesteigert.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass die Icons des Flow Charts automatisch miteinander verbunden werden. Auch hierin liegt eine Steigerung der Arbeitseffizienz des Anwenders, da er die Icons nicht nachträglich per Hand miteinander verbinden muss.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass das Flow Chart in der Anzeige verkleinert oder vergrößert dargestellt Werden kann. Durch diese Zoom-Funktionalität wird für den Anwender die Übersichtlichkeit der Diagramme erhöht und außerdem kann er bestimmte Programmabläufe, die ihn momentan interessieren, durch Vergrößerung graphisch hervorheben.
  • Gemäß der Erfindung wird die oben genannte Aufgabe für eine Einrichtung der eingangs genannten Art durch die folgenden aufeinander folgenden Elemente gelöst:
    • a) aus dem Flow Chart ist eine textuelle Sprache erzeugbar,
    • b) die textuelle Sprache ist in einen prozessorunabhängigen Zwischencode kompilierbar,
    • c) der prozessorunabhängige Zwischencode ist in einen Speicherbereich der Steuerung ladbar,
    • d) der geladene prozessorunabhängige Zwischencode ist durch den Prozessor in einen ablauffähigen Prozessorcode umsetzbar,
    wobei dem Anwender auf einem zugehörigen Display im Flow Chart-Editor, in Abhängigkeit von der zugrundeliegenden Maschinen- bzw. Hardwarekonfiguration adäquate Sprachmechanismen zur Verfügung gestellt sind.
  • Erfindungsgemäß werden aus anwenderdefinierten, durch Markierungen vorgegebenen Unterprogrammen der textuellen Sprache automatisch entsprechende graphische Elemente in der Flow Chart-Notation generiert, welche die Funktionsschnittstelle der entsprechenden Unterprogramme enthalten.
  • Dadurch, dass aus den Flow Chart-Diagrammen in einem Zwischenschritt eine textuelle Sprache erzeugbar ist, hat der Anwender die Möglichkeit, bereits auf dieser Ebene der textuellen Sprache Plausibilitätsüberprüfungen durchzuführen. Er kann aber auch weitere Sprachelemente, die in der textuellen Sprache vorliegen, zu seiner Anwendung hinzubinden. Dadurch, dass die textuelle Sprache in einem weiteren Zwischenschritt in einen prozessorunabhängigen Zwischencode kompilierbar ist, bleibt die angesprochene Flexibilität für den Anwender weiterhin erhalten. Auch auf dieser Zwischencodeebene kann der Anwender Plausibilitätschecks bzw. ein Debugging durchführen. Der letztendlich in der Steuerung ablaufende Prozessorcode ist aus dem prozessorunabhängigen Zwischencode generierbar, dadurch kann das Target der Anwendung erst zu einem sehr späten Zeitpunkt festgelegt werden. Durch die Zwischenschritte bei der Codegenerierung können außerdem sehr leicht unterschiedliche Ziel-Hardwaren bedient werden.
  • Ein weiterer Vorteil der vorliegenden Erfindung liegt darin, dass aus der zugrunde liegenden Maschinenkonfigurierung bzw. Maschinenprojektierung aktuelle und adäquate Sprachmechanismen abgeleitet werden, die im Flow Chart-Editor, in Form von Icons, dem Anwender zur Verfügung gestellt werden. Dadurch wird einem Anwender eine Programmierumgebung zur Verfügung gestellt, die auf die zugrunde liegende Hardware abgestimmt ist und somit optimal den vorliegenden Anforderungen und Randbedingungen genügt. Der Sprachvorrat des Flow Chart-Editors adaptiert sich somit selbständig an die vorhandenen HW-Gegebenheiten (z.B. die zugrunde liegende Maschinenkonfiguration).
  • Dadurch dass aus anwenderdefinierten Unterprogrammen der textuellen Sprache automatisch entsprechende grafische Elemente in der Flow Chart-Notation generierbar sind, welche die Funktionsschnittstelle der entsprechenden Unterprogramme enthalten, ist es möglich dass aus schon vorhandenen Unterprogrammen der textuellen Sprache oder aus zusätzlichen Unterprogrammen, die in die textuelle Sprache eventuell vom Maschinenbauer eingebracht wurden, automatisch grafische Elemente (Icons) und die dazugehörigen Masken vom System generiert werden und dem Anwender im Flow Chart-Editor zur Verfügung gestellt werden. Die Funktionsschnittstelle und die Übergabeparameter der Unterprogramme der textuellen Sprache werden dabei automatisch für die Flow Chart Icons generiert. Durch diesen Mechanismus lassen sich leicht von OEM-Kunden (Original Equipment Manufacturer) schon in textueller Sprache vorliegende Unterprogramme in den Flow Chart-Editor übernehmen. Damit wird dem Endanwender für seine Flow Chart-Programmierung ein angepasster und erweiterter Sprachvorrat an Icons zur Verfügung gestellt.
  • Durch die Verwendung von syntaktischen und geometrischen Informationen, die in Form von Markierungen erfolgen, ist es möglich, aus der textuellen Sprache in die Flow Chart-Notation eine Rückübersetzung vorzunehmen. Diese Rückübersetzungsmöglichkeit hat für den Anwender den Vorteil, dass Ände rungen, die auf der Ebene der textuellen Sprache eingegeben werden, unmittelbar im Flow Chart-Editor in der Flow Chart-Notation nachgezogen werden können und somit für den Anwender in den Flow Chart-Diagrammen auf dem Display sichtbar sind. Solche rückübersetzten Programme kann der Anwender dann auf der Graphikebene mit Hilfe des Flow Chart-Editors weiterbearbeiten und daraus im weiteren Vorgehen Steuerungscode für die Steuerung erzeugen.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass die automatisch generierten grafischen Elemente vom Anwender als Sprachelemente des Flow Charts verwendbar sind. Dadurch, dass der Anwender die automatisch generierten Icons als normale Sprachelemente des Flow Chart-Editors verwenden kann, wird der ihm zur Verfügung stehende Sprachvorrat an Flow Chart-Elementen, d.h. an Icons, erweitert. Somit wird die Flexibilität und Ausdrucksmöglichkeit bezüglich der Programmierung von Applikationen für den Anwender erhöht.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass als textuelle Sprache IEC 6-1131 verwendbar ist. Dadurch, dass mit IEC 6-1131 eine genormte Sprache auf der Ebene der textuellen Sprache verwendbar ist, ist der Austausch bzw. die Kopplung mit anderen Programmiersystemen sehr leicht möglich. Außerdem wird durch die Verwendung von IEC 6-1131 als Zwischensprache die Portierung auf unterschiedliche Zielsysteme sehr erleichtert.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass für einen Anwender zum Formulieren von Bedingungen ein beliebiger Wechsel zwischen den Darstellungsformen textuelle Sprache, Kontaktplan und/oder Funktionsplan vorgesehen ist. Dadurch, dass auf der Structured Text-Ebene IEC 6-1131 als textuelle Sprache verwendbar ist, können auch andere Darstellungsformen von IEC 6-1131 neben der textuellen Sprache, nämlich Kontaktpläne und/oder Funktionspläne, ver wendet werden. Ein Anwender hat somit die Flexibilität, innerhalb dieser Sprachen der SPS-Welt, nämlich Structured Text, Kontaktplan (KOP) oder Funktionsplan (FUP), beliebig zu wechseln. Diese Flexibilität ist insbesondere für die Formulierung von Bedingungen ein großer Vorteil für den Anwender, denn er kann sich die Darstellungs- bzw. Beschreibungsform wählen, in der er die meiste Erfahrung hat, oder die dem zugrunde liegenden Problem angemessen ist. Üblicherweise verwendet ein Anwender für die Darstellung von binären Verknüpfungen Kontaktpläne (KOP) und/oder Funktionspläne (FUP) und für die Formulierung von arithmetischen Berechnungen Structured Text.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation als Sprachelemente mindestens eine Schleife und/oder mindestens eine Parallelverzweigung vorhanden sind. In den heutzutage gängigen Flow Chart-Editoren werden auf den Displays Schleifen und oft auch Verzweigungen mit Hilfe von Sprungmarken dargestellt. Durch die Verwendung von Sprüngen (Goto-Problematik!) und die dazugehörigen Zielmarken wird die Programmgestaltung aber sehr unübersichtlich und schwer nachvollziehbar. Dadurch, dass dem Anwender als eigene Sprachelemente Schleifen und Parallelverzweigung zur Verfügung stehen, wird die Programmerstellung und auch die Lesbarkeit der Programme erheblich vereinfacht.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass innerhalb der jeweiligen Parallelverzweigung die einzelnen Befehle im selben Interpolatortakt startbar sind. Dadurch, dass alle Zweige des Sprachkonstrukts Parallelverzweigung im selben Interpolatortakt bedient werden, ist eine quasi parallele Abarbeitung der in den einzelnen Zweigen des Parallelverzweigungs-Konstrukts enthaltenen Befehle möglich. Neben der sequentiellen wird somit auch die parallele Abarbeitung von Befehlen ermöglicht und durch adäquate Sprachmechanismen in der Programmierumgebung für den Anwender unterstützt.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation die Funktionsblöcke durch Maskeneingabe parametriert sind. Dadurch wird für den Anwender die Eingabe (durch Eingabehilfsmittel wie Maus, Tastatur) und die Darstellung (am Display) von Parametern in einer übersichtlichen und leicht verständlichen Form ermöglicht. Für jeden Typ von Funktionsblock existieren Standardmasken, die einem Anwender nur die für den aktuellen Typ möglichen Parametereingaben erlauben. Die Gefahr von fehlerhaften Eingaben wird durch diese Kontextsensitivität reduziert.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation Funktionsblöcke zu Modulen zusammengefasst sind, die wiederum einen Funktionsblock bilden. Dadurch wird die Übersichtlichkeit des Programmablaufs im Flow Chart für den Anwender erhöht. Ein Anwender kann nämlich logisch zusammengehörende Funktionsblöcke zu einem Modul zusammenfassen und kapseln, wobei dieses Modul wiederum als Funktionsblock im Flow Chart-Editor, d.h. als Icon, erscheint. Durch diesen Mechanismus der Zusammenfassung und Kapselung wird aber nicht nur die Übersichtlichkeit (am Display) im Ablauf erhöht, auch der Programmablauf lässt sich dadurch strukturieren.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation ineinander geschachtelte Module vorgesehen sind. Das heißt, ein Modul kann wiederum als Element ein oder mehrere Module enthalten. Module können sozusagen wiederum als Unterprogramme in anderen Modulen verwendet werden, dadurch wird die Übersichtlichkeit (am Display) und die Struktur des Programmablaufs im Flow Chart erhöht.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation für den Anwender in den Funktionsblöcken für die Variablenzuweisung jeweils mehrere Zuweisungen vorgesehen sind. Dadurch, dass der Anwender in einem Funktionsblock, d.h. in einem Icon, mehrere Variablenzuweisungen nacheinander eingeben kann und nicht für jede Variablenzuweisung einen neuen Funktionsblock benötigt, wird zum einen die Übersichtlichkeit erhöht, zum anderen wird aber auch das Programmierprinzip der hohen Kohäsion unterstützt, da der Anwender seine Variablenzuweisungen, die sinnvollerweise zu diesem Funktionsblock gehören, auch in diesem einen Funktionsblock gebündelt vornehmen kann.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass in der Flow Chart-Notation für diejenigen Funktionsblöcke, die Funktionen repräsentieren, die eine Zeitdauer beanspruchen, Weiterschaltbedingungen vorgesehen sind. Funktionen, die eine Zeitdauer beanspruchen, sind z.B. Referenzpunktfahren, Beschleunigen oder Achspositionieren. Solche Funktionen bzw. ihr Zusammenwirken können Anwender mit Hilfe der Weiterschaltbedingungen synchronisieren. Einem Anwender steht somit mit Hilfe der Weiterschaltbedingungen ein Synchronisationsmechanismus zur Verfügung, der es ihm erlaubt, komplexe Bewegungen und Zusammenhänge mehrerer Achsen zu synchronisieren.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass die grafischen Elemente des Flow Charts automatisch positionierbar sind. Wenn ein Anwender ein neues Icon im Flow Chart-Editor auf dem Display darstellen will, wird es automatisch an der Stelle positioniert, die als nächstes dem logischen Programmablauf entspricht. Dadurch, dass ein Anwender die generierten Icons nicht selbst positionieren muss, wird seine Arbeitseffizienz gesteigert.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass die grafischen Elemente des Flow Charts automatisch miteinander verbindbar sind. Auch hierin liegt eine Steigerung der Arbeitseffizienz des Anwenders, da er die Icons nicht nachträglich per Hand (d.h. mit Tastatur, Maus oder anderen Eingabehilfsmitteln) miteinander verbinden muss.
  • Eine weitere vorteilhafte Ausgestaltung der Erfindung liegt darin, dass das Flow Chart (MCC) in der Anzeige verkleinert oder vergrößert darstellbar ist. Durch diese Zoom-Funktionalität wird für den Anwender die Übersichtlichkeit der Diagramme am Display erhöht und außerdem kann er bestimmte Programmabläufe, die ihn momentan interessieren, durch Vergrößerung graphisch hervorheben.
  • Die wesentlichen mit der Erfindung erzielten Vorteile bestehen also insbesondere darin, dass ein Anwender in einer einheitlichen Programmierumgebung sowohl Bewegungssteuerungsaufgaben (Motion Control) und Prozesssteuerungsaufgaben (SPS-Aufgaben) in einer jeweils angemessenen Form programmieren kann. Weiterhin ist von Vorteil, dass die Programmierumgebung sich projektsensitiv verhält, d.h. dass dem Anwender in Abhängigkeit von der zugrunde liegenden Hardware bzw. Maschinenprojektierung zusätzliche dedizierte Sprachelemente zur Verfügung gestellt werden.
  • Ein weiterer Vorteil liegt darin, dass der Anwender sowohl für die sequentielle als auch für die zyklische Programmierung der Steuerungsabläufe unterstützt wird. Dadurch, dass eine geschachtelte Modulbildung von Funktionsblöcken zur Verfügung steht, hat der Anwender den Vorteil, die Übersichtlichkeit und die Struktur seiner Programme zu erhöhen, da er die Designkriterien, Lokalität und hohe Kohäsion sehr leicht umsetzen kann.
  • Ein weiterer sehr großer Vorteil liegt darin, dass aus Unterprogrammen, die in der textuellen Sprache vorliegen, für den Flow Chart-Editor Icons generiert werden, die die Funktionsschnittstelle der entsprechenden Unterprogramme automatisch enthalten. Wenn ein OEM-Kunde bereits Unterprogramme in der textuellen Sprache erstellt hat, so können diese Unterprogramme automatisch durch entsprechende Icons den Sprachvorrat des Flow Chart-Editors erweitern.
  • Ein Ausführungsbeispiel der Erfindung ist in der Zeichnung dargestellt und wird im folgenden erläutert.
  • Dabei zeigen:
  • 1 in einer Schemadarstellung ein Engineering-System, das zugehörige Run-Time-System und den zu steuernden technischen Prozess,
  • 2 zeigt in einem Übersichtsbild Elemente des Engineering-Systems und der Steuerung sowie ihre Beziehungen untereinander,
  • 3 zeigt ebenfalls in Form eines Übersichtsbildes den programmtechnischen Zusammenhang zwischen Elementen des Engineering-Systems und des Run-Time-Systems,
  • 4 zeigt ein einfaches Diagramm in Flow Chart-Notation,
  • 5 zeigt ein komplexes Diagramm in Flow Chart-Notation mit den Kontrollstrukturen while und if,
  • 6 zeigt ebenfalls ein komplexes Diagramm in Flow Chart-Notation mit dem Sprachkonstrukt Parallelverzweigung (sync),
  • 7 zeigt eine Parametriermaske für den Befehl "positioniere Achse",
  • 8 zeigt eine Auswahl von Sprachelementen (so genannten Icons) des Flow Chart-Editors.
  • In der Darstellung gemäß 1 wird in Form eines Strukturbildes gezeigt, dass die Steuerung eines technischen Prozesses TP über das Run-Time-System RTS einer industriellen Steuerung erfolgt. Die Verbindung zwischen dem Run-Time-System RTS der Steuerung und dem technischen Prozess TP geschieht bidirektional über den Ein-/Ausgang EA. Die Programmierung der Steuerung und damit das Festlegen des Verhaltens des Run-Time-Systems RTS geschieht im Engineering-System ES. Das Engineering-System ES enthält Werkzeuge für die Konfigurierung, Projektierung und Programmierung für Maschinen bzw. für die Steuerung technischer Prozesse. Die im Engineering-System erstellten Programme werden über den Informationspfad I1 in das Run-Time-System RTS der Steuerung übertragen. Bezüglich seiner Hardware-Ausstattung besteht ein Engineeringsystem ES üblicherweise aus einem Computersystem mit Grafikbildschirm (z.B. Display), Eingabehilfsmitteln (z.B. Tastatur und Maus), Prozessor, Arbeits- und Sekundärspeicher, einer Einrichtung für die Aufnahme computerlesbarer Medien (z.B. Disketten, CDs) sowie Anschlusseinheiten für einen Datenaustausch mit anderen Systemen (z.B. weiteren Computersystemen, Steuerungen für technische Prozesse) oder Medien (z.B. Internet). Eine Steuerung besteht üblicherweise aus Eingabe- und Ausgebeeinheiten, sowie aus Prozessor und Programmspeicher.
  • In der Darstellung gemäß 2 werden in Form eines Übersichtsbildes Elemente des Engineering-Systems und der Steuerung sowie ihr Zusammenspiel dargestellt. Dabei werden die einzelnen Elemente in Form von Rechtecken dargestellt, die im Engineering-System enthaltene Datenablage wird in Form des üblicherweise verwendeten Datenspeichersymbols dargestellt. Durch Pfeile (unidirektional oder bidirektional) wird der datenlogische bzw. der ablauflogische Zusammenhang zwischen den Elementen dargestellt. Die obere Hälfte von 2 zeigt die Elemente des Engineering-Systems, nämlich den MCC-Editor, den ST-Compiler mit Programmiergebung, den Konfigurations-Server KS und die Maschinenprojektierung sowie eine Datenablage. Die Zugehörigkeit dieser Elemente zum Engineering-System wird durch Umrandung dargestellt. Die Steuerung beinhaltet den Codeumsetzer und die Programmverarbeitung. Auch die Elemente der Steuerung, die sich im unteren Abschnitt von 2 befinden, sind umrandet. Sowohl das Engineering-System als auch die Steuerung können noch weitere Elemente beinhalten, sie sind aber aus Gründen der Übersichtlichkeit nicht dargestellt.
  • Im MCC-Editor (MCC steht für Motion Control Chart) werden die graphischen Programmabläufe erzeugt. Die Sprachelemente des Editors, d.h. die Icons, können z.B. über eine Befehlsleiste im Bildschirm, die mit Hilfe einer Maus bedient wird oder denkbare andere Eingabehilfsmittel mit dem Editor erzeugt und dargestellt werden. Ein Anwender kann mit Hilfe des MCC-Editors Funktionsblöcke (Icons) und Kontrollstrukturen zu einem Flow Chart verknüpfen, d.h. er kann den MCC-Editor als graphisches Programmier-Tool für die Erstellung von Programmen für Bewegungssteuerungen und/oder Prozesssteuerungen verwenden. Aus dem Flow Chart wird ein textuelles Programm bzw. eine textuelle Sprache (üblicherweise Structured Text nach IEC 6-1131) erzeugt. Dieser Structure Text-Code (ST-Code) wird vom Structured Text-Compiler (ST-Compiler, der Teil der Programmierumgebung ist) in einen prozessorunabhängigen Zwischencode kompiliert. Dieser Zwischencode wird auf die Steue rung geladen und dort vom Codeumsetzer in ablauffähigen Prozessorcode umgesetzt. Dieser wird von der Programmverarbeitung innerhalb der Steuerung zum Ablauf gebracht. Durch die unidirektionalen Pfeile im linken Abschnitt von 2 werden die Schritte der Code- bzw. Programmumsetzung dargestellt. Parallel zu den drei von oben nach unten verlaufenden unidirektionalen Pfeilen, die diese Umsetzung darstellen, verlaufen jeweils zwischen den Elementen MCC-Editor, ST-Compiler, Codeumsetzer und Programmverarbeitung drei bidirektionale Pfeile, die Debug-Schnittstellen bzw. die Möglichkeit einer Programmbeobachtung darstellen. Zwischen Programmverarbeitung und Codeumsetzer existiert eine Debug-Schnittstelle auf Prozessorcode-, d.h. auf Objektcodeebene, eine weitere Debug-Schnittstelle existiert zwischen dem Codeumsetzer und dem ST-Compiler, diese Debug-Schnittstelle befindet sich auf Zwischencodeebene. Zwischen dem ST-Compiler und dem MCC-Editor befindet sich eine weitere Debug- bzw. Programmbeobachtungsschnittstelle auf Ebene von Structured Text (ST-Code).
  • In 2 sind als weitere Elemente des Engineering-Systems die Maschinenprojektierung und ein Konfigurations-Server KS dargestellt. In der Maschinenprojektierung wird mit Hilfe geeigneter Werkzeuge die Auslegung der Hardware bzw. der zugrunde gelegten Maschine vollzogen. Das heißt, in der Maschinenprojektierung wird z.B. festgelegt, welche Achstypen in welcher Anzahl physikalisch vorhanden sind. Diese Maschineninformationen werden über den Konfigurations-Server KS in den MCC-Editor eingespeist. Die Übertragung dieser Informationen wird durch die unidirektionalen Pfeile I2 und I3 dargestellt. Weiterhin beinhaltet der Konfigurations-Server KS weitere relevante Konfigurationsinformationen für das System, die z.B. auch für die Lizenzierung von zugehörigen Softwarekomponenten verwendet werden können.
  • Eine Datenablage DA, dargestellt durch das gängige Datenspeichersymbol, beinhaltet drei Aspekte: Zum einen das vom MCC-Editor für ein Flow Chart erzeugtes Objektmodell, als zweites den dazugehörigen Structured Text und der dritte Inhalt der Datenablage DA ist der aus dem Structured Text generierte Zwischencode. Die Datenablage DA steht in bidirektionaler Verbindung zum MCC-Editor und ST-Compiler, dargestellt durch die bidirektionalen Informationspfeile I4 und I5.
  • Die Darstellung gemäß 3 zeigt als Übersichtsbild die vorhandenen Abstraktionsebenen aus Sicht des Programmcodes. Die unterschiedlichen Programmcode-Ebenen sind als Rechtecke dargestellt. Die oberste Ebene ist die MCC-Ebene, in der die Flow Chart-Programme erzeugt werden. Die nächstuntergeordnete Codeebene ist die Structured Text-Ebene ST. In die ST-Ebene gelangt man aus der MCC-Ebene durch eine entsprechende Codegenerierung, dargestellt durch einen Pfeil vom MCC-Block zum ST-Block. Unterhalb der Structured Text-Ebene ST liegt die Zwischencode-Ebene. Durch einen Compiler wird aus dem Structured Text-Programm ein prozessorunabhängiger Zwischencode kompiliert, dargestellt durch den Pfeil vom ST-Block zum Block mit dem Namen Zwischencode. Unterhalb der Zwischencode-Ebene liegt die unterste Codeebene, nämlich die Objektcode-Ebene, die den ablauffähigen Prozessorcode beinhaltet. Aus dem Zwischencode wird über einen Umsetzer der Objektcode erzeugt, ebenfalls dargestellt durch einen Pfeil vom Zwischen-codeblock zum Objektcodeblock. Von der Objektcode-Ebene gehen rechtwinklig abgewinkelte Pfeile zurück zur Structured Text-Codeebene ST und zur Flow Chart-Ebene MCC. Dadurch ist angedeutet, dass auf diesen Ebenen Test- und Programmverfolgungsaktivitäten stattfinden können, auf der Basis des Objektcodes. Durch den fetten Doppelpfeil zwischen der MCC- und der ST-Ebene wird angedeutet, dass zwischen diesen beiden Ebenen Aufrufe, Task-Steuerbefehle und Variablenaustauschfunktionen möglich sind. Die gestrichelte Linie in 3 zeigt die Grenze zwischen dem Engineering System ES und dem Run-Time-System RTS der Steuerung (S; 2) an. Die Grenze verläuft durch die Zwischencode-Ebene, alles, was oberhalb der gestrichelten Linie ist, gehört zum Engineering System ES, alles, was un terhalb der gestrichelten Linie stattfindet, gehört zum Run-Time-System RTS.
  • Weiterhin wird in 3 gezeigt, wie ein Programmierer oder Anwender (am linken Bildrand dargestellt durch ein stilisiertes Strichmännchen) im Engineering System ES Eingaben einbringen kann. Er kann zum einen auf der MCC-Ebene mit Hilfe der graphischen Programmierung Flow Charts erzeugen, zum anderen kann er auf der Structured Text-Ebene ST durch eine textuelle Programmierung Programme erstellen. Beide Eingabemöglichkeiten sind durch Pfeile vom Strichmännchen zum MCC-Block bzw. zum ST-Block dargestellt.
  • Darstellung gemäß 4 zeigt einen einfachen Programmablauf für die Programmierung von Achsbewegungen. Jedes Flow Chart beginnt mit einem Startknoten und endet mit einem Endeknoten. Diese Programmbegrenzungssymbole tragen die Bezeichnung "Start" bzw. "Ende". Start- und Endesymbole werden jeweils durch ein Rechteck dargestellt, dessen Stirnseiten durch zwei Halbkreise ausgebildet sind. Die Programmbefehle werden durch Rechtecke dargestellt, die einen Bezeichner und ein graphisches Symbol beinhalten, welches den hinterlagerten Befehl repräsentiert.
  • Die Flow Chart-Symbole werden üblicherweise über eine Eingabeleiste mit Hilfe einer Maus im Flow Chart-Editor erzeugt, wobei auch andere Eingabehilfsmittel wie z.B. ein Touch Pad denkbar sind. Alternativ wäre auch eine Bedienung über Tastatur mit oder ohne Maus möglich.
  • Die Flow Chart-Symbole werden vom Flow Chart-Editor defaultmäßig untereinander ausgerichtet und durch eine Linie miteinander verbunden.
  • Im Flow Chart nach 4 wird nach dem Start eine Gleichlaufachse freigeschaltet, danach wird auf ein Synchronisierungssignal gewartet und als nächster und letzter Befehl des Flow Charts wird für eine Gleichlaufachse eine Kurvenscheibe eingeschaltet. Die Befehlsequenz von 4 wird beendet durch das Endesymbol.
  • Die Darstellung gemäß 5 zeigt ein komplexes Flow Chart mit Kontrollstrukturen für eine While-Schleife und für das If-Konstrukt. Das While- und das If-Konstrukt werden jeweils durch sechseckige, wabenförmige Symbole dargestellt. Ansonsten werden im Programmablauf, wie er in 5 dargestellt ist, die gleichen Typen von Symbolen verwendet, wie sie schon aus 4 bekannt sind. Auch das Flow Chart nach 5 beginnt mit dem Start- und endet mit dem Endesymbol. Unmittelbar nach dem Startknoten folgt ein Befehl, der die Task "motion_3" startet. Dieser Befehl ist vom Typ "Starte Task". Das Rechteck für diesen Befehl enthält deshalb auch das zugehörige entsprechende Symbol, welches das Starten einer Task darstellt. Als nächstes im Programmablauf, wie er in 5 dargestellt ist, folgt das sechseckige wabenförmige While-Konstrukt. Solange die im While-Konstrukt angegebene Bedingung true ist, werden die auf das While-Konstrukt folgenden Befehle zyklisch nacheinander ausgeführt. Das Ende der Befehlsfolge einer While-Schleife wird dargestellt durch einen abgewinkelten Pfeil, der vom letzten Symbol des while-Konstrukts (in 5 ist dies der Befehl vom Typ "Getriebegleichlauf aus", bezogen auf eine Gleichlaufachse) von unten abgeht und auf der linken Seite von 5 zurück in das While-Konstrukt mündet. Ist die Bedingung im While-Konstrukt nicht mehr erfüllt, dann wird die Befehlsfolge, die zum While-Konstrukt gehört, nicht mehr ausgeführt. In 5 wird dies dargestellt durch eine rechtwinklige Verbindungslinie, die das While-Symbol auf der rechten Seite verlässt und rechter Hand die zum While-Symbol gehörende Symbolbefehlsfolge umgeht und in auf das dieser Befehlsfolge unmittelbar folgende Symbol einmündet, in 5 ist dies das Ende-Symbol.
  • Wenn aber die While-Bedingung erfüllt ist, wird folgende Befehlsfolge abgearbeitet: Unmittelbar nach dem While-Konstrukt folgt ein Befehl, der das Warten auf eine Bedingung repräsentiert. Auch dieser Befehl enthält ein entsprechendes mnemotechnisches grafisches Symbol, das den Wartevorgang graphisch darstellt. Als nächstes folgt ein Befehl, der die Task "motion_2" startet. Auch dieser Befehl ist vom Typ "Starte Task" und enthält das entsprechende graphische Symbol. Nach diesem Befehl folgt das If-Konstrukt, das genauso wie das While-Konstrukt durch ein sechseckiges, wabenförmiges Symbol dargestellt wird. Ist die If-Bedingung (in 5 dargestellt durch "error <> 0"), erfüllt dann wird im True-Zweig die Befehlsfolge weiter abgearbeitet, ansonsten, wenn die Bedingung nicht erfüllt ist, wird die Befehlsfolge im False-Zweig weiter abgearbeitet. Im True-Zweig der If-Bedingung folgt als nächster Befehl ein Befehl, der die Task "motion_2" stoppt. Dieser Befehl ist vom Typ "Stoppe Task" Darauf folgt ein Befehl, der die Task "motion_3" stoppt. Auch dieser Befehl ist vom Typ "Stoppe Task". Diese Befehle werden außerdem durch dazugehörende entsprechende Symbole repräsentiert. Als nächstes in der Befehlsfolge kommen zwei "Stoppe Achs"-Befehle. Im ersten solchen Befehl wird eine Drehzahlachse gestoppt, im darauffolgenden eine Positionierachse, auch diese "stoppe Achs"-Befehle werden durch dazugehörende entsprechende graphische Symbole repräsentiert. Der nächste und zugleich der letzte Befehl in 5 bezieht sich auf eine Achse mit dem Namen "Gleichlaufachse", nämlich auf das Ausschalten des Getriebegleichlaufes ("Getriebegleichlauf aus"), auch dieser Befehl wird durch ein entsprechendes graphisches Symbol repräsentiert. Die Symbole des Flow Charts sind durch Linien miteinander verbunden, womit der Programmablauf dargestellt wird. Von diesem Befehl, der den letzten Befehl im While-Konstrukt darstellt, geht ein rechtwinklig abgewinkelter Pfeil zurück zu diesem While-Konstrukt. Dadurch wird das zyklische Abarbeiten der Befehlsfolge dargestellt. Im While-Konstrukt wird geprüft, ob die Bedingung erfüllt ist. Ist sie erfüllt oder weiterhin erfüllt, wird die Befehlsfolge noch einmal durchlaufen. Ist sie nicht erfüllt, wird das While-Konstrukt verlassen und, wie beispielhaft in 5 darge stellt, mit dem Ende-Symbolfortgefahren, d.h. der durch das Flow Chart dargestellte Programmablauf wird beendet.
  • Die Darstellung gemäß 6 zeigt ebenfalls ein komplexes Diagramm in Flow Chart-Notation mit dem Sprachkonstrukt Parallelverzweigung (sync). In 6 folgt auf das Start-Symbol ein Befehl, der sich auf eine Drehzahlachse bezieht, nämlich "Achsfreigabe schalten". Auch für diesen Befehl wird im Befehlsrechteck ein graphisches Symbol angegeben, das diesen Befehl repräsentiert. Danach folgt wiederum ein Befehl vom Typ "Achsfreigabe schalten", diesmal aber bezogen auf eine Positionierachse, auch hier ist das dazugehörige entsprechende Symbol angegeben. Der nächstfolgende Befehl ist ein Synchronisationsbefehl "warte auf Signal", in 6 mit "Auto" bezeichnet und mit dem entsprechenden Symbol versehen.
  • Als nächstes Symbol in 6 folgt das Symbol für die Parallelverzweigung (sync). Dieses Symbol wird ebenfalls wie das While- oder das If-Konstrukt durch ein sechseckiges, wabenförmiges graphisches Element dargestellt. Alle Befehle, die in dem Sektor unmittelbar unter dem Symbol für die Parallelverzweigung angeordnet sind, werden im selben Interpolatortakt gestartet. In 6 sind dies die Befehle "Positioniere Achse", bezogen auf eine Positionierachse (dieser Befehlstyp beinhaltet auch das zugehörige entsprechende graphische Symbol) und ein Befehl vom Typ "Setze Ausgang". Der Befehlstyp "Setze Ausgang" ist ebenfalls durch ein Rechteck dargestellt, dieses Rechteck enthält die Adresse des Ausgangs (%QB40) und das entsprechende Symbol für diesen Setz-Befehl (S steht für Set). Die Befehle, die zu einem Parallelverzweigungssymbol gehören, d.h. die innerhalb desselben Interpolatortakts gestartet werden, sind mit dem Parallelverzweigungssymbol nach oben mit einer Linie verbunden und nach unten sind sie mit einer Doppellinie verbunden. Diese waagrechte Doppellinie zeigt an, dass die parallele Abarbeitung wieder aufgehoben ist und dass mit der Bearbeitung des nachfolgenden Befehls so lange gewartet wird, bis alle Aktionen in der Parallelver zweigung beendet sind. Sie ist somit auch das Ende-Symbol des Parallelverzweigungskonstrukts. Als nächstes folgt ein Befehl vom Typ "Drehzahlvorgabe", der sich auf eine Drehzahlachse bezieht. Darauf folgen zwei Befehle vom Typ "Positioniere Achse", die sich jeweils auf Positionierachsen beziehen. Darauf folgt wieder ein Befehl vom Typ "Stoppe Achse", der sich auf eine Drehzahlachse bezieht. Die Rechtecke, die diese genannten Befehle darstellen, beinhalten natürlich auch wieder entsprechende dazugehörige graphische Symbole. Nach dem Befehl vom Typ "Stoppe Achse", der sich auf die schon genannte Drehzahlachse bezieht, folgt das Ende-Symbol.
  • Die hier dargestellte Art der Flow Chart-Programmierung unterstützt unterschiedliche Arten der Programmierung. Zum einen wird durch das Parallelverzweigungssymbol mit dem Starten der dazugehörigen Befehle in einem Interpolatortakt eine mehr oder weniger echte Parallelität erreicht, d.h. die Programmierung paralleler Threads wird unterstützt, und ihre dazugehörige Abarbeitung wird ermöglicht. Zum anderen wird die zyklische Programmierung, d.h. auch die zyklische Programmabarbeitung, unterstützt, es kann nämlich dargestellt werden, dass aufeinander folgende Befehle nur angestoßen werden, wobei aber jeweils nicht auf die Abarbeitung des vorhergehenden Befehls gewartet werden muss. Aber auch die Programmierung und die Darstellung solcher sequentiellen Abläufe wäre möglich, dass nämlich bei Anstoß eines Befehls auf die Abarbeitung dieses Befehls gewartet wird, bis der nächste Befehl angestoßen und abgearbeitet wird. Die hier vorgestellte Flow Chart-Programmierung ist somit für einen Anwender sehr flexibel anwendbar und für unterschiedliche Applikationen einsetzbar.
  • Die Darstellung gemäß 7 zeigt eine Parametriermaske für den Flow Chart-Befehl "Positioniere Achse". Oben links im oberen Balken der Parametriermaske steht die Bezeichnung des entsprechenden Befehls, in diesem Fall "Positioniere Achse". Der obere Balken beinhaltet auf seiner rechten Seite zwei Schalter, ein Schalter mit einem Fragezeichen versehen beinhaltet eine Online-Hilfe, der zweite Schalter, mit x versehen, wird für das Schließen der Maske verwendet. Die Parametriermaske beinhaltet unterschiedliche Eingabesektoren. Im obersten Eingabesektor kann die entsprechende Achse ausgewählt werden mit Hilfe eines Eingabemenüs (dargestellt durch einen Eingabeknopf mit einem kleinen auf dem Kopf stehenden Dreieck) können im Eingabefenster die entsprechenden Achsen ausgewählt werden. In diesem obersten Sektor ist links oben auch das zu diesem Befehl dazugehörige graphische Symbol angegeben, nämlich ein auf dem Kopf stehendes Dreieck mit der Spitze nach unten, das waagrecht mittig mit einer dunklen Linie versehen ist, wobei an den Enden dieser Linie jeweils nach unten abgeschrägte weitere kleine Linien angebracht sind. Der nächste und größte Sektor der Parametriermaske stellt die Möglichkeiten dar, Parameter einzugeben. Die Parameter sind, je nach Befehl, unterschiedlich. Sie werden über benamte Reiter, die auf einer Reiterleiste angeordnet sind, wie in gängigen Programmoberflächen üblich, logisch sortiert. Die erste Seite (in 7 ist diese Seite durch den Reiter "Parameter" aufblendbar) trägt üblicherweise die Parameter, die unbedingt zur Parametrierung des Befehls angegeben werden müssen. Für den Befehl "Positioniere Achse" ist ein unbedingter Parameter z.B. die Zielposition einer Achsbewegung.
  • Die Anzahl und Bedeutung der Reiter ist befehlsabhängig unterschiedlich. In 7 ist dargestellt, dass für den Befehl "Positioniere Achse" neben dem Reiter "Parameter" noch ein Reiter "Dynamic" vorhanden ist. Mit diesem Reiter können für die Beschreibung des dynamischen Verhaltens Eingaben zu Ruck und Beschleunigung sowie zum Geschwindigkeitsprofil gemacht werden. Diese Eingaben können über Eingabefelder und dazugehörigen Menüs gemacht werden. In Abbildung von 7 wurde als Geschwindigkeitsprofil die Trapezform gewählt. Diese Form wurde auch graphisch in der Mitte dieses Eingabesektors stilisiert dargestellt. Im unten darauffolgenden Eingabesektor der Parametriermaske können weitere Eingaben, z.B. für das Übergangsverhalten, gemacht werden. Im Beispiel von 7 wurde für das Übergangsverhalten "Ablösen" eingegeben. Zusätzlich können Wartebedingungen eingegeben werden, indem das Kästchen "Warten" mit einem Häkchen versehen wird. Zu diesem Synchronisieren können in einem dazugehörenden Eingabefenster weitere Eingaben gemacht werden. Im Beispiel nach 7 wurde "Positionsfenster erreicht" dafür eingegeben. Auch diese Eingaben werden durch stilisiert dargestellte Achsprofile unterstützt. Das untere Ende einer Parametrierachse besteht aus vier Eingabeknöpfen, nämlich einem "OK"-Knopf, einem "Abbrechen"-Knopf, einem "Übernehmen"-Knopf und einem "Hilfe"-Knopf. Mit Hilfe dieser Eingabeknöpfe können Anwender entweder die Eingaben übernehmen, bestätigen, verwerfen oder die Eingabehilfe aufrufen. Mit Hilfe der Wartebedingungen können durch einen Anwender sogenannte Weiterschaltbedingungen spezifiziert werden, die Funktionen (z.B. Referenzpunktfahren oder Achspositionieren) bzw. ihr Zusammenspiel synchronisieren.
  • Solche Parametriermasken existieren dediziert für alle Befehle, die mit Hilfe des Flow Chart-Editors eingegeben und bearbeitet werden können. Der Anwender wird also kontextsensitiv mit Hilfe dieser Parametriermasken bei der Programmierung seiner Bewegungs- und Steuerungsabläufe unterstützt.
  • Die Darstellung gemäß 8 zeigt eine Auswahl von Sprachelementen (so genannten Icons) des Flow Chart-Editors. Diese Sprachelemente repräsentieren Befehle, die der Anwender bei der graphischen Programmierung im Flow Chart-Editor benutzen kann. Der MCC-Flow Chart-Editor unterstützt folgende Klassen von Befehlen und stellt für die einzelnen Befehle dieser Klassen jeweils entsprechende Symbole zur Verfügung: Start-Befehle, Stop-Befehle, Positionierbefehle, Gleichlauf- und Kurvenscheiben-Befehle, Messtaster und SW-Nocken-Befehle, Warte-Befehle, Tasksteuer-Befehle, Befehle für die Manipulierung von Variablen sowie weitere allgemeine Befehle. Außerdem stellt der MCC-Flow Chart-Editor weitere grafischen Kontrollstrukturen für den grafischen Programmablauf zur Verfügung.

Claims (29)

  1. Verfahren für die Programmierung von industriellen Steuerungen, insbesondere Bewegungssteuerungen, bei dem einem Anwender mit einem grafischen Editor Kontrollstrukturen und Funktionsblöcke zum Verknüpfen zu einem auf einer Anzeigeeinrichtung visualisierbaren Flow Chart (MCC) zur Verfügung gestellt werden, mit den Schritten: a) aus dem Flow Chart wird eine textuelle Sprache (ST) erzeugt, b) die textuelle Sprache (ST) wird in einen prozessorunabhängigen Zwischencode kompiliert, c) der prozessorunabhängige Zwischencode wird auf die Steuerung geladen, d) der prozessorunabhängige Zwischencode wird in ablauffähigen Prozessorcode umgesetzt, wobei dem Anwender im Flow Chart-Editor, in Abhängigkeit von der zugrundeliegenden Maschinen- bzw. Hardwarekonfiguration adäquate Sprachmechanismen zur Verfügung gestellt werden, dadurch gekennzeichnet, dass durch Markierungen in der textuellen Sprache eine Rückübersetzung in Flow Chart-Notation möglich ist.
  2. Verfahren nach Anspruch 1, dadurch gekennzeichnet, dass aus anwenderdefinierten Unterprogrammen der textuellen Sprache (ST) automatisch entsprechende grafische Elemente in der Flow Chart-Notation (MCC) generiert werden, welche die Funktionsschnittstelle der entsprechenden Unterprogramme enthalten.
  3. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass die automatisch generierten grafischen Elemente vom Anwender als Sprachelemente des Flow Charts (MCC) verwendbar sind.
  4. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass als textuelle Sprache Structured Text nach IEC 6-1131 verwendet wird.
  5. Verfahren nach Anspruch 4, dadurch gekennzeichnet, dass ein Anwender zum Formulieren von Bedingungen beliebig zwischen den Darstellungsformen textuelle Sprache (ST), Kontaktplan (KOP) und/oder Funktionsplan (FUP) wechseln kann.
  6. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) als Sprachelemente mindestens eine Schleife und/oder mindestens eine Parallelverzweigung vorhanden sind.
  7. Verfahren nach Anspruch 6, dadurch gekennzeichnet, dass innerhalb der jeweiligen Parallelverzweigung die einzelnen Befehle im selben Interpolatortakt gestartet werden.
  8. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) die Funktionsblöcke durch Maskeneingabe parametriert werden.
  9. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) Funktionsblöcke zu Modulen zusammengefasst werden, die wiederum als Funktionsblöcke erscheinen.
  10. Verfahren nach Anspruch 9, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) ineinander geschachtelte Module möglich sind.
  11. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) dem Anwender in den Funktionsblöcken für die Variablenzuweisung jeweils mehrere Zuweisungen möglich sind.
  12. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) die Funktionsblöcke, die Funktionen repräsentieren, die eine Zeitdauer beanspruchen, Weiterschaltbedingungen enthalten.
  13. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass die grafischen Elemente des Flow Charts automatisch positioniert werden.
  14. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass die grafischen Elemente des Flow Charts automatisch miteinander verbunden werden.
  15. Verfahren nach einem der vorstehenden Ansprüche, dadurch gekennzeichnet, dass das Flow Chart in der Anzeige verkleinert oder vergrößert dargestellt werden kann.
  16. Einrichtung für die Programmierung von industriellen Steuerungen, insbesondere Bewegungssteuerungen, wobei vom Anwender mit einem grafischen Editor Kontrollstrukturen und Funktionsblöcke zu einem auf einer Anzeigeeinrichtung visualisierbaren Flow Chart (MCC) verknüpfbar sind mit den aufeinander folgenden Elementen: a) aus dem Flow Chart ist eine textuelle Sprache (ST) erzeugbar, b) die textuelle Sprache (ST) ist in einen prozessorunabhängigen Zwischencode kompilierbar, c) der prozessorunabhängige Zwischencode ist in einen Speicherbereich der Steuerung ladbar, d) der geladene prozessorunabhängige Zwischencode ist durch den Prozessor in einen ablauffähigen Prozessorcode umsetzbar, wobei, dem Anwender auf einem zugehörigen Display im Flow Chart-Editor, in Abhängigkeit von der zugrundeliegenden Maschinen- bzw. Hardwarekonfiguration adäquate Sprachmechanismen zur Verfügung gestellt sind, dadurch gekennzeichnet, dass aus anwenderdefinierten, durch Markierungen in der textuellen Sprache (ST) gekennzeichneten Unterprogrammen der textuellen Sprache (ST) automatisch entsprechende grafische Elemente in der Flow Chart-Notation (MCC) generierbar sind, welche die Funktionsschnittstelle der entsprechenden Unterprogramme enthalten.
  17. Einrichtung für die Programmierung nach Anspruch 16, dadurch gekennzeichnet, dass die automatisch generierten grafischen Elemente vom Anwender als Sprachelemente des Flow Charts (MCC) verwendbar sind.
  18. Einrichtung für die Programmierung nach Anspruch 16 oder 17, dadurch gekennzeichnet, dass als textuelle Sprache IEC 6-1131 verwendbar ist.
  19. Einrichtung für die Programmierung nach Anspruch 18, dadurch gekennzeichnet, dass für einen Anwender zum Formulieren von Bedingungen ein beliebiger Wechsel zwischen den Darstellungsformen textuelle Sprache (ST), Kontaktplan (KOP) und/oder Funktionsplan (FUP) vorgesehen ist.
  20. Einrichtung für die Programmierung nach einem der Ansprüche 16 bis 19, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) als Sprachelemente mindestens eine Schleife und/oder mindestens eine Parallelverzweigung vorhanden sind.
  21. Einrichtung für die Programmierung nach Anspruch 20, dadurch gekennzeichnet, dass innerhalb der jeweiligen Parallelverzweigung die einzelnen Befehle im selben Interpolatortakt startbar sind.
  22. Einrichtung für die Programmierung nach einem der Ansprüche 16 bis 21, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) die Funktionsblöcke durch Maskeneingabe parametriert sind.
  23. Einrichtung für die Programmierung nach einem der Ansprüche 16 bis 22, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) Funktionsblöcke zu Modulen zusammengefasst sind, die wiederum einen Funktionsblock bilden.
  24. Einrichtung für die Programmierung nach Anspruch 23, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) ineinander geschachtelte Module vorgesehen sind.
  25. Einrichtung für die Programmierung nach einem der Ansprüche 16 bis 24, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) für den Anwender in den Funktionsblöcken für die Variablenzuweisung jeweils mehrere Zuweisungen vorgesehen sind.
  26. Einrichtung für die Programmierung nach einem der Ansprüche 16 bis 25, dadurch gekennzeichnet, dass in der Flow Chart-Notation (MCC) für diejenigen Funktionsblöcke, die Funktionen repräsentieren, die eine Zeitdauer beanspruchen, Weiterschaltbedingungen vorgesehen sind.
  27. Einrichtung für die Programmierung nach einem der Ansprüche 16 bis 26, dadurch gekennzeichnet, dass die grafischen Elemente des Flow Charts (MCC) automatisch positionierbar sind.
  28. Einrichtung für die Programmierung nach einem der Ansprüche 16 bis 27, dadurch gekennzeichnet, dass die grafischen Elemente des Flow Charts (MCC) automatisch miteinander verbindbar sind.
  29. Einrichtung für die Programmierung nach einem der Ansprüche 16 bis 28, dadurch gekennzeichnet, dass das Flow Chart (MCC) in der Anzeige verkleinert oder vergrößert darstellbar ist.
DE2000138441 2000-08-07 2000-08-07 "Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen" Expired - Fee Related DE10038441B4 (de)

Priority Applications (10)

Application Number Priority Date Filing Date Title
DE2000138441 DE10038441B4 (de) 2000-08-07 2000-08-07 "Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen"
US09/912,128 US7302676B2 (en) 2000-08-07 2001-07-24 Method for debugging flowchart programs for industrial controllers
US09/911,586 US7000191B2 (en) 2000-08-07 2001-07-24 Flowchart programming for industrial controllers, in particular motion controllers
US09/911,585 US6981226B2 (en) 2000-08-07 2001-07-24 Flowchart programming for industrial controllers, in particular motion controllers
EP01118072A EP1184758B1 (de) 2000-08-07 2001-07-25 Verfahren zum Debuggen von Programmen für industrielle Steuerungen, insbesondere Bewegungssteuerungen, im Kontext der Flow Chart Programmierung
EP01118071A EP1184757B1 (de) 2000-08-07 2001-07-25 Flow chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen
DE50112950T DE50112950D1 (de) 2000-08-07 2001-07-25 Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen
DE50114712T DE50114712D1 (de) 2000-08-07 2001-07-25 Verfahren zum Debuggen von Programmen für industrielle Steuerungen, insbesondere Bewegungssteuerungen, im Kontext der Flow Chart Programmierung
DE50112949T DE50112949D1 (de) 2000-08-07 2001-07-25 Flow chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen
EP01118073A EP1184759B1 (de) 2000-08-07 2001-07-25 Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
DE2000138441 DE10038441B4 (de) 2000-08-07 2000-08-07 "Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen"

Publications (2)

Publication Number Publication Date
DE10038441A1 DE10038441A1 (de) 2002-10-24
DE10038441B4 true DE10038441B4 (de) 2005-10-27

Family

ID=7651559

Family Applications (1)

Application Number Title Priority Date Filing Date
DE2000138441 Expired - Fee Related DE10038441B4 (de) 2000-08-07 2000-08-07 "Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen"

Country Status (1)

Country Link
DE (1) DE10038441B4 (de)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE202008003348U1 (de) 2008-03-07 2009-07-30 Kuka Systems Gmbh Steuereinrichtung

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE10308815B4 (de) * 2003-02-27 2008-06-05 Siemens Ag Verfahren zur Erzeugung und Visualisierung einer aufgabenorientierten Schrittdarstellung
AT10596U1 (de) 2008-02-26 2009-06-15 Keba Ag Konfigurierung von maschinenablaufen
DE102012004983B4 (de) * 2012-03-14 2016-10-27 Hermann Müller Verfahren zur grafikbasierten Roboterprogrammierung eines Mehrachs-Roboters
WO2014166530A1 (de) * 2013-04-10 2014-10-16 Siemens Aktiengesellschaft Verfahren und instanzgenerator zur programmierung einer industriellen automatisierungskomponente
US20140364970A1 (en) * 2013-06-07 2014-12-11 General Electric Company System and method for application development and deployment

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0383506B1 (de) * 1989-02-13 1995-12-13 International Business Machines Corporation Verfahren und System zur gegenseitig ausschliessenden Betriebsmittelsteuerung
US5485620A (en) * 1994-02-25 1996-01-16 Automation System And Products, Inc. Integrated control system for industrial automation applications
US5504902A (en) * 1993-12-01 1996-04-02 Patriot Sensors And Controls Corporation Multi-language generation of control program for an industrial controller
US5508909A (en) * 1994-04-26 1996-04-16 Patriot Sensors And Controls Method and systems for use with an industrial controller

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0383506B1 (de) * 1989-02-13 1995-12-13 International Business Machines Corporation Verfahren und System zur gegenseitig ausschliessenden Betriebsmittelsteuerung
US5504902A (en) * 1993-12-01 1996-04-02 Patriot Sensors And Controls Corporation Multi-language generation of control program for an industrial controller
US5485620A (en) * 1994-02-25 1996-01-16 Automation System And Products, Inc. Integrated control system for industrial automation applications
US5508909A (en) * 1994-04-26 1996-04-16 Patriot Sensors And Controls Method and systems for use with an industrial controller

Non-Patent Citations (5)

* Cited by examiner, † Cited by third party
Title
Beiblatt 1 zu DIN EN 61131-3, November 1997, Beuth Verlag, Berlin *
BRANDENBURG, G. (u.a.): Tagungsband SPS/IPC/ DRIVES '99, Hüthig GmbH Heidelberg, S. 88-95 *
DIN 66001, Sept. 1966 *
Hübl, J.: Visuelle Sprachen - ein unaufhaltsamer Trend in der Industrie. In: Tagungsband SPS/IPC/ DRIVES '99, 23.-25.11.1999 in Nürnberg. Hüthig GmbH Heidelberg, S. 88-95 *
Kief, H.D.: NC/CNC Handbuch. Hansa Verlag 2000, S. 254 u. 327 *

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE202008003348U1 (de) 2008-03-07 2009-07-30 Kuka Systems Gmbh Steuereinrichtung

Also Published As

Publication number Publication date
DE10038441A1 (de) 2002-10-24

Similar Documents

Publication Publication Date Title
EP1184757B1 (de) Flow chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen
DE69121712T2 (de) Graphische, programmierbare schnittstelle für maschine-/prozesssteuerungsgeräte
EP2453326B1 (de) Verfahren und System zur Bedienung einer Maschine aus der Automatisierungstechnik
EP1182528A2 (de) Industrielle Steuerung auf der Basis verteilbarer Technologischer Objekte
DE112006000988T5 (de) Wechselrichter und Programmiervorrichtung für denselben
WO2002065223A2 (de) Steuerungs- und überwachungsanlage von maschinen und/oder anlagen mit aktionskomponenten unterschiedlicher aktionsgruppen
WO2005124479A1 (de) System und verfahren zum konfigurieren und parametrieren einer maschine der automatisierungstechnik
EP1221638A2 (de) Automatisierungssystem
EP1224512B1 (de) Steuerungssystem einer numerischen werkzeugmaschine mit einer wiederverwendbaren softwarestruktur
EP1148398B1 (de) Eingabeverfahren für die Programmierung von industriellen Steuerungen
EP0553621B1 (de) Programmierbare Computersteuerung für eine Werkzeugmaschine
DE112012006104T5 (de) Sequenz-Programm-Design-Hilfsvorrichtung
EP1137972B1 (de) Automatisierungssystem zur lösung einer prozesstechnischen aufgabenstellung und verfahren hierzu
DE10038441B4 (de) &#34;Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen&#34;
EP0838054B1 (de) Verfahren und steuereinrichtung für eine graphische steuerung von abläufen in einem netzwerkmanagementsystem
DE102007014271A1 (de) Verfahren und Vorrichtung zur Bedienung und Steuerung einer maschinentechnischen Anlage mit Hilfe einer grafischen Entwicklungsoberfläche und automatischer Code-Generierung
EP1548527A1 (de) Steuerungs- oder Regelungseinrichtung einer Werkzeug- oder Produktionsmaschine
EP1217476A2 (de) Vorrichtung und Verfahren zur Inbetriebnahme und Diagnose von Steuerungssystemen
EP1221641A2 (de) Industrielle Steuerung mit taktsynchronem Ablaufebenenmodell
DE10038439B4 (de) Vorrichtung, zumindest umfassend ein Computersystem und eine industrielle Steuerung, für das Debuggen von Programmen für industrielle Steuerungen
WO2010028760A1 (de) Automatisierungssystem mit frameworkbasierter steuerung
EP1450279A2 (de) Verfahren zur Projektierung eines elektrischen Systems
DE10055168A1 (de) Industrielle Steuerung auf der Basis verteilbarer Technologischer Objekte
DE10038440A1 (de) Flow Chart Programmierung für industrielle Steuerungen, insbesondere Bewegungssteuerungen
EP1226475B1 (de) Verfahren zum erstellen von leittechnik-programmcode

Legal Events

Date Code Title Description
OP8 Request for examination as to paragraph 44 patent law
8364 No opposition during term of opposition
8339 Ceased/non-payment of the annual fee