„Agentenorientierte Programmierung“ – Versionsunterschied
[gesichtete Version] | [gesichtete Version] |
K Bot: Ergänze: hu:Szoftver ágens, sv:Programvaruagent |
TMg (Diskussion | Beiträge) Allgemeine Überarbeitung, vor allem Rotlinks entfernt |
||
Zeile 1: | Zeile 1: | ||
{{Überarbeiten}} |
{{Überarbeiten}} |
||
'''Agentenorientierte Programmierung''' ist eine Art der Programmierung, die auf der Theorie der agentenorientierten Paradigmen von [[Yoav Shoham]] basiert |
'''Agentenorientierte Programmierung''' ist eine Art der Programmierung, die auf der Theorie der agentenorientierten Paradigmen von [[Yoav Shoham]] basiert und hauptsächlich in der deklarativen [[Programmiersprache]] [[PROLOG]] angewendet wurde. |
||
1993 hat Shoham agentenorientierte Paradigmen veröffentlicht, die auf so genannten „mentalen Zuständen“ ('' |
1993 hat Shoham agentenorientierte Paradigmen veröffentlicht, die auf so genannten „mentalen Zuständen“ (''mental states'') basieren, womit der innere, das heißt von außen nicht sichtbare Zustand von [[Softwareagent]]en gemeint ist. Eine formale Sprache beschreibt die „mentalen Zustände“, die durch Annahmen (''beliefs'') und Verpflichtungen (''commitments'') bestimmt werden. |
||
* Handlungen ('' |
* Handlungen (''actions'') werden beschrieben, z. B. REQUEST, INFORM. |
||
* ''Beliefs'' sind Annahmen, die der Agent über seine Umwelt hat, also sämtliche Daten, die ihm zur Verfügung stehen. |
* ''Beliefs'' sind Annahmen, die der Agent über seine Umwelt hat, also sämtliche Daten, die ihm zur Verfügung stehen. |
||
* ''Commitments'' sind Zusicherungen, die der Agent seiner Umwelt (andere Agenten) gibt. Sie besagen, dass wenn der Agent eine bestimmte Nachricht empfängt während er sich in einem bestimmten mentalen Zustand befindet, er eine bestimmte Aktion ausführt. |
* ''Commitments'' sind Zusicherungen, die der Agent seiner Umwelt (andere Agenten) gibt. Sie besagen, dass wenn der Agent eine bestimmte Nachricht empfängt, während er sich in einem bestimmten mentalen Zustand befindet, er eine bestimmte Aktion ausführt. |
||
* Herkömmliche Programme werden in einen [[Wrapper (Software)|Wrapper]] gehüllt, um sie als Agenten betrachten zu können. Shoham spricht von „Agentifizierung“ ('' |
* Herkömmliche Programme werden in einen [[Wrapper (Software)|Wrapper]] gehüllt, um sie als Agenten betrachten zu können. Shoham spricht von „Agentifizierung“ (''agentification''). |
||
* Es wird eine zeitpunktbasierte [[Temporale Logik der Aktionen|Temporale Logik]] verwendet. |
* Es wird eine zeitpunktbasierte [[Temporale Logik der Aktionen|Temporale Logik]] verwendet. |
||
== |
== Sprachen zur agentenorientierten Programmierung == |
||
⚫ | '''PLACA''' ist eine Weiterentwicklung der eher theoretischen [[Programmiersprache]] AGENT-0. PLACA wurde an der [[Stanford University]] in Kalifornien von Sarah Rebecca Thomas entwickelt. Im Gegensatz zu AGENT-0 hat PLACA den Vorteil, dass nicht nur Anfragen von anderen Agenten beantwortet sowie Anfragen an diese gerichtet werden können, sondern in PLACA auch direkte Mechanismen vorhanden sind, um ein Ziel zu verfolgen und mehrere Aktionen hintereinander auszuführen, um ein Ziel zu erreichen. Jeder Agent in PLACA besitzt eine geordnete Liste mit Intentionen (Zielen) und eine geordnete Liste mit Plänen. Um diese Listen zu verwalten hat PLACA folgende syntaktische Struktur: |
||
* [[3APL]] |
|||
⚫ | |||
* [[AgentSpeak(L)]] |
|||
⚫ | |||
* [[ConGolog]] |
|||
⚫ | |||
* [[LALO]] |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
== Literatur == |
== Literatur == |
||
Zeile 26: | Zeile 23: | ||
* Yoav Shoham: ''Agent-Oriented Programming''. Artificial Intelligence 60 (1993) 51-92, Stanford, CA, USA |
* Yoav Shoham: ''Agent-Oriented Programming''. Artificial Intelligence 60 (1993) 51-92, Stanford, CA, USA |
||
* Yoav Shoham: ''An overview of agent-oriented programming''. MIT Press, Cambridge, MA, USA 1997, ISBN 0-262-52234-9 |
* Yoav Shoham: ''An overview of agent-oriented programming''. MIT Press, Cambridge, MA, USA 1997, ISBN 0-262-52234-9 |
||
* Matthew A. Huntbach, Graem A. Ringwood: ''Agent-Oriented Programming''. Springer, Berlin 1999, ISBN |
* Matthew A. Huntbach, Graem A. Ringwood: ''Agent-Oriented Programming''. Springer, Berlin 1999, ISBN 3-540-66683-4 |
||
[[Kategorie:Programmierung]] |
[[Kategorie:Programmierung]] |
Version vom 11. Oktober 2012, 22:16 Uhr
Agentenorientierte Programmierung ist eine Art der Programmierung, die auf der Theorie der agentenorientierten Paradigmen von Yoav Shoham basiert und hauptsächlich in der deklarativen Programmiersprache PROLOG angewendet wurde.
1993 hat Shoham agentenorientierte Paradigmen veröffentlicht, die auf so genannten „mentalen Zuständen“ (mental states) basieren, womit der innere, das heißt von außen nicht sichtbare Zustand von Softwareagenten gemeint ist. Eine formale Sprache beschreibt die „mentalen Zustände“, die durch Annahmen (beliefs) und Verpflichtungen (commitments) bestimmt werden.
- Handlungen (actions) werden beschrieben, z. B. REQUEST, INFORM.
- Beliefs sind Annahmen, die der Agent über seine Umwelt hat, also sämtliche Daten, die ihm zur Verfügung stehen.
- Commitments sind Zusicherungen, die der Agent seiner Umwelt (andere Agenten) gibt. Sie besagen, dass wenn der Agent eine bestimmte Nachricht empfängt, während er sich in einem bestimmten mentalen Zustand befindet, er eine bestimmte Aktion ausführt.
- Herkömmliche Programme werden in einen Wrapper gehüllt, um sie als Agenten betrachten zu können. Shoham spricht von „Agentifizierung“ (agentification).
- Es wird eine zeitpunktbasierte Temporale Logik verwendet.
Sprachen zur agentenorientierten Programmierung
PLACA ist eine Weiterentwicklung der eher theoretischen Programmiersprache AGENT-0. PLACA wurde an der Stanford University in Kalifornien von Sarah Rebecca Thomas entwickelt. Im Gegensatz zu AGENT-0 hat PLACA den Vorteil, dass nicht nur Anfragen von anderen Agenten beantwortet sowie Anfragen an diese gerichtet werden können, sondern in PLACA auch direkte Mechanismen vorhanden sind, um ein Ziel zu verfolgen und mehrere Aktionen hintereinander auszuführen, um ein Ziel zu erreichen. Jeder Agent in PLACA besitzt eine geordnete Liste mit Intentionen (Zielen) und eine geordnete Liste mit Plänen. Um diese Listen zu verwalten hat PLACA folgende syntaktische Struktur:
- (INTEND x) – Der PLACA-Agent versucht, die Aussage y wahr zu machen. Daher wird x zur Liste der Intentionen hinzugefügt.
- (ADOPT x) – Fügt die Intention bzw. den Plan zur Liste der Intentionen bzw. Pläne hinzu.
- (Drop x) – Löscht die Intentionen x bzw. den Plan x aus der Liste der Intentionen bzw. Pläne.
- (CAN-DO x) – Der Agent meldet, dass er die Aktion x ausführen kann.
CAROL5 wurde in C++ implementiert, um Gruppenlernsysteme (social learning systems) zu implementieren.
Literatur
- Yoav Shoham: Agent-Oriented Programming. Artificial Intelligence 60 (1993) 51-92, Stanford, CA, USA
- Yoav Shoham: An overview of agent-oriented programming. MIT Press, Cambridge, MA, USA 1997, ISBN 0-262-52234-9
- Matthew A. Huntbach, Graem A. Ringwood: Agent-Oriented Programming. Springer, Berlin 1999, ISBN 3-540-66683-4