Comunicação entre Agentes Inteligentes

Slides:



Advertisements
Apresentações semelhantes
Terminologia Definicao Construção Exemplos
Advertisements

Concepção da linguagem, ou seja, porque e como ela é como é?
Comunicação entre processos distribuídos
1 ZEUS Agentes Inteligentes e Sistemas Multi-agente Ferramentas de Contrução de Agentes IST- 2003/2004 Ana Paiva.
O Essencial sobre Linguagens de Programação Luís Caires Maio 2005.
Padrão de Projeto Interpreter
Sistema para Gerenciamento de Redes Baseado em Agentes Móveis
Linguagens de Comunicação de Agentes
Comunicação entre Agentes
Sistemas Baseados em Conhecimento
Modelos Baseados em Agentes
Redes de Computadores 2 - Camada de Aplicação (HTTP) –
Programação Orientada a Agentes Franklin Souza Ramalho
Programação Lógica: PROLOG
Programação Concorrente
JADE Java Agent DEvelopment Framework
Sincronização de Processos (6) - Troca de Mensagens -
UFRPE – Modelos de Qualidade Teresa Maciel
Camada de Transporte: Portas, Sockets, Aplicações em Rede
Software de Rede Willamys Araújo.
Universidade do Vale do Rio dos Sinos - São Leopoldo -
Plano de Aula Introdução Conceitos Básicos KQML FIPA ACL
Segurança na Web SSL - Secure Socket Level TLS - Transport Layer Security SET – Secure Electronic Transaction.
Web Semântica Mineração na Web – if796 Subtitle.
Desenvolvendo Sistemas Multiagentes com JADE
Exame de Defesa de Mestrado
Sistemas Distribuídos
Tópicos de Sistemas de Informação A
Web Services Uninorte Semana de Tecnologia da Informação
REDES DE COMPUTADORES Prof. Deivson
CORBA e Desenvolvimento Baseado em Componentes
CCNA 1 – Modelos OSI e TCP/IP
Marcela Bezerra da Silva Cin - UFPE
Plano de Aula Introdução Conceitos Básicos KQML FIPA ACL
1 Mobilidade de Código com μcode Projeto Giga Alexandre Lages
MODELO ESSENCIAL Modelo Ambiental
FIPA THE FOUNDATION FOR INTELLIGENT PHYSICAL AGENTS
Aulas 2 e 3 – Java – Prof. Marcelo Heitor # O método main e argumentos na linha de comando; # Fluxo padrão de entrada e saída; # A classe JOptionPane;
Concorrência e thread Petrônio Júnior(pglj) Márcio Neves(mmn2)
Paradigmas da Programação – Semestre 1 – Aula 9 Professor: Eduardo Mantovani )
Agentes Inteligentes e Sistemas Multi- agente (UD 8) Comunicação IST- 2004/2005.
Da Introdução à Prática
IIS Web Server.
FERRAMENTAS DE GERENCIAMENTO Aula 01
Inteligência Artificial Web Semântica
7 © 2005 by Pearson Education SIP  Session Initiation Protocol  Desenvolvido pelo IETF Visão de longo prazo do SIP  Todas chamadas telefônicas.
OMNeT++.
Laboratório de Programação
Padrões de Interação com o Usuário
Plano de Aula Agentes que Interagem Conceitos Básicos FIPA ACL
1 Comunicação em SMA Introdução Conceitos Básicos KQML FIPA ACL Exemplo Ryan Albuquerque e Patricia Tedesco.
Comunicação em Sistemas Multiagentes
Aula Prática 1 Monitoria IP/CC (~if669) (A partir do slide elaborado por Luís Gabriel)
RMI Objetos Distribuídos Luiz C. D´oleron SCJP
Projeto Supervisionado no Desenvolvimento de Aplicações Profissionais na Web Introdução a Aplicações Web.
Sistemas Multi-Agentes Comunicação e Cooperação. Motivação O uso de agentes individuais pode não ser adequado para todas as situações de problemas que.
JR: Flexible Distributed Programming in an Extended Java Elmário Gomes Dutra Jr. Gustavo Romano.
1 Comunicação em SMA Introdução Conceitos Básicos KQML FIPA ACL Exemplo Ryan Albuquerque e Patricia Tedesco.
Camada de Aplicação Prof. Horácio. Objetivo Apresentar os detalhes específicos dos tipos de aplicação; Apresentar o modelo cliente-servidor; Apresentar.
Sistemas Multiagentes Uma Visão geral Motivação IA Distribuída - por que? Justificativas e Vantagens de SMA Conceitos Básicos Comunicação em SMA KQML FIPA.
Protocolos de Comunicação e Passagem de Mensagens
Aula: Arquiteturas de redes: modelo de referência OSI 04/12/2010.
YOUR LOGO Tópicos Avançados em Internet Prof. Lincoln Ferreira Dantas Sistemas de Informação UNIESP – Presidente Epitácio.
Redes de Computadores e Aplicações – Camada de aplicação IGOR ALVES.
Web Services / SOA. O cenário de TI nas corporações Novas tendências batiam à porta das corporações Migraram o foco do “gerenciamento de dados” para o.
ONTOLOGIAS NO CONTROLE DA ADAPTAÇÃO AO CONTEXTO EM ESPAÇO UBÍQUO ONTOLOGIAS NO CONTROLE DA ADAPTAÇÃO AO CONTEXTO EM ESPAÇO UBÍQUO Nelsi Warken, Luiz A.
Curso Superior em Redes de Computadores Camada de Aplicação Prof. Sales Filho.
Servidor WEB IGOR ALVES. O protocolo HTTP 1990 surgimento da aplicação www Grande quantidade de informação que pode ser acessada por demanda Buscadores.
Transcrição da apresentação:

