Java Agent Development Framework

Java Agent Development Framework, or JADE, is a software framework for the development of intelligent agents, implemented in Java. JADE system supports coordination between several agents FIPA and provides a standard implementation of the communication language FIPA-ACL, which facilitates the communication between agents and allows the services detection of the system. JADE was originally developed by Telecom Italia and is distributed as free software.

JADE
Stable release
4.5.0 / June 8, 2017 (2017-06-08)
Written inJava
PlatformJava SE
TypeMulti-agent system, software framework
LicenseGNU Lesser General Public License
Websitejade.tilab.com/ 

Resume

JADE is a middleware which facilitates the development of multi-agent systems under the standard FIPA for which purpose it creates multiple containers for agents, each of them can run on one or more systems. Is understood that a set of containers constitutes a platform.

JADE provides:

  • An environment where JADE agents are executed
  • Class libraries to create agents using heritage and redefinition of behaviors
  • A graphical toolkit to monitoring and managing the platform of intelligent agents

History

JADE was initially developed by Telecom Italia Lab. This sector is the R & D branch of Telecom Italia Group which is responsible for promoting technological innovation. Telecom Italia conceived and promoted JADE by basing it in 2000. The latest available dates from June 2017 (version 4.5). The first version of JADE distributed as free software is available from February 2000 (versiĆ³n 1.3).

In March 2003 Motorola and Telecom Italia created the JADE Governing Board with the objective of promoting the development and adoption of JADE in the mobile telecommunications industry as middleware based. The JADE Governing Board accepts to any company and/or organization interested in the commercial use and exploitation of JADE to commit to its development and promotion.

Platform

JADE is a distributed agents platform, which has a container for each host where you are running the agents. Additionally, the platform has various debugging tools, mobility of code and content agents, the possibility of parallel execution of the behavior of agents, as well as support for the definition of languages and ontologies. Each platform must have a parent container that has two special agents called AMS and DF.

  • The DF (Directory Facilitator) provides a directory which announces which agents are available on the platform.
  • The AMS (Agent Management System) controls the platform. It is the only one who can create and destroy other agents, destroy containers and stop the platform.

DF Agent

To access the DF agent the class "jade.domain.DFService" and its static methods are used: register, deregister, modify and Search.

AMS agent

To access the AMS Service an agent is created which automatically runs the register method of the AMS by default before executing the method setup from the new agent. When an agent is destroyed it executes its takeDown() method by default and automatically calls the deregister method of the AMS.

Agent class

The Agent class is a superclass which allows the users to create JADE agents. To create an agent one needs to inherit directly from Agent. Normally, each agent recorder several services which they should be implemented by one or more behaviors.

This class provides methods to perform the basic tasks of the agents as:

  • Pass messages by objects ACLMessage, with pattern matching
  • Support the life cycle of an agent
  • Plan and execute multiple activities at the same time

JADE agent

The cycle of life of a JADE agent follows the cycle proposed by FIPA. These agents go through different states defined as:

  1. Initiated: The agent has been created but has not registered yet the AMS.
  2. Active: The agent has been registered and has a name. In this state, it can communicate with other agents.
  3. Suspended: The agent is stopped because its thread is suspended.
  4. Waiting: The agent is blocked waiting for an event.
  5. Deleted: The agent has finished and his thread ended his execute and there is not any more in the AMS.
  6. Transit: The agent is moving to a new location.

Agents' behaviour

The behavior defines the actions under a given event. This behavior of the agent is defined in the method setup using the method addBehaviour. The different behaviors that the agent will adopt are defined from the abstract class Behaviour. The class Behaviour contains the abstract methods:

  • action (): Is executed when the action takes place.
  • done (): Is executed at the end of the performance.

A user can override the methods onStart () and OnEnd () property. Additionally, there are other methods such as block () and restart () used for modifying the agent's behavior. When an agent is locked it can be unlocked in different ways. Otherwise the user can override the methods onStart() and onEnd() the agent possess.

Unlock an agent

  1. Receiving a message.
  2. When the timeout happens associated with block ().
  3. Calling restart.

ACL messages

Message passing ACL (Agent Communication Language) is the base of communication between agents. Sending messages is done by the method send of the class Agent. In this method, you have to pass an object of type ACLMessage that contains the recipient information, language, coding and content of the message. These messages are sent asynchronously, while messages are received they will be stored in a message queue. There are two types of receiving ACL messages, blocking or non-blocking. For this provide methods blockingReceive () and receive () respectively. In both methods, you can make filtering messages to be retrieved from the queue by setting different templates.

Extensions

JADE has an extension denominated WADE (Workflows and Agents Development Environment) which is a system of workflow which allows create process by a graphic editor named WOLF.

gollark: https://en.wikipedia.org/wiki/Landauer%27s_principle
gollark: Er. What?
gollark: Not infinite mass, I think it's just infinite density.
gollark: Watts are power (energy per time), so I'm pretty sure that question doesn't actually make sense.
gollark: No, still stupid. Yes, you can not know things and that is fine. But not looking up relevant safety information (or ignoring it? If I remember right, that person was not very receptive to people saying that they were doing stupid things) when doing something you can quite easily recognize as potentially dangerous is stupid.

See also

References

    • Jade news archive
    • Wade User Guide
    • Developing Multi-Agent Systems with JADE, Volume 7 Wiley Series in Agent Technology, Fabio Luigi Bellifemine, Giovanni Caire, Dominic Greenwood ISBN 9780470058404
    This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.