Agent Communications Necessity Communication languages Communication architectures.

Slides:



Advertisements
Similar presentations
Ontology-Based Computing Kenneth Baclawski Northeastern University and Jarg.
Advertisements

8-1 LECTURE 8: Agent Communication An Introduction to MultiAgent Systems
Semantic Web Thanks to folks at LAIT lab Sources include :
CS570 Artificial Intelligence Semantic Web & Ontology 2
1 Computer Science Department California Polytechnic State University San Luis Obispo, CA, U.S.A. Franz J. Kurfess CPE/CSC 580: Intelligent Agents 1.
Implementation Advice: When Intelligent Agents Meet RDF 2004 년 1 학기 - 인간과 컴퓨터 상호작용 인공지능연구실, 부산대학교 최성자.
OASIS Reference Model for Service Oriented Architecture 1.0
Software Agent -communication-. Outline Overview Speech act theory Agent communication languages Summary 1/35.
A New Computing Paradigm. Overview of Web Services Over 66 percent of respondents to a 2001 InfoWorld magazine poll agreed that "Web services are likely.
INTERACTION AND COMMUNICATION. Coordination A property of interaction among a set of agents performing some activity in a shared state. The degree of.
Dynamic Ontologies on the Web Jeff Heflin, James Hendler.
Multi-Agent Systems Chapter 2 Adapted (with permission) from Adina Magda Florea
Multiagent Systems and Societies of Agents
Communication in multi-agent system
Agent Communication Languages CSE5610- Intelligent Software Systems Agent Communication Languages.
COMP 6703 eScience Project Semantic Web for Museums Student : Lei Junran Client/Technical Supervisor : Tom Worthington Academic Supervisor : Peter Strazdins.
Presentation on Formalising Speech Acts (Course: Formal Logic)
Agent Communication Language. Agent Coordination Agents communicate in order to achieve better the goals of themselves or of the society Coordination.
From SHIQ and RDF to OWL: The Making of a Web Ontology Language
KQML as an Agent Communication Language Tim Finin, Yannis Labrou, James Mayfield.
Agents Communication Languages (ACL) Dumitru Roman Digital Enterprise Research Institute
Processing of structured documents Spring 2003, Part 6 Helena Ahonen-Myka.
Knowledge Mediation in the WWW based on Labelled DAGs with Attached Constraints Jutta Eusterbrock WebTechnology GmbH.
Computer Science 30/08/20151 Agent Communication BDI Communication CPSC /CPSC Rob Kremer Department of Computer Science University of Calgary.
RDF (Resource Description Framework) Why?. XML XML is a metalanguage that allows users to define markup XML separates content and structure from formatting.
Topic 5: Communication and Negotiation Protocols
PS429 Social and Public Communication PS429 Social and Public Communication Week 4 (25/10/2005) Reading group discussion.
Knowledge Representation Ontology are best delivered in some computable representation Variety of choices with different: –Expressiveness The range of.
8-1 LECTURE 7: Agent Communication Based on An Introduction to MultiAgent Systems
Agent Communication The nature of communication Indirect communication
8-1 LECTURE 7: Agent Communication Based on An Introduction to MultiAgent Systems
The Semantic Web Service Shuying Wang Outline Semantic Web vision Core technologies XML, RDF, Ontology, Agent… Web services DAML-S.
Of 39 lecture 2: ontology - basics. of 39 ontology a branch of metaphysics relating to the nature and relations of being a particular theory about the.
SIF8072 Distributed Artificial Intelligence and Intelligent Agents 13 February 2003 Lecture 5: Agent Communication Lecturer:
Spoken dialog for e-learning supported by domain ontologies Dario Bianchi, Monica Mordonini and Agostino Poggi Dipartimento di Ingegneria dell’Informazione.
EEL 5937 Agent communication EEL 5937 Multi Agent Systems Lecture 10, Feb. 6, 2003 Lotzi Bölöni.
ARTIFICIAL INTELLIGENCE [INTELLIGENT AGENTS PARADIGM] Professor Janis Grundspenkis Riga Technical University Faculty of Computer Science and Information.
Metadata. Generally speaking, metadata are data and information that describe and model data and information For example, a database schema is the metadata.
“D.A.I. & S.M. for KM” a synergy of complementary domains and challenges  the semantic web addicted people “please, raise your hands !”
LOGIC AND ONTOLOGY Both logic and ontology are important areas of philosophy covering large, diverse, and active research projects. These two areas overlap.
An Ontological Framework for Web Service Processes By Claus Pahl and Ronan Barrett.
Semantic Web - an introduction By Daniel Wu (danielwujr)
Introduction to Server-Side Web Development Introduction to Server-Side Web Development using JSP and Web Services JSP and Web Services 18 th March 2005.
©Ferenc Vajda 1 Semantic Grid Ferenc Vajda Computer and Automation Research Institute Hungarian Academy of Sciences.
Proposed NWI KIF/CG --> Common Logic Standard A working group was recently formed from the KIF working group. John Sowa is the only CG representative so.
Design of Multi-Agent Systems Teacher Bart Verheij Student assistants Albert Hankel Elske van der Vaart Web site
AOSE Multi-Agent Interaction. Agents and Interaction Interaction forms the basis of an agents collaborative problem solving capabilities. –Agents are.
Ontology-Based Computing Kenneth Baclawski Northeastern University and Jarg.
Christoph F. Eick University of Houston Organization 1. What are Ontologies? 2. What are they good for? 3. Ontologies and.
Introduction to Semantic Web Service Architecture ► The vision of the Semantic Web ► Ontologies as the basic building block ► Semantic Web Service Architecture.
Trustworthy Semantic Webs Dr. Bhavani Thuraisingham The University of Texas at Dallas Lecture #4 Vision for Semantic Web.
Issues in Ontology-based Information integration By Zhan Cui, Dean Jones and Paul O’Brien.
EEL 5937 Agent communication EEL 5937 Multi Agent Systems Lotzi Bölöni.
The Semantic Web and Ontology. The Semantic Web WWW: –syntactic transmission of information –only processible by human – no semantic conservation of the.
Intelligent Agents: Technology and Applications Agent Communications IST 597B Spring 2003 John Yen.
The Semantic Web. What is the Semantic Web? The Semantic Web is an extension of the current Web in which information is given well-defined meaning, enabling.
A Portrait of the Semantic Web in Action Jeff Heflin and James Hendler IEEE Intelligent Systems December 6, 2010 Hyewon Lim.
Agent Communication Languages Speech act theory Speech act theory Semantics of languages Semantics of languages KQML KQML FIPA ACL FIPA ACL Comparison.
EEL 5937 Content languages EEL 5937 Multi Agent Systems Lecture 10, Feb. 6, 2003 Lotzi Bölöni.
Enable Semantic Interoperability for Decision Support and Risk Management Presented by Dr. David Li Key Contributors: Dr. Ruixin Yang and Dr. John Qu.
다중 에이전트의 의사소통 모델에 관한 연구 - KQML 언어의 의미론을 중심으로 - 인지과학 협동과정 김 경수.
Agent Communication Michael Floyd SYSC 5103 – Software Agents November 13, 2008.
OWL (Ontology Web Language and Applications) Maw-Sheng Horng Department of Mathematics and Information Education National Taipei University of Education.
OKBC (Open Knowledge Base Connectivity) An API For Knowledge Servers
LECTURE 9: Agent Communication
The Semantic Web By: Maulik Parikh.
ece 627 intelligent web: ontology and beyond
Chapter 2 Database Environment.
AGENT FRAMEWORK By- Arpan Biswas Rahul Gupta.
Presentation transcript:

Agent Communications Necessity Communication languages Communication architectures

Motivation for Agent Communication ”Language is a very difficult thing to put into words” – Voltaire 1.Communication is required for cooperation between agents 2.Societies can perform tasks no individual agent can 3.Communicating agents need only know a ”common language” 4.Supports heterogenous agents

The nature of communication Human communication  Communication is the intentional exchange of information brought about by the production and perception of signs drawn from a shared system of conventional signs (AIMA, Russell&Norvig)  language  Communication seen as an action (communicative act) and as an intentional stance Component steps of communication SpeakerHearer  Intention  Perception  Generation  Analysis  Synthesis  Disambiguation  Incorporation 3 Syntax Semantics Pragmatics

 The environment provides a computational infrastructure where interactions among agents take place. The infrastructure includes protocols for agents to communicate and protocols for agents to interact 4 Artificial Communication in a multi-agents system

ACL Agent Communication Language (ACL) is based on speech-act theory.speech-act theory Speech Acts...speaking a language is performing speech acts, acts such as making statements, giving commands, asking questions, making promises, and so on. - John Searle

Speech Acts Speech act theories are pragmatic theories of language, i.e., theories of language use: they attempt to account for how language is used by people every day to achieve their goals and intentions The origin of speech act theories are usually traced to Austin ’ s 1962 book, How to Do Things with Words