Comunicação entre Agentes Inteligentes Ryan Leite Albuquerque < ryan@cesar.org.br >

Motivação : Ubiqüidade Ubiqüidade: Do latim “ubiquu” O que está em todo lugar a toda hora Ubiqüidade Computacional Os serviços computacionais poderão ser usados em toda parte e a qualquer hora “Jetsons”, “Sexto Dia”, “Matrix”. Algo familiar ? Cenário SeDi = Secretário Digital Júlia é Engenheira de Tráfego

Motivação : Cenário de um SeDi Chegada ao Aeroporto Visto de entrada Caminho até o ponto de ônibus (óculos) A Caminho do Hotel Deficiente visual ajudado pelo SeDi e o SeDi do ônibus Compras Localização e comparação das lojas que vendem o produto Conferência Nível de ansiedade (monitoramento) Reprodução do CD da Enia Demonstrações online Animações holográficas Conexão com as câmeras online nas avenidas

Motivação : Cenário de um SeDi Comemoração Ninguém tem que combinar nada Os SeDis decidem onde ir baseados nos perfis Pagamento Automático. Sem estresse. Da melhor forma para Júlia. Voltando pra casa... Putz! E as compras? O presente já está sendo entregue Chegando em casa Suprimentos Curriculum

Motivação : Agentes Reflexão Como implemnetar? Agentes Cenário altamente dinâmico Integração de diversas mídias e dispositivos Como implemnetar? Sugestão: usar Agentes Inteligentes Agentes Conjunto de metáforas, técnicas e ferramentas Ideal para aplicações autônomas, móveis e inseridas em uma sociedade Naturalmente capazes de: Reagir de forma autônoma e reativa Raciocinar de forma pró-ativa Adaptar-se ao ambiente onde estão inseridos Iteragir com outras entidades

Motivação : Agentes Iteração Mas como implementar? Solução compartilhada de problemas Requisito básico Mecanismo de Comunicação Linguagem comum Infra-estrutura Mas como implementar?

Roteiro Conceitos Básicos KQML FIPA ACL Exemplo Ferramentas Tipos de Comunicação Atos da Fala Linguagens de Comunicação Linguagens de Conteúdo Ontologias KQML FIPA ACL Exemplo Ferramentas

Conceitos Básicos

Tipos de comunicação Telepatia Acesso direto à uma Knowledge Base (KB) Lendo a mente... Cada um com sua KB KB compartilhada Problemas Podem usar o mesmo símbolo para denotar coisas diferentes Podem usar símbolos diferentes para denotar a mesma coisa Linguagem de Comunicação de Agentes (LCA) Comum

