Мне нужно передать сообщение ACL между 2 нефритовыми платформами. Я реализовал свой код для передачи сообщений между агентами в одном контейнере. Это прекрасно работает. Но я не мог разработать этот код для передачи сообщений между удаленными платформами.Передача сообщений ACL между удаленными платформами jade
Ниже приведено то, что я применил для агентов в одном контейнере. В коде агента отправителя результат [] получает только агентов на той же платформе.
Что мне не хватает? Есть ли способ получить список агентов на удаленной платформе?
Sender агент
DFAgentDescription temp = new DFAgentDescription();
try
{
//DFAgentDescription[] result = DFService.search(this,temp);
SearchConstraints sc = new SearchConstraints();
DFAgentDescription[] result=DFService.search(this,temp,sc);
ACLMessage acl = new ACLMessage(ACLMessage.REQUEST);
System.out.println("Agents: ");
for(int i=0;i<result.length;i++)
{
if(result[i].getName().getLocalName().equalsIgnoreCase("R1"))
{
acl.addReceiver(result[i].getName());
System.out.print(" , "+result[i].getName().getLocalName());
}
}
acl.setContent("Hello...");
this.send(acl);
System.out.println("Message Sent...");
}
catch(FIPAException e)
{
System.out.println("Error !: "+e);
}
Receiver агент
addBehaviour(new CyclicBehaviour()
{
public void action()
{
ACLMessage msg = myAgent.receive();
if(msg != null)
{
if(msg.getPerformative()== ACLMessage.REQUEST)
{
String content = msg.getContent();
if ((content != null))
{
System.out.println("Received Request from "+msg.getSender().getLocalName());
System.out.println("Received Message : "+content);
}
else
{
block();
}
}
}
else
{
block();
}
}
});
Это сработало! ... большое спасибо. – Dini88
agent-name @ platform Является ли это именем отправителя или получателя? –
Да, это локальное имя агента. –