All Downloads are FREE. Search and download functionalities are using the official Maven repository.

jadex.bdi.planlib.protocols.contractnet.CNPReceiverPlan Maven / Gradle / Ivy

Go to download

The Jadex applib BDI package contain ready to use functionalities for BDI agents mostly in form of modules called capabilities.

There is a newer version: 2.4
Show newest version
package jadex.bdi.planlib.protocols.contractnet;

import jadex.bdi.planlib.protocols.AbstractReceiverPlan;
import jadex.bdi.runtime.IGoal;
import jadex.bdi.runtime.IMessageEvent;
import jadex.bridge.IComponentIdentifier;
import jadex.bridge.fipa.SFipa;
import jadex.commons.collection.SCollection;

import java.util.List;

/**
 *  Receive a contract net protocol (cnp) and answer it.
 */
public class CNPReceiverPlan extends AbstractReceiverPlan
{
	/**
	 *  The body method is called on the
	 *  instatiated plan instance from the scheduler.
	 */
	public void body()
	{
		long timeout;
		if(getBeliefbase().containsBelief("timeout") && getBeliefbase().getBelief("timeout").getFact()!=null)
		{
			timeout = ((Long)getBeliefbase().getBelief("timeout").getFact()).longValue();
		}
		else
		{
			timeout = -1;
		}

		IMessageEvent me = (IMessageEvent)getParameter("message").getValue();
		IComponentIdentifier initiator = (IComponentIdentifier)me.getParameter(SFipa.SENDER).getValue();
		Object cfp;
		IMessageEvent reply;
		List records = SCollection.createArrayList();
		Object[] proposal = null;

		for(int i=0; me.getType().equals(getShortProtocolName()+"_cfp") 
			&& (i==0 || isIterated()); i++)
		{
			getLogger().info("Negotiation round: "+i+" receiver got cfp: "+me);
			records.add(me);
			cfp = me.getParameter(SFipa.CONTENT).getValue();

			Exception ex = null;
			try
			{
				proposal = makeProposal(cfp, initiator); // todo: include information about negotiation round
			}
			catch(Exception e)
			{
				ex = e;
				getLogger().info("No proposal made due to exception: "+e);
				//e.printStackTrace();
			}
			if(ex!=null || proposal == null || proposal[0]==null)
			{
				reply = getEventbase().createReply(me, getShortProtocolName()+"_refuse");
				getLogger().info("No proposal made. Finished.");
				sendMessage(reply);
				return; // todo: ?
				//fail();
			}

			reply = getEventbase().createReply(me, getShortProtocolName()+"_propose");
			reply.getParameter(SFipa.CONTENT).setValue(proposal[0]);
			getLogger().info("Receiver sent proposal: "+reply);
			me = sendMessageAndWait(reply, timeout);
		}

		if(me.getType().equals(getShortProtocolName()+"_accept"))
		{
			getLogger().info(getComponentName()+" excuting the cnp task.");
			try
			{
				Object result = executeTask(proposal[0], proposal[1], initiator);
				reply = getEventbase().createReply(me, getShortProtocolName()+"_inform");
				reply.getParameter(SFipa.CONTENT).setValue(result); // todo: how to put in the Done()???
				getLogger().info("Receiver sent done: "+reply);
				sendMessage(reply);
				getParameter("result").setValue(result);
			}
			catch(Exception e)
			{
				reply = getEventbase().createReply(me,getShortProtocolName()+"_failure");
				getLogger().info("Receiver sent failure: "+reply);
				sendMessage(reply);
			}
		}
		else
		{
			getLogger().info("Proposal rejected. Finished.");
		}
	}
	
	/**
	 *  Test if it is the iterated contract-net version.
	 *  @return True, if is is the iterated version.
	 */
	protected boolean isIterated()
	{
		return ((Boolean)getParameter("iterated").getValue()).booleanValue();	
	}
	
	/**
	 *  Get protocol abbrev name.
	 *  @return The protocol abbrev name.
	 */
	protected String getShortProtocolName()
	{
		String ret = "cnp";
		if(isIterated())
			ret = "icnp";
		return ret;
	}

	/**
	 *  Make a proposal based on the task description.
	 *  @param cfp The cfp including the task to execute.
	 *  @return The proposal for executing the task.
	 */
	public Object[] makeProposal(Object cfp, IComponentIdentifier initiator)
	{
		IGoal make_proposal = createGoal(getShortProtocolName()+"_make_proposal");
		make_proposal.getParameter("cfp").setValue(cfp);
		make_proposal.getParameter("initiator").setValue(initiator);
		dispatchSubgoalAndWait(make_proposal);
		return new Object[]{make_proposal.getParameter("proposal").getValue(),
			make_proposal.getParameter("proposal_info").getValue()};
	}

	/**
	 *  Execute the task.
	 *  @param proposal The proposal.
	 *  @param proposal_info The proposal info.
	 *  @return The result of the task.
	 */
	public Object executeTask(Object proposal, Object proposal_info, IComponentIdentifier initiator)
	{
		IGoal execute_task = createGoal(getShortProtocolName()+"_execute_task");
		execute_task.getParameter("proposal").setValue(proposal);
		execute_task.getParameter("proposal_info").setValue(proposal_info);
		execute_task.getParameter("initiator").setValue(initiator);
		dispatchSubgoalAndWait(execute_task);
		return execute_task.getParameter("result").getValue();
	}
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy