High Level Architecture

High Level Architecture

High-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.

Inhaltsverzeichnis

Technischer Überblick

Die High-Level-Architecture basiert auf drei großen Definitionsbereichen

  • Interface Specification: Diese definiert die Schnittstelle zwischen den Einzelsimulationen und der RTI. Dies sind konkret Programmbibliotheken, die die Funktionen und Datenstrukturen für die Kommunikation zwischen RTI und Föderaten beinhalten.
  • Object Model Template (OMT): Das OMT definiert, welche Informationen zwischen den Simulationen ausgetauscht werden sollen und wie diese zu dokumentieren sind.
  • HLA-Regeln: Definiert die Regeln, die eine Simulation einhalten muss, um standardkonform zu sein.

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 per Broadcast austauscht.

Interface Specification

Die 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:

  • Federation Management
  • Declaration Management
  • Object Management
  • Time Management
  • Data Distribution Management
  • Ownership Management
  • Support Services

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:

  • Federation Object Model (FOM): Dieses definiert die Objekte mit Attributen und die Interaktionen mit Parametern, die innerhalb einer Föderation ausgetauscht werden können und ist deshalb föderationsweit bekannt.
  • Simulation Object Model (SOM): Vergleichbar mit FOM, definiert jedoch die Daten, die ein einzelner Föderat austauschen kann.

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-Regeln

Die HLA-Regeln beschreiben Anforderungen an Föderaten und Föderationen beim Simulationsablauf. Hier werden u. a. die Kommunikationsgrundlagen definiert.

Regeln für Federations:

  • Jede Federation muss ein Federation Object Model (FOM) besitzen, das kompatibel zum Object Model Template (OMT) der HLA ist.
  • Alle simulationsbezogenen Objektinstanzen einer Federation sollen seinen Federates zugeordnet sein, nicht der RTI.
  • Während einer Federation Execution muss der gesamte Datenaustausch zwischen seinen Federates über die RTI erfolgen.
  • Die gesamte Kommunikation zwischen einem Federate und der RTI hat unter Verwendung von Diensten der Interface Specification der HLA zu erfolgen.
  • Während einer Federation Execution darf es für ein Attribut einer Instanz zu jedem Zeitpunkt nur höchstens ein Federate geben, in dessen Besitz das Attribut ist.

Regeln für Federates:

  • Jedes Federate muss ein Simulation Object Model (SOM) besitzen, das kompatibel zum Object Model Template (OMT) der HLA ist.
  • Federates sollen Attribute der im SOM definierten Objekte empfangen bzw. aktualisieren, sowie die im SOM definierten Interaktionen senden bzw. empfangen können.
  • Federates sollen Attribute der im SOM definierten Objekte während der Federation Execution dynamisch anderen Federates übereignen bzw. den Besitz von anderen Federates übernehmen können.
  • Federates sollen Bedingungen, unter denen Attribute der im SOM definierten Objekte aktualisiert werden, verändern können.
  • Jedes Federate soll seine lokale Zeit so verwalten können, dass der in der SOM festgelegte Datenaustausch mit anderen Federates korrekt ausgeführt werden kann. (Time Management)

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.

Standards

Die HLA ist seit 2000 im IEEE-Standard 1516 definiert, welcher sich in folgende Anteile gliedert:

  • IEEE 1516-2000: High Level Architecture - Framework and Rules
  • IEEE 1516.1-2000: High Level Architecture - Federate Interface Specification
  • IEEE 1516.1-2000: Errata (16.Okt. 2003)
  • IEEE 1516.2-2000: High Level Architecture - Object Model Template (OMT) Specification
  • IEEE 1516.3-2003: Recommended Practice for HLA Federation Development and Execution Process (FEDEP)

Weblinks


Wikimedia Foundation.

Игры ⚽ Нужна курсовая?

Schlagen Sie auch in anderen Wörterbüchern nach:

  • High Level Architecture — L Architecture de Haut Niveau (High Level Architecture HLA) est une spécification d architecture logicielle (une norme) qui définit comment créer une simulation globale composée de simulations distribuées interagissant sans être recodées. Dans… …   Wikipédia en Français

  • High Level Architecture (simulation) — The High Level Architecture (HLA) is a general purpose architecture for distributed computer simulation systems. Using HLA, computer simulations can communicate to other computer simulations regardless of the computing platforms. Communication… …   Wikipedia

  • High-level synthesis — (HLS), sometimes referred to as C synthesis, electronic system level (ESL) synthesis, algorithmic synthesis, or behavioral synthesis, is an automated design process that interprets an algorithmic description of a desired behavior and creates… …   Wikipedia

  • High-level assembler — High level assemblers are assembly language translators that incorporate features found in modern high level programming languages into an assembler.Some high level assemblers are Borland s TASM, Microsoft s MASM, IBM s HLASM (for z/Architecture… …   Wikipedia

  • High-level emulation — (HLE) is an approach for construction of emulators, specifically of video game console systems. In HLE, instead of trying to accurately recreate the hardware, to create a platform on which the native code can be run, the effort focuses on… …   Wikipedia

  • High-Level Data Link Control — (HDLC) is a bit oriented synchronous data link layer protocol developed by the International Organization for Standardization (ISO). The original ISO standards for HDLC were: *ISO 3309 mdash; Frame Structure *ISO 4335 mdash; Elements of Procedure …   Wikipedia

  • High Level Assembly — (HLA) Développeur Randall Hyde Environnements …   Wikipédia en Français

  • High-level programming language — In computing, a high level programming language is a programming language with strong abstraction from the details of the computer. In comparison to low level programming languages, it may use natural language elements, be easier to use, or more… …   Wikipedia

  • high-level language —    Any machine independent programming language that uses English like syntax in which each statement corresponds to many assembly language instructions. High level languages free programmers from dealing with the underlying machine architecture… …   Dictionary of networking

  • IBM High Level Assembler (HLASM) — For a discussion of high level assemblers in general, see High level assembler. Wikipedia by [SERVERlocalurl:NAMESPACE:HLASM|action=edit expanding it] . IntroductionHLASM is IBM s high level assembler product for its z/OS, z/VSE, z/VM and z/TPF… …   Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”