Atos da Fala Categorização das expressões humanas qto a Intenção do locutor Impacto ou reação do ato comunicativo causado no estado mental do receptor Existem aproximadamente 4600 atos de fala! Não é esse o objetivo de uma ACL Ajuda a decidir as primitivas das ACLs Todo primitiva de uma ACL é um ato de fala

Atos da Fala Linguagem Humana Dificuldades Atos comunicativos são interpretados a partir da mensagem e do contexto Nem sempre esta interpretação é óbvia Dificuldades “Cale-se !” (Comando) “Por favor, você pode se calar ?” (Pedido) “Você vai se calar ou não ?” (Pergunta) “Eu gostaria que você se calasse.” (Informação)

Atos da Fala : Categorias Representativos Expressam uma Proposta Ex: “Vamos jogar boliche amanhã?” Diretivos Expressam um Pedido ou Comando Ex: “Cale-se!” Comissivos Expressam Promessa ou Ameaça Ex: “Eu prometo doar R$1.000,00.” Expressivos Expressam Desculpas ou Agradecimentos Ex: “Desculpe pelo atraso?” Declarativos Mudam o Estado do Mundo Ex: “Eu os declaro marido e mulher!” Veredictos Expressam um Julgamento Ex: “West é criminoso.”

Atos da Fala Ato Locucionário Efeito Ilocucionário Emissão da mensagem Efeito Ilocucionário O que o locutor entende por algo Efeito Perlocucionário O real efeito do ato comunicativo no receptor Ideal Efeito perlocucionário previsível Para um dado Ato Locucionário, Efeito Ilocucionário = Efeito Perlocucionário. Em miúdos, prever a reação do receptor!

Linguagens de Comunicação Baseadas na Teoria dos Atos da Fala Objetiva a troca de informações entre agentes Transporte de mensagens na rede através de protocolos de baixo nível SMTP, TCP/IP, IIOP ou HTTP Esse transporte é transparente para o usuário Para o KSE, uma LCA é dividida em: Ontologia Linguagem interna (lógica) Codificação do conteúdo Linguagem externa Ato Locucionário (Performativa) Encapsulamento de infomações para o roteamento

Ontologias Definição Uma vez especificada… É um vocabulário cujos termos são relacionados a um certo domínio e precisamente definidos por textos como entradas de dicionário ou de enciclopédias Os relacionamentos entre esses termos também são especificadas usando técnicas de modelagem formal Uma vez especificada… Pode-se construir uma KB relacionadas ao domínio coberto pela ontologia Esta KB pode ser compartilhada com outros agentes interessados em conhecimentos sobre este domínio

Linguagem Interna (LI) O que é? Linguagem em que deve ser codificado o conhecimento que se deseja compartilhar com o destinatário da mensagem Exemplos KIF ( Knowledge Interchange Format ) Versão prefixada (“LISP like”) da lógica clássica de primeira ordem Não está totalmente implementada para uso comercial Produzida pelo KSE Linguagem natural Prolog, SQL, LISP RDF (Resource Description Framework) XML Ato Comunicativo Conteúdo Mensagem

Linguagem Externa ( LE ) O que é ? Linguagem que encapsula: O ato comunicativo = ato locucionário = performativa Informações para o roteamento Agente receptor Ontologia Linguagem interna Conteúdo … Exemplos KQML FIPA ACL

Knowledge Query and Manipulation Language KQML Knowledge Query and Manipulation Language

KQML Objetivo Pioneira ( KSE – 1994 ) Aplicações Interoperabilidade entre agentes de software em aplicações distribuídas e/ou heterogênea Pioneira ( KSE – 1994 ) Aplicações eCommerce (negociação) Jogos BDs distribuídos e/ou heterogêneos Integração de tecnologias ...

KQML : Características Principais características da linguagem: Independente de Linguagem Interna Independente de Ontologia Independente de Protocolos de Transporte de Rede Comunicação baseada nos atos da fala Performativas Sugere o uso de Agentes Facilitadores Camadas: Comunicação, Conteúdo e Mensagem