Theory of Speech Acts J. Austin - How to do things with words, 1962, J. Searle - Speech acts, 1969 A speech act has 3 aspects:  locution = physical utterance( 発話 ) by the speaker  illocution = the intended meaning of the utterance by the speaker (performative)  prelocution = the action that results from the locution Alice told Tom: "Would you please close the door" locutionillocutioncontent prelocution: door closed (hopefully!) Illocutionary aspect - several categories oAssertives, which inform: the door is shut oDirectives, which request: shut the door, can pelicans fly? oCommissives, which promise something: I will shut the door oPermissive, which gives permission for an act: you may shut the door oProhibitives, which ban some act: do not shut the door oDeclaratives, which causes events: I name you king of Ruritania oExpressives, which express emotions and evaluations: I am happy 7

An utterance is a spoken word or string of spoken words. At the simplest level, to utter is simply to say a word with no particular forethought or intention to communicate a meaning. Propositional Utterance is a more meaningful type of utterance makes reference to or describes a real or imaginary object. An illocutionary utterance is spoken with the intention of providing information, soliciting answers to questions, giving praise, and so on Perlocutionary utterances, on the other hand, do attempt to effect a change. The Speech Act Model

ACLs – communication as action - communicative acts - standard formats for the exchange of messages

KQML and KIF The best known ACL is KQML, developed by the ARPA knowledge sharing initiative KQML is comprised of two parts: –the knowledge query and manipulation language (KQML) –the knowledge interchange format (KIF)

KQML KQML is an ‘ outer ’ language, that defines various acceptable ‘ communicative verbs ’, or performatives Example performatives: –ask-if ( ‘ is it true that... ’ ) –perform ( ‘ please perform the following action... ’ ) –tell ( ‘ it is true that... ’ ) –reply ( ‘ the answer is... ’ )

Categories of KQML performatives 1.Basic Query performatives 2.Multi-response query performatives 3.Response performatives 4.Generic Informational performatives 5.Generator performatives 6.Capability performatives 7.Networking performatives

