High Level ArchitectureHigh-Level Architecture (HLA) ist eine vom US-amerikanischen Verteidigungsministerium (genauer dem „Defense Modeling and Simulation Office, DMSO for the U.S. Department of Defense“) definierte Architektur zur integrierten und verteilten Simulation. Dieses Konzept ist im Jahr 2000 zum internationalen Standard geworden (IEEE 1516). Sie basiert auf der Idee, eine Gesamtsimulation in mehrere einzelne, kleine Simulationen aufzuteilen, die untereinander ihre Informationen austauschen. Die Kommunikation geschieht über ein Computernetzwerk. Verwaltet werden die einzelnen Simulationen dabei von einer zentralen Komponente, der sogenannten „Run-Time-Infrastructure“ (RTI). Diese überwacht den Simulationsablauf und verwaltet die Verteilung der Daten zwischen den Einzelsimulationen (Föderaten). Die Gesamtheit der Einzelsimulationen wird als „Föderation“ bezeichnet. Technischer ÜberblickDie High-Level-Architecture basiert auf drei großen Definitionsbereichen
Die Daten, die zwischen HLA-Föderaten ausgetauscht werden, können entweder Objekte oder Interaktionen sein. Ein Objekt ist eine Datenstruktur, die in einer teilnehmenden Simulation vorhanden ist und die ihre Daten (Attribute) im Netzwerk verteilt. Eine Interaktion ist mit einem Ereignis gleichzusetzen und besitzt bestimmte Parameter. Zum Beispiel besitzt ein Objekt „Flugabwehrpanzer“ in Simulation A die Attribute Position, Geschwindigkeit, Beschleunigung etc. Eine Interaktion kann nun z. B. das Abfeuern eines Lenkflugkörpers auf ein Kampfflugzeug in Simulation B sein und als Parameter den Typ des Gefechtskopfes, das beschossene Ziel oder das abfeuernde Objekt besitzen. Nun wäre Simulation B in der Lage, auf das Abfeuern des Lenkflugkörpers zu reagieren. Die Daten können als Unicast UDP/TCP oder Multicast übertragen werden. Somit bietet die HLA mehr Flexibilität im Bereich der vernetzten Simulation als das Simulationsprotokoll DIS, das seine Daten ausschließlich per Broadcast austauscht. Interface SpecificationDie Schnittstelle zwischen Simulation und RTI ist in der Regel objektorientiert und in einer Programmiersprache wie C++ oder Java implementiert. Die zur Verfügung stehenden Objekte und Funktionen können in folgende Gruppen (service groups) unterteilt werden:
Object Model Template (OMT)Das OMT bildet einen gemeinsamen Rahmen für die Kommunikation zwischen HLA-Föderaten. Es handelt sich um eine standardisierte Schablone für ein Datenmodell und legt fest, welche Daten mit anderen Föderaten ausgetauscht werden können. Das Datenmodell selber kann frei definiert werden. Man unterscheidet zwei Arten von Datenmodellen:
Damit ein Datenaustausch innerhalb einer Föderation möglich ist, müssen die Föderaten mit ihrem SOM zumindest eine gemeinsame Schnittmenge des FOM unterstützen. HLA-RegelnDie HLA-Regeln beschreiben Anforderungen an Föderaten und Föderationen beim Simulationsablauf. Hier werden u. a. die Kommunikationsgrundlagen definiert. Regeln für Federations:
Regeln für Federates:
Die RTI überprüft die Einhaltung der HLA-Regeln, der Implementierungsgrad variiert je nach verwendeter RTI. Insbesondere „Time Management“ wird nicht von allen RTIs unterstützt. StandardsDie HLA ist seit 2000 im IEEE-Standard 1516 definiert, welcher sich in folgende Anteile gliedert:
Weblinks |