KQML : Sintaxe ( performativa :sender <word> :receiver <word> :reply-with <word> :in-reply-to <word> :language <word> :ontology <word> :content <expression> ) Camada de Comunicação Camada de Mensagem Camada de Conteúdo

KQML : Performativas Performativas Típicas Outras Performativas tell : informa que o conteúdo da mensagem está na KB do locutor ask-if : o locutor quer saber se o conteúdo de sua mensagem é verdadeiro para o receptor advertise : o locutor quer que o receptor saiba que ele pode processar mensagens no modelo do seu conteúdo insert : o locutor “pede” ao receptor que adicione o conteúdo da mensagem à sua KB Outras Performativas achieve, ask-about, ask-all, ask-one, break, broadcast, broker-all, broker-one, deny, delete, delete-all, delete-one, discard, eos, error, evaluate, forward, generator, monitor, …

Exemplo A1 envia a seguinte mensagem para A2 ... :sender A1 ( advertise :sender A1 :receiver A2 :reply-with id1 :language KQML :ontology kqml-ontology :content ( ask-if :sender A2 :receiver A1 :in-reply-to id1 :language Prolog :ontology CIn :content “Professor(X,Y)”))

Exemplo A2 pergunta então a A1 ... ( ask-if :sender A2 :receiver A1 :in-reply-to id1 :reply-with id2 :language Prolog :ontology CIn :content “Professor(X, ‘Agentes’)” )

Exemplo A1 responde ao agente A2 ... ( tell :sender A1 :receiver A2 :in-reply-to id2 :reply-with id3 :language Prolog :ontology CIn :content “X = Geber, X = Flávia, X = Jacques...” )

KQML : Problemas Ambigüidade e Termos Vagos O significado de performativas reservadas é pouco claro. Normalmente estão associadas à intuição e ao domínio da linguagem natural do intérprete Performativas com nomes inadequados Algumas performativas têm nomes que não correspondem diretamente ao ato comunicativo a ela associado Ex: “tell” Ausência de performativas Alguns atos comunicativos não estão representados entre as performativas disponíveis

Foundation for Intelligent Physical Agents FIPA Foundation for Intelligent Physical Agents

FIPA : Histórico FIPA é uma associação sem fins lucrativos fundada em 1996 e localizada em Genebra na Suíça Objetiva promover o sucesso das aplicações, serviços e equipamentos baseados em agentes Provê especificações para maximizar a interoperabilidade entre aplicações, serviços e equipamentos baseados em agentes

FIPA FIPA x KQML Linguagem de Comunicação de Agentes Ao contrário do KQML, as especificações FIPA têm uma grande preocupação com a modelagem semântica Linguagem de Comunicação de Agentes FIPA ACL Linguagens Interna FIPA Content Language Library (FIPA-CLL) FIPA-SL, FIPA-RDF, FIPA-CCL, FIPA-KIF, … Mas também é independente de LI

FIPA ACL Sintaxe Semântica Praticamente igual ao KQML Conjunto de performativas menor accept-proposal, agree, cancel, cfp, confirm, disconfirm, failure, inform, inform-if, inform-ref, not-understood, propose, query-if, query-ref, refuse, reject-proposal, request, request-when, request-whenever, subscribe E só estes! Semântica Definida precisamente

FIPA ACL x KQML Igualdades Diferenças Independência de IL e de ontologias Sintaxe idêntica Diferenças Visível principalmente na semântica Performativas são diferentes Os agentes de FIPA ACL são proibido de manipular diretamente a KB de outros agentes Tratamento diferente do gerenciamento dos agentes e das primitivas de administração Em FIPA ACL register, unregister, ..., são tratados por um módulo a parte

FIPA ACL x KQML Diferenças (situação fictícia) Em KQML Mensagem de A para B: achieve goal X Usa todo o vocabulário da LCA (performativa “achieve”) Em FIPA ACL Mensagem de A para B: tell ( achieve goal X ) A LCA não entende! A LI sim! Elimina a necessidade da performativa achieve na LCA Questão ainda em aberto! Conteúdo

Exemplo A simple one...

Agente Somador Linguagens Ferramentas Java KQML SACI (Simple Agent Communication Infrastructure)