(ask-one :sender joe :receiver ibm-stock :reply-with ibm-stock :language PROLOG :ontology NYSE-TICKS :content (price ibm ?price) ) 13 (tell :sender willie :receiver joe :reply-with block1 :language KIF :ontology BlockWorld :content (AND (Block A)(Block B) (On A B)) ) 1. Query performatives: ask-one, ask-all, ask-if, stream-all,... (stream-all:sender willie :receiver ibm-stock :content (price ?VL ?price ) ) (standby :content (stream-all :content (price ?VL ?price) ) ask-one(P) tell(P) tell(P1) stream-all(P) tell(P2) eos tell(P1,P2,...) ask-all(P) B B B A A A

14 4. Generic informational performatives: tell, untell, insert, delete,... In fact, KQML contains only 2 types of illocutionary acts: assertives and directives + facilitator and network-related performatives (no necessarily speech acts) tell(P) untell(P) delete(P) insert(P) 2. Generator performatives: standby, ready, next, rest, discard, generate, Network performatives: register, unregister, forward, route, Response performatives: reply, sorry Capability performatives: advartise, subscribe, recommend... Facilitator A A B B

15 Facilitator agent = an agent that performs various useful communication services: kmaintaining a registry of service names (Agent Name Server) kforwarding messages to named services krouting messages based on content kmatchmaking between information providers and clients kproviding mediation and translation services tell(P) ask(P) subscribe(ask(P)) tell(P) advertise(ask(P)) tell(P) recruit(ask(P)) ask(P) recommend(ask(P))advertise(ask(P)) tell(P) ask(P) reply(B) A A A A B B B B

KQML Examples I A  B - (tell (> 3 2)) A  B - (perform (print ”hello” t)) B  A – (reply done) A  B - (ask-if (> (size chip1) (size chip2) )) B  A – (reply true) A  B - (subscribe (position ?x ?r ?c)) B  A – (tell (position chip1 8 10)) B  A – (tell (position chip2 8 46)) B  A – (tell (position chip3 3 64)) A  B - (unsubscribe (position ?x ?r ?c))

(ask-one :content (geoloc TRD (?long ?lat)) :ontology geo-model3) (ask-all :content ”price(IBM, [?price, ?time])” :receiver stock-server :language standard-prolog :ontology NYSE-TICS) KQML Examples II

KIF – Knowledge Interchange Format KIF is a language for expressing message content Used to state: Properties of things in a domain (e.g., “ Noam is chairman ” ) Relationships between things in a domain (e.g., “ Amnon is Yael ’ s boss ” ) General properties of a domain (e.g., “ All students are registered for at least one course ” )

KIF examples - I Terms: (size chip1) (+ (sin theta)(cos theta)) (if (> theta 0) theta (-theta)) (setofall ?x (above ?x chip1)) Sentences: (Prime ) (> (sin theta) (cos phi)) (not (> (sin theta) 0))) (> (* (width chip1) (length chip2))(*(width chip1)(length chip2))) (=> (> ?x 0) (positive ?x))

KIF Examples - II Definitions: (defrelation leq(?x ?y) := (not (> ?x ?y))) (defrelation natural(?x) := (and (integer ?x) (>= ?x 0))) Procedures: (progn (fresh_line t)(print ”Hi!”)(fresh_line t)) Meta-Knowledge: (believes John ’(material moon jarlsberg)) (=> (believes John ?p) (believes Mary ?p)) Rules: (<<= (flies ?x)(bird ?x))

KQML Statement Structure KQML Statements consists of 1.A performative 2.Parameters and context information General syntax: (KQML-performative :sender word :receiver word :language word :ontology word :content expression...) A formal specification of a set of terms is known as an ontology The knowledge sharing effort has associated with it a large effort at defining common ontologies - software tools like ontolingua

22 Ontologies Ontology = a specification of objects, concepts, and reationships in a particular domain; it comprises a vocabulary, a domain theory and a conceptual schemata to describe organization and interpretation An ontology is more than a taxonomy of classes, it must also describe relationships  x (Block x)  (PhysicalObject x) Instead of (Block A) (InstanceOf A Block) (Class Block) Hierarchy (Class PhysicalObjects) (SubclassOf Block PhysicalObjects)  x,y,z (InstanceOf x y)  (SubclassOf y z)  (InstanceOf x z) Ontology editors frame-based KR systems that allow the user to define an ontology and its components: classes, instances, relationships, and functions Person PupilStudEmpl Sun_EIBM_E Person Empl Woman Stud Man JoeAlice JoeAlice