Agente Somador Sociedade Facilitador Agente Servidor Agente Cliente (1) Advertise (2) Get Possible Servers (4) Ask One (3) Forward (5) Forward (6) Tell Agente Servidor Agente Cliente

Plus Server public static void main(String[] args) { Agent a = new PlusServer(); if (a.enterSoc("APlusServer")) { mbox.advertise("ask-one", "algebra", "matematica", "X+Y"); a.run(); // Fica lendo o Mailbox }

Plus Server public void run() { while (running) { Message m = mbox.polling(); if (m.get("performative").equals("forward")) { m = new Message(m.get("content").toString()); } if (m.get("performative").equals("ask-one")) { Message r = new Message("(tell)"); r.put("receiver", m.get("sender")); r.put("in-reply-to", m.get("reply-with")); r.put("content", calcula( (String)m.get("content") ) ); mbox.forward(r); } else { System.out.println("ignorando a mensagem"); }

Plus Client public static void main(String[] args) { PlusClient a = new PlusClient(); if (a.enterSoc("AClient")) { a.run(args[0]); }

Plus Client public void run(String exp) { String ag = mbox.consultYP("ask-one", "algebra", "matematica", "X+Y"); Message m = new Message("(ask-one :content \""+ exp + "\")"); m.put("receiver", ag); m.put("reply-with", "rSoma"); mbox.forward(m); Message resposta = mbox.polling(); if (resposta.get("performative").equals("forward")) { resposta = new Message(resposta.get("content").toString()); } if ( ((String)resposta.get("in-reply-to")).equals("rSoma")) { System.out.println("\n\n>>>>>>>>> Resposta de “ + resposta.get("sender") + " foi “ + resposta.get("content")); mbox.disconnect();

Ferramentas de Auxílio Análise

Critérios Ferramentas escritas em Java Com download disponível Manuais de instalação e configuração O mínimo necessário Divisão Ambientes Completos Bibliotecas de Classes Java (API)

Nome Vs Ano Mec. Transp. ACL Onto. Facil. Documet. Tipo OBS AgentBuilder Lite 1.3 1999 RMI, TCP/IP KQML Sim Não Excelente! Ambiente Completo - Bond 1998 Shadow Razoável Biblioteca JACK 2.1 2000 UDP/IP JACKAL 3.1 TCP/IP JADE 2.01 RMI FIPA Boa Suporte a JSP e JESS JATLite 0.4b JKQML 5.1a KTP, ATP, OTP Madkit 2.0.1 ??? Ambiente de Execução SACI RC3 FIPA OS 1.3.2 RMI, CORBA Ruim ZEUS 1.05

Referências KQML FIPA SACI FIPA x KQML http://www.cs.umbc.edu/kqml/ http://www.fipa.org/ SACI http://www.lti.pcs.usp.br/saci/ FIPA x KQML http://www.objs.com/agility/tech-reports/9807-comparing-ACLs.html

Referências Finin, Tim and Labrou, Yannis. A Proposal for a new KQML Specification; Finin, Tim., Labrou, Yannis and Mayfield, James. KQML as na communication language. Finin, Tim and Fritzon, Rich. KQML - A language and Protocol for Knowledge and Information Exchange. Finin, Tim and Labrou, Yannis. Semantics and Conversations for na Agent Communication Language Patil, Ramesh S., Fikes Richard E., Patel-Schneider Peter F. ., Don Mckay, Finnin, Tim., Gruber, Thomas and Neches Robert. The DARPA Knowledge Sharing Effort : Progress Report

Referências Hübner, Jomi and Sichman, Jaime, "SACI: Uma Ferramenta para Implementação e Monitoração da Comunicação entre Agentes", IBERAMIA'2000, SBIA'2000, Atibaia-SP, novembro de 2000 (http://www.lti.pcs.usp.br/saci/) Andrew C. Huang, Benjamin C. Ling, Shankar Ponnekanti, Armando Fox. “Pervasive Computing: What Is It Good For?. In proceedings of the Workshop on Mobile Data Management (MobiDE) in conjunction with ACM MobiCom '99, Seattle, WA, September 1999 (forthcoming)