KQML Agent naming System for mapping agents into names is important in most ACLs KQML assumes that names are local –A can register with B under the name Alice –A can register with C under the name Albert Doesn’t preclude the use of a central Agent Name Server, an architecture used by most systems What gets registered under a name? Contact information like: name(amundbot, tcpip, [cavenan.idi.ntnu.no,80]). name(amundbot,http,[

Facilitators - I Agents performing various (useful) communication services 1.Maintain registry of service names 2.Forward messages to named services 3.Route messages based on content 4.Provide ”matchmaking” 5.Provide mediation and translation services

Routers Content-independent message routers Each KQML-agent is associated with its own separate router process Router handles all outgoing/incoming ACL messages Outgoing messages can specify a particular agent address (to agent or router) Message can specify a description of context Delivery of messages is not guaranteed

Other ACLs Telescript – supports mobile computing FIPA ACL – competing/extending KQML FIPA vs KQML –Both are based on speech act –Different set of performatives –FIPA has a more formal basis –FIPA can describe interaction protocols –FIPA is probably becoming the standard ACL

More recently, the Foundation for Intelligent Physical Agents (FIPA) started work on a program of agent standards — the centerpiece is an ACL Basic structure is quite similar to KQML: –performative 20 performative in FIPA –housekeeping e.g., sender, etc. –content the actual content of the message FIPA’s Agent Communication Language Specifications

FIPA Example (inform :senderagent1 :receiveragent5 :content(price good ) :languagesl :ontologyhpl-auction )

FIPA

“ Inform ” and “ Request ” “ Inform ” and “ Request ” are the two basic performatives in FIPA. All others are macro definitions, defined in terms of these. The meaning of inform and request is defined in two parts: –pre-condition what must be true in order for the speech act to succeed –“ rational effect ” what the sender of the message hopes to bring about

“ Inform ” For the “ inform ” performative … The content is a statement. Pre-condition is that sender: –holds that the content is true –intends that the recipient believe the content –does not already believe that the recipient is aware of whether content is true or not

“ Request ” For the “ request ” performative … The content is an action. Pre-condition is that sender: –intends action content to be performed –believes recipient is capable of performing this action –does not believe that receiver already intends to perform action

What is FIPA? The Foundation for Intelligent Physical Agents (FIPA) is a non-profit association. FIPA’s purpose is to promote the success of emerging agent-based applications, services and equipment. FIPA’s goal is pursued by making available in a timely manner, internationally agreed specifications that maximise interoperability across agent-based applications, services and equipment.

Who is FIPA? FIPA operates through the open international collaboration of member organisations, which are companies and universities active in the agent field. Companies: Alcatel, Boeing, British Telecom, Deutsche Telekom, France Telecom, Fujitsu, Hitatchi, HP, IBM, Fujitsu, Hewlett Packard, IBM, Intel, Lucent, NEC, NHK, NTT, Nortel, Siemens, SUN, Telia, Toshiba, etc. Universities and Research Institutes: GMD, EPFL, Imperial, IRST, etc. Government Agencies: DARPA

FIPA Encodings and package Fipa supports three main types of syntax encoding: 1.Extensible Markup Language – XML 2.Proprietary Binary format 3.Lisp-like format Separates between Envelopes and Messages

Example - XML-encoded FIPA ACL fipa.acl.rep.xml.std T no encryption

Binary encoded FIPA XML 1. 0xfe 0x00 0x97 0x12 0x20 0x31 0x11 0x06 0x19 0x15 0x37 0x62 0x59 0x20 0x02 0x03 0x02 2.‘ r ’ ‘ e ’ ‘ c ’ ‘ e ’ ‘ i ’ ‘ v ’ ‘ e ’ ‘ r ’ ’ ‘ f ’ ‘ o ’ ‘ o ’ ‘. ’ ‘ c ’ ‘ o ’ ‘ m ’ 0x x02 ‘ h ’ ‘ t ’ ‘ t ’ ‘ p ’ ‘ : ’ ‘ / ’ ‘ / ’ ‘ f ’ ‘ o ’ ‘ o ’ ‘. ’ ‘ c ’ ‘ o ’ ‘ m ’ ‘ / ’ ‘ a ’ 4.‘ c ’ ‘ c ’ 0x00 0x01 0x01 0x02 ‘ s ’ ‘ e ’ ‘ n ’ ‘ d ’ ‘ e ’ ‘ r ’ ’ ‘ b ’ ‘ a ’ ‘ r ’ ‘. ’ 5.‘ c ’ ‘ o ’ ‘ m ’ 0x00 0x02 ‘ h ’ ‘ t ’ ‘ t ’ ‘ p ’ ‘ : ’ ‘ / ’ ‘ / ’ ‘ b ’ ‘ a ’ ‘ r ’ ‘. ’ ‘ c ’ 6.‘ o ’ ‘ m ’ ‘ / ’ ‘ a ’ ‘ c ’ ‘ c ’ 0x00 0x01 0x01 0x08 ‘ n ’ ‘ o ’ ‘ ’ ‘ e ’ ‘ n ’ ‘ c ’ ‘ r ’ 7.‘ y ’ ‘ p ’ ‘ t ’ ‘ i ’ ‘ o ’ ‘ n ’ 0x00 0x0a ‘ h ’ ‘ t ’ ‘ t ’ ‘ p ’ ‘ : ’ ‘ / ’ ‘ / ’ ‘ b ’ ‘ a ’ 8.‘ r ’ ‘. ’ ‘ c ’ ‘ o ’ ‘ m ’ ‘ / ’ ‘ a ’ ‘ c ’ ‘ c ’ 0x00 0x20 0x31 0x11 0x06 0x19 0x15 0x x62 0x59 0x20 0x03 ‘ 1 ’ ‘ 2 ’ ‘ 3 ’ ‘ 4 ’ ‘ 5 ’ ‘ 6 ’ ‘ 7 ’ ‘ 8 ’ ‘ 9 ’ 0x00 0x01 10.

Shortcomings of current ACLs Intentional level description: which mental attitudes, what definitions? Problems with mental attitudes: from theory to practice Can all desirable communication primitives be modeled after speech acts? Should they? Flexible description of agents’ capabilities and advertising of such capabilities. How can we test an agent’s compliance with the ACL? Ease of extending an ACL

Conclusions of Current ACLs Agent Communication Languages have a common basis – speech act Syntax is well specified, but current research is on describing semantics

Motivation for KIF (Knowledge Interchange Format) Creating language for development of intelligent applications Creating language for common interchange format Note: KIF is not intended for interaction with humans KIF is not intended to be internal representation for knowledge within computer programs

KIF Features 1.Prefix version of 1 st order predicate calculus (logic) 2.Declarative semantics 3.Logically comprehensive 4.Provides representation of knowledge about representation of knowledge Additional features: Translatability Readability Usability

KIF General Overview Variables: Operators: Term Operators: listof, if,.. Sentence Operators: not, and, /=,... Rule Operators: =>>,.. Definition Operators: defobject, deffunction Constants: object, function, relational, logical Expressions: Word or a finite sequence of words (i.e. Sentences)

Agent Vocabularies Agents should use words consistently Open-ended Dictionary Each word has: –English description for understanding by humans –KIF (or alternative) for understanding by computers Dictionary would contain multiple ontologies for many areas

Ontology Inference Layer – OIL OIL is used to specify and exchange ontologies Three roots of OIL: 1.Description Logics 2.Frame-based Systems 3.Web-standards: XML and RDF Small, not too expressive (as possibly the case with Ontolingua)

OIL Example ontology-container: title: ”african animals” subject: ”animal, food, vegetarians” description: ”example ontology describing african animals” Language ”en-uk” Source ontology-definitions: slot-def: eats inverse: is-eaten-by class-def: animal class-def: plant

Terminology of Agent Communication Speech Act – Formal subset of natural language representing actions ACL – Agent Communication Language FIPA - Foundation for Intelligent Physical Agents KQML – Knowledge Query and Manipulation Language Ontology – ”World Model”, formal description of agent domain Encoding – syntactic representation of ACL messages ACC – Agent Communication Channel (FIPA) KSE – Knowledge Sharing Effort KIF – Knowledge Interchange Format Router – entity that sends incoming messages in correct ”direction” Facilitator – An agent that includes a Router

Semantics on the Web - terminology Semantic Web RDF – Resource Decription Framework OIL – Open Inference Layer XML/XML Schema Ontolingua OKBC – Open Knowledge Base Connectivity DAML – DARPA Agent Markup Language DAML-S – Service description language based on DAML UDDI – Universal Description, Discovery and Integration WSDL – Web Services Description Language SHOE – Simple HTML Ontology Extensions ebXML – e-business XML

Exercise Read the paper: kqml-acl.pdf Present your understanding of the paper in minutes in next lecture.