\documentclass[runningheads]{llncs}\usepackage[T1]{fontenc}\usepackage{graphicx}\usepackage{hyperref}
% \usepackage{../_package/AOcommon}\picsFrom{amicity/flash/abms/}
\def\flatpack{}\usepackage{AOcommon}\picsFrom{pic/}
\usepackage{amssymb}\usepackage{tikz}\usetikzlibrary{arrows.meta, calc, positioning}
% \usepackage{color}\renewcommand\UrlFont{\color{blue}\rmfamily}
\begin{document}
\title{Reconciling Simulation and Distributed Deployment in a MAS Development Framework}\titlerunning{Reconciling Simulation and Distributed Deployment in MAS}
\author{	Andrei Olaru\orcidID{0000-0002-2718-9195}%\inst{1}%
\and	  	Ionuț Hodoroagă
}\authorrunning{A. Olaru and I. Hodoroagă}
\institute{Department of Computer Science and Engineering, National University of Science and Technology POLITEHNICA Bucharest, 313 Splaiul Independentei, 060042 Bucharest, Romania \email{andrei.olaru@upb.ro, ionut.hodoroaga@stud.acs.upb.ro}}
%
\maketitle              % typeset the header of the contribution
	\begin{abstract} %The abstract should briefly summarize the contents of the paper in 150--250 words.
In a world where agents are attracting renewed attention as a model for distributing artificial intelligence applications, the ability to test and simulate systems of agents becomes more important. However, agent-based simulation platforms and network-distributed multi-agent system deployment frameworks traditionally differ strongly in their approach to agent interaction and execution model, although each could benefit from featuring the capabilities of the other.

Following in the tracks of other works that have attempted to bridge the gap for specific cases, this paper makes a primary investigation on the requirements that a framework would need to satisfy to support both large-scale simulations and real-life deployments with the same agent code.

We present a minimal set of principles upon which features can be developed, relating to interaction support, execution control, and environment modeling. We developed a set of features that allow compatibility between an ABM application and an existing MAS framework, and a proof-of-concept implementation of a classic ABM application using a framework originally built for network-based deployment.%, showing how ABM features can be built into an agent deployment framework so that the same application can run in simulation and in real-life-deployment mode, validating the claim that the same framework could be used for both scenarios.
	
	\keywords{Multi-agent systems  \and Multi-agent frameworks \and Agent-Based Modeling and Simulation.}\end{abstract}


\renewcommand{\aa}[1][ ]{A\&A#1}\newcommand{\jade}[1][ ]{\textsc{Jade}#1}
\renewcommand{\sim}{\emph{Sim}}\newcommand{\real}{\emph{IRL}}
% \def\auxilliaries{}


% DONE spellcheck, warnings

% 16 pages, excluding references and appendices, in LNCS format

% Introduction				3 pg
% Related Work				3 pg
% Approach & principles		3 pg
% Implementation				4 pg
% 	scenario & requirements
% 	model as F-MAS entities
% 	specific challenges
% Discussion					2 pg
% 	features table
% Conclusion					1 pg


% DONE mention agent mind earlier

% DONE two more applications -- deployment information, images, contexts used, focus on common contexts


\section{Introduction}%\label{sec:}

In the world of multi-agent systems (MAS) and the software platforms underpinning them, there is an important distinction between two types of applications, which are supported by different types of platforms.

On the one hand, there are MAS applications where agents interact via agent communication languages or other communication protocols, can execute on different machines, and have a complex lifecycle based on multiple behaviors and a high level of asynchronicity. These applications are underpinned by frameworks such as Jade and SPADE \cite{BPR99,PTJ20}. While these are generally referred to as ``MAS frameworks'', to better make the distinction and not create confusion, let us call these \emph{network-based deployments}, since one of their central features is the support of communication over the network. These applications are deployed \emph{in real life}, or \real.

In \emph{simulations} based on \emph{agent-based models}, the number of agents is large, interactions can be complex, and it all happens on a single machine, or in a tightly coupled execution environment such as an HPC computing cluster. There are visualizations that can be used to monitor the progress of the simulation, and the user is able to control the speed of the simulation or pause it to investigate the details of a particular instantaneous state. These applications are \emph{simulations}, and we will abbreviate this type of scenario as \sim.

ABM and MAS applications are not \emph{fundamentally} different. In both scenarios, there are agents, which interact with the environment via perceptions and actions, and which interact among each other, via objects in the environment, via events, or via direct communication.

Many times, network deployments and agent-based simulations are seen as different fields, with no reason to interoperate the two. Indeed, some simulations, such as crowd simulations, are meant to simulate a process which happens in reality and which features non-software entities. However, simulation is also a means of \emph{testing} the functionality of a system formed of a large number of software agents, or the interaction between software agents and entities that, in the real deployment, are non-software, e.g. humans. Simulations are how we can tweak the behavior of agents so that, when deployed in real life, they will behave correctly. This is especially useful in applications concerning mobile robots and robot swarms \cite{LH25,CPM22,NF13} and traffic control \cite{VA18,AZ22}, in which the simulation precedes the deployment of agent behaviors into the real-life application. In traffic-related applications, for instance, once a complex behavior is implemented for agents -- either agents controlling traffic lights, or agents controlling cars, or both -- it is desirable that the same code is used, as developed, in real life.
\dx[here refer to work connected to Dan Novischi]

Our vision is to have a framework for agent deployment that allows deploying agents in real life, but also allows \emph{the same} agents to be tested in simulations, and by \emph{the same} we mean agents with the same code and the same behavior -- the same ``\emph{agent mind}''. While this has been attempted before, both in a general purpose approach \cite{Car16,RCB20,BVM25} and for specific application domains \cite{AZ15,VA18}, currently mainstream ABM frameworks offer no possibility of deploying the simulated agents in real life, with the same code (e.g. deploy Netlogo agent code to control a robot), and deployment frameworks such as JADE or SPADE cannot support large-scale simulations.

We are in the course of defining the architecture of a framework that allows agents to be deployed in a real-life scenario, interacting with each other via the network and interacting with the environment, but also to be simulated in a controlled environment, with simulations being efficient and execution is controllable.

Network-based deployment of agents, such as in \jade or SPADE, means that agents need to have a lifecycle usually based on behaviors, sometimes based on cognitive models such as BDI, are able to interact asynchronously over a network, potentially using secure communications, and interact with their environment directly or, in the Agents and Artifacts (\aa[]) meta-model, via artifacts. But \real\ applications would benefit from the possibility to simulate the agent behaviors and interactions prior to deployment, in a controlled execution environment, but without the performance overhead generated by more capable interaction infrastructures, and with the possibility of controlling the pace of the simulation \cite{Car16}.

In an agent-based simulation, such as in NetLogo, Repast, or GAMA \cite{WR15,Col03,TVA10}, agents interact mostly with their neighborhood, and implement a more reactive approach to internal agent modeling, either executing in a step-wise (tick-based) manner, or via reaction to events (reflexes). But \sim\ applications would benefit from the possibility of more advanced internal agent modeling and behavior (e.g. a BDI approach) and, for some applications, from the possibility of deploying the agents, as they are, in a real-world setup.

The question we are tackling is what would be the architectural principles around which to build such a framework, that allows both simulation and real-life, network-based deployment. We investigated the challenges that arise and studied several use cases in search of developing a \emph{minimal} but \emph{complete} set of requirements that would satisfy both scenarios. Upon these requirements, we have built an infrastructure of necessary functionality, focusing on modeling concerns but also keeping in mind the potential for performance in large-scale simulation.

To put the principles that we have developed to the test, before moving on to more complex applications, we have implemented a proof-of-concept implementation of a classic ABM scenario in \fmas[], a modular, flexible agent deployment framework developed within our department \cite{OSF19,Ola25}. While we have noticed that the \fmas framework is particularly appropriate for our objective, thanks to its modularity and focus on contexts, the goal of this research is to identify general principles that can be extended to other MAS frameworks. By integrating ABM features in \fmas[], we can also help establish \fmas as a capable agent deployment framework suitable of a variety of scenarios.
% , such as multi-robot systems


The purpose of this research, of which this paper showcases only the first steps, is twofold. On the one hand, it identifies several principles that can be followed by frameworks that wish to gain the ability to handle both scenarios; on the other hand, it showcases the design of several components that enable the compatibility between \sim\ and \real\ scenarios and shows how \fmas can use these components to become an agent deployment framework that is able to handle both agent-based simulation and network-distributed applications.

\dx[present also components that are already in \fmas]

% DONE place
% We will use the following terms: for simulated scenarios, as in the case of ABMS, \sim; and for real-life scenarios, as in the case of network-distributed deployments, \real.


% DONE While our framework is Java-based, the principles that we discuss can be applied to Python implementations as well.

% NO The role of waves -- similar to the vision of RESTful approach in Collier's work

% NO Use cases studied

% NO we use ``agent code'' instead of ``agent mind'' so as to give a more practical angle on things


\section{Related Work}%\label{sec:}

There is a significant body of work in MAS frameworks, as well as in ABM simulations. However, there are relatively few works at the intersection of the two. We will review some of them here and highlight how they are related to this work.

\subsection{From Simulation to Real-Life Deployment}%\label{sec:}

While some simulations are meant to replicate real-life processes just to observe what is the result of environmental conditions, some simulations are used as a testbed for entity behavior before entities are deployed in the real world. These simulations are using application-specific simulation platforms.

The Aerialist is a test bench for drone control software, focused on simulating environment conditions and specific control issues \cite{KPT24}. Barone et al \cite{BWC23} introduce a simulation framework for military applications, using a derivative of NetLogo for the simulation, as well as a specialized simulator for realistic network communication conditions. In the field of networking, Pinyoanuntapong et al \cite{PPB21} present the effort of transferring behaviors tested in simulation to real-life, where the behaviors, policies and knowledge need to be transferred to specialized devices, such as network switches and routers. And Al-Zinati and Zalila-Wenkstern introduce MATISSE 2.0 as a testbed for agent-based transportation systems, before they are deployed in real-life

When transferring policies and behaviors from simulation to real-life deployments (what is called ``sim to real''), there are several gaps that can be identified \cite{CPM22}: the simulation gap, derived from the forced synchronicity in simulated agent execution; the
observation gap, derived from the reduced observation horizon in the real world; and the communication gap, resulting from imperfect real-world communication. These gaps can be, at least in part, covered by simulation components appropriately replicating realistic environments. However, one gap that occurs in many applications is the lack of software support that allows for a seamless sim-to-real transfer for that specific application domain.

There is a significant body of work dealing with the transfer of reinforcement learning policies from simulation to real-world environments \cite{TKS26}, especially in application domains such as robotics \cite{LH25} and autonomous vehicle control \cite{CPM22}. However, many of these transfers focus on how to transform input/output streams from simulated inputs and feedback loops to real-life interfaces. In these works, agent behavior is represented by a policy. In agent-oriented engineering, however, there is considerably more focus on the internal architecture of agents and on features offered by the framework that enable communication and the relationship with the environment. Internal agent architectures can rely on more than applying a learned policy, such as, for instance, behavior-based architectures or models inspired by the BDI approach \cite{RG95}.


\subsection{Bringing Simulation Functionality to MAS Frameworks}%\label{sec:}

To solve the issue of simulating agents with more advanced behaviors, there have been several attempts to bring simulation capabilities to existing MAS frameworks, especially \jade and JaCaMo, with the goal of validating BDI models through simulation \cite{BBC26}.

Collier et al \cite{CRG22} introduces the concept of \emph{Hybrid Simulation} -- the ability to integrate different sub-simulations in the same scenario, each potentially differently modelled, with different techniques. The authors highlight the lack of tools for integration of ABM with other techniques \cite{PGH19}.

Jagutis et al \cite{JRC23} create an architecture for bringing simulation features to the microservices-based ASTRA-MAMS agent framework, identifying two distinct microservices for simulation: one is the environment and the other is an agent-oriented service, running the behaviors of agents. The environment sends to the agents percepts and affordances, whereas agents send actions. In our work we also observe this separation, but we take it further towards a more controllable execution.

Palanca et al \cite{PRC23} illustrate the need for agents that combine different types of behaviors in the same architecture, such as reactive behaviors but also BDI-based decisional behaviors. The implementation is in SPADE 3 and the BDI behaviors are specified using AgentSpeak. We envision that by integrating simulation features in \fmas we will also enable a variety of hybrid agent systems.

Several solutions propose interoperation between agent deployment frameworks and ABM frameworks or an ABM-oriented approach, based on providing agents with perceptions and obtaining from agents actions to be executed in the environment. One example is the ABM-BDI approach \cite{SPL16}. However, there is no manner in which agents can access functionality from the environment in a more responsive and efficient manner, such as obtaining, on demand, information about their surroundings, or about other agents. Rather, the interface between environment and agents is heavy and unsuited for large-scale simulation. While this could be solved by offering all the possibly accessible information in the perception, this would greatly decrease the efficiency of the implementation.

Cardoso created a mechanism for interoperation between two popular frameworks -- \jade and Repast, to enable simulation of \jade agents using the Repast framework \cite{Car16}. The complexity and lack of modularity of \jade[], however, hinder the process, as well as the fact that \jade allows blocking calls. The simulation requires modifying \jade itself, and does not use the exact same \jade agent code, but supports automated bidirectional conversion between agent code for normal \jade and for the simulated version.

The SimJade Architecture integrates \jade with the PeerSim high-per\-for\-mance simulator by intercepting messages and calls to the AMS and DF services \cite{BVM25}, but there is no interaction between agents and the environment.

Several initiatives have attempted to interoperate Jason or JaCaMo \cite{BBH13} with simulation features, as JaCaMo is a popular, and powerful, agent-oriented programming framework with rich agent behavior specification derived from Agent\-Speak. Some attempts have been made to interoperate JaCaMo with the SUMO traffic simulator \cite{BC13,VA18}, but they are limited to application-specific solutions and rely on Jason submitting explicit requests that are destined to reach the simulator.

JaCaMo-sim \cite{RCB20} attempts to integrate general-purpose simulation features into the platform. Like other attempts, it focused on uncoupling the agent behavior from the actual reading of perceptions, receipt of events, and execution of actions, such that the environment could be simulated and the pace of the execution controlled. However, the work has unfortunately not continued.

Grosjean et al \cite{GDH25} also work in improving the model of ABM frameworks, by decoupling the application (the `thematic' model) from communication and distribution mechanisms (the `distribution' model), but remaining in the area of HPC simulations and not crossing into more loosely coupled network deployments.

SARL, a general-purpose agent-oriented language can run on different execution platforms \cite{GRG20}, such as Janus, appears suited for both ABM scenarios and network-based deployments, however it remains to be seen if it can flexibly integrate a wider range of environment contexts.

Baiardi et al introduced the ability to simulate JaKtA agents using Alchemist -- a Discrete Event Simulator. The authors make a thorough analysis of requirements and use a UAV scenario, but the simulation benefits from the fact that agents are implemented in a domain-specific language, rather than in a general-purpose one.



\section{Approach, Requirements, and Principles}\label{sec:principles}

\begin{figure}[t]\centering
\picSs[.1]{architectures-physical} \hskip1ex\vline\hskip1ex \picSs[.1]{architectures-MAS} \\ (a) \hskip.4\tw (b) \\
\picSs[.1]{architectures-ABM} \\ (c)
\caption{The relation of the agent code (the agent `mind') with other components of the scenario in (a) a physically embodied agent; (b) a network-deployed MAS; (c) an agent-based simulation.}\label{fig:architectures}\end{figure}


\dx[diagrams with relations to exterior nad execution models]

Our research deals with a design that enables the same agent code to be deployed in both \sim\ -- agent-based simulation -- and in \real\ -- real-life scenarios.

% DONE what is the second question
A first question here is ``\emph{what is agent code and is there anything else in an agent}?''. We see the \emph{agent code} as equivalent to the \emph{agent mind}, as opposed to the \emph{agent body}. The \emph{agent mind} represents its behavior, its decision algorithm, internal state and knowledge management, input processing, etc. Conversely, the \emph{agent body} contains all elements that are associated with the agent but are not \emph{internal} to its decision process, such as the actual sensors and actuators, for a robotic embodiment; extrinsic properties such as its position in space; or any other component that mediates between the agent and the environment. Examples of \emph{agent code} are shown, in different languages, in Figure \ref{fig:wolf-agent}. % Indeed, at times, the separation may not be entirely clear

A second question is ``\emph{what are the connections that the agent mind needs to other components}?''. We are interested in all connections that need to behave differently in the \sim\ and the \real\ scenarios.

And the last question is ``\emph{what is the minimal set of requirements that need to be satisfied by a multi-agent deployment framework such that the same agent code is compatible with both \sim\ and \real\ execution}?''

\subsection{Sketching the Requirements}%\label{sec:}

Any agent deployment framework must ensure that agents are \emph{situated in} and can \emph{interact with} the environment, and that they can interact with each other via \emph{communication protocols}.

In relation to the environment, the agent must be able to \emph{observe} and \emph{perceive} at least a part of the environment, and to \emph{execute actions} that affect the environment or affect the situation of the agent body in the environment (e.g. agent movement). In \sim, when an agent performs a \code{move(position)}, the simulation environment changes the extrinsic \emph{position} property of the agent, so that a future perception on its own position will return the updated position. In \real, a similar call results in an actual movement of the agent's body in the physical environment.

The different relations between the agent decision process -- the agent mind -- and other components in a scenario are shown in Figure \ref{fig:architectures}, for three cases: a physical agent body that the agent mind controls; a MAS in which the agent mind interacts directly with the framework or with the local system, via the programming language, as in \jade[]; and an agent-based simulation, where the agent mind interacts with the simulation framework and its execution is controlled externally.

Regarding communication, agents must be able to communicate directly, via one-to-one messages, or via broadcasting in a given vicinity. Such communicative acts must be perceived as such by other agents. Agents can also communicate indirectly, but this can be covered by the relation of the agents to the environment. In \sim, communication can many times be performed based on vicinity (e.g. send a message to all agents of a certain type and in a given range). In \real, communication is either direct and identifier-based, or based on artifacts and/or organizations which allow broadcasting. \real\ applications need an actual means of discovery and communication, such as unique identifiers, a registration server and a communication protocol (XMPP in SPADE, or TCP/IP in \jade[]).

To ensure the same agent code can run in both \sim\ and \real, we need to represent the relation with the environment in the same manner in both scenarios. Based on the principles in the \aa approach, the modeling used in the Repast framework, and our own previous work in MAS modeling \cite{ONF23}, we abstract the elements of the environment as \emph{contexts}. Any agent can be part of any number of contexts, and a context can offer functionalities, e.g. positioning and movement of agents.


\begin{figure}[t]\centering
\begin{tikzpicture}[
    font=\footnotesize,
    node distance=1cm and 1cm,
    every node/.style={
        draw,
        rounded corners,
        rectangle,
        minimum width=1cm,
        minimum height=0.8cm,
        align=center,
        font=\scriptsize,
    },
    arrow/.style={->, thick},
    lab/.style={midway, font=\scriptsize, draw=none, fill=none},
]

% Styles by type
\tikzset{
    agent/.style={fill=cyan!30},
    context/.style={fill=orange!30},
    link/.style={fill=green!30},
    buffer/.style={fill=black!15},
    comms/.style={fill=orange!45},
    control/.style={fill=cyan!40}
}

% Main nodes
\node[agent, minimum height=2cm] (agent) {Agent Code};
\node[control, left=of agent] (exec) {\shortstack{Execution\\ Control}};

% Context chain – upper
\node[link, right=1.5cm of agent] (linkA) {Context Link};
\node[context, right=2.5cm of linkA] (ctxA) {Context};

\node[buffer, below right=0cm and 1cm of linkA] (actBufA) {buffer};
\node[buffer, above right=0cm and 1cm of linkA] (percBufA) {buffer};

\node[link, below=of agent] (msg) {Messaging};
\node[buffer, right=of msg] (msgBuf) {Message Buffer};
\node[comms, right=of msgBuf] (comms) {\shortstack{Communications\\ Infrastructure}};

% Control flow
\draw[arrow] (exec.north) -- ++(0, 1) -| node[lab, above] {give control} (agent.north);
\draw[arrow] ([xshift=-10pt]agent.south) -- ++(0, -.2) -| node[lab, below] {yield control} (exec.south);

% Upper context – actions
\draw[arrow] ([yshift=3pt] linkA.west) -- ([yshift=3pt] agent.east) 
    node[lab, above] {perception};
\draw[arrow] ([yshift=-3pt] agent.east) -- ([yshift=-3pt] linkA.west) 
    node[lab, below] {action};
\draw[arrow] (linkA) -- (actBufA) node[lab, below] {add};
\draw[arrow] (actBufA) -- (ctxA);

% Upper context – perceptions
\draw[arrow] (ctxA) -- (percBufA);
\draw[arrow] (percBufA) -- (linkA) node[lab, above] {post};

% Messaging

\draw[arrow] ([xshift=3pt] msg.north) -- ([xshift=3pt] agent.south) 
    node[lab, right] {receive};
\draw[arrow] ([xshift=-3pt] agent.south) -- ([xshift=-3pt] msg.north) 
    node[lab, pos=.7, left] {send};
\draw[arrow] ([yshift=-3pt] msg.east) -- ([yshift=-3pt] msgBuf.west) node[lab, below] {add};
\draw[arrow] ([yshift=-3pt] msgBuf.east) -- ([yshift=-3pt] comms.west);

% Upper context – perceptions
\draw[arrow] ([yshift=3pt] comms.west) -- ([yshift=3pt] msgBuf.east);
\draw[arrow] ([yshift=3pt] msgBuf.west) -- ([yshift=3pt] msg.east) node[lab, above] {post};

\end{tikzpicture}
\caption{A general perspective on how the agent code interacts with other components that ensure the separation from the environment and the communications infrastructure. The diagram applies especially to \sim\ scenarios, where interactions need to be buffered to ensure the appearance of simultaneity.}\label{fig:separations}
\end{figure}

For instance, a \emph{spatial context} may allow placement of the agent in a topology, movement of agents in the topology, and observation of the surroundings; an \emph{agent management} context may allow the creation or destruction of agents; a \emph{temporal context} may allow the agent to know what time it is (in simulation / application time) and to schedule actions and behaviors in the future; and so on.

In MAS, direct communication is seen as a special functionality, separate from the interaction with the environment, so, while we can perceive it as a \emph{communication context}, we will give it a special place.

One important difference between \sim\ and \real\ applications is the execution. In simulations, agents run in a step-wise manner or use synchronization events, and the speed of the simulation can be controlled by the user. In network deployments, agents usually run in their own threads and are synchronized only loosely, via communication, many times using timers or other mechanisms linked to the time of the system, rather than the time of the simulation. Indeed, frameworks such as \jade or SPADE incentivize the use of behaviors as a means of internal organization of agents, such that the framework has some control over the execution and \emph{could} call behaviors at a controlled pace, but behaviors can still contain blocking calls, timers, or sleep calls.



\subsection{Principles}%\label{sec:}

We have derived the following principles that are necessary to ensure that the same agent code can run in both \sim\ and \real. The components that we highlight in the principles are shown in Figure \ref{fig:separations}. The three principles are: 		\begin{itemize}
	\item[P1] The simulated environment is represented by a set of \emph{simulation contexts}. Real-life environments may or may not be implemented as contexts, but still they should be \emph{accessed} by agents as such. All \emph{actions} executed by the agents (\emph{external} actions) must be performed via such a dedicated interface. Similarly, all \emph{perceptions} are obtained via a context. These interfaces must not necessarily be one single interface, but they must be \emph{external to} the agent's decision process. We call the set of interfaces the \emph{Context Link}. The \emph{Context Link} must also handle any perception of time, system access, random numbers, etc.
	\item[P2] Similarly to external actions, communications and interactions between agents must go through a component external to the agent's decision process. Moreover, in \sim, communications must follow the time of the simulation and must replicate any latencies or reliability issues that are present in the \real\ scenario. % NO what if no IDs
% 	DONE refine this; steps must not be too long. clarify perception part (possbily change the term 'perceived')
	\item[P3] The execution model of agents must fully support either step-wise execution or event-based simulation control. In \sim, given that there will exist an external executor, the agent be able to \emph{yield control} a short time after it \emph{receives control}. As such, there are two possibilities for any agent: step-based execution or event-based execution control.
															\end{itemize}
	
In \textbf{step-based execution}, the execution of the agent happens in small, self-contained \emph{steps}: everything that happens inside the step must run independently from other agents, and any interaction -- with the environment or with other agents -- must take place between one step and the next. From the perspective of the agent, the \emph{decision} takes place inside a step, during which the agent posts any interactions it wishes to initiate, and the \emph{interactions} take place between steps (see Figure \ref{fig:timeline}). Since no actions or communications can be expected to take place instantaneously, and also in \real\ scenarios the agent needs to wait for the interaction tu actually happen, from the point of the agent it cannot \emph{perceive} how much time passed between steps, as long as interactions between all agents happen at the same pace.

In \textbf{event-based control}, the execution of an agent can be interrupted and resumed at any time, with fine granularity, via events such as \emph{suspend} and \emph{resume}. For this to be achieved, the agent must handle events with promptness. The execution time allowed between a \emph{suspend} and a \emph{resume} event (equivalent to a \emph{step}), should be of the same order of magnitude as the time to execute an action, or to send a message, such that in a step the agent will expect to receive the responses to messages sent in the previous step.

If these principles are followed, they are \emph{sufficient} to ensure compatibility between \sim\ and \real\ scenarios. Agent code from a \real\ application, following the principles, can be \emph{simulated}, because all interaction with its exterior goes through contexts or through communications support, and its execution can be controlled. If all agents decide on their actions and interactions in the \emph{step phase}, and all agent actions and interactions are carried out in the \emph{update phase}, which is disjoint from the \emph{step phase}, then it will \emph{appear} to agents that actions happen simultaneously, as shown in Figures \ref{fig:timeline} and \ref{fig:execution-phases}.

Conversely, agent code from a \sim\ application, following the principles, can be \emph{deployed} in real life, as all of its external actions can be directed to its body, its communications can go through an appropriate support infrastructure, and it can be executed by an execution engine either calling its \codeS{step} method, or running it and not ever suspending it.

The principles are also \emph{necessary} to ensure compatibility, forming a minimal set. None of the principles could be ablated.

% DONE explain how these break the illusion


\newcommand{\wolfcode}{
\fbox{\parbox[b]{.3\tw}{\axrst\tt\scriptsize
\axr  to go
\axr	rt random 50
\axr	lt random 50
\axr	fd 1
\axr	\ldots
\axr	let prey one-of sheep-here
\axr	if prey != nobody  [
\axri		ask prey [ die ]
\axro	]
\axr  end
}}
\fbox{\parbox[b]{.65\tw}{\axrst\tt\scriptsize
\axr  public void step() \{
\axr	Context context = ContextUtils.getContext(this);
\axr	Grid patch = (Grid) context.getProjection("Simple Grid");
\axri	\angles{\textrm{compute new x, y}} \axout
\axr	patch.moveTo(this, x, y);	
\axr	for(Object o: patch.getObjectsAt(x,y))
\axri		if(o instanceof Sheep)
\axri			(Sheep)o.die(); \axrst
\axr  \}
}}
\\\vskip1ex (a) \hskip.4\tw (b) \hspace*{.2\tw} \\\vskip1ex
\fbox{\parbox[b]{.53\tw}{\axrst\tt\scriptsize
\axr	public void setup() \{
\axr	addBehavior(new TickerBehavior(this, tick) \{
\axr	x = \angles{new \; x}; y = \angles{new \; y};
\axr	DFAgentDescription template = new \axcont DFAgentDescription();
\axr	ServiceDescription sd = new ServiceDescription();
\axr	sd.setType("sheep");
\axr	sd.addProperties(new Property("x", x));
\axr	sd.addProperties(new Property("y", y));
\axr	template.addServices(sd);
\axr	DFAgentDescription[] result = \axcont DFService.search(this, template);
\axr	if (result.length > 0) \{
\axri		ACLMessage msg = new ACLMessage(REQUEST);
\axr		msg.addReceiver(result[0].getName());
\axr		msg.setContent("hunt");
\axr		send(msg);
\axro	\}	\});	\}
}}
\fbox{\parbox[b]{.42\tw}{\axrst\tt\scriptsize
\axr	public void step() \{
\axr	Position pos = e.getCurrentPosition();
\axr	for(Entity en : e.getEntitiesAt(pos))
\axri		if(en instanceof SheepAgent)
\axri			e.requestDestroyAgent(en);	\axrst
\axr	List<Position> next = \axcont e.getFreeNeighborPositions(pos)
\axr	Position newPos = \axr \hskip1ex next.get(random.nextInt(next.size()));
\axr	e.moveToPosition(newPos);
\axr	\}
}}
\\\vskip1ex (c) \hskip.5\tw (d) \\
}

\begin{figure}[t]\centering\wolfcode
\caption{The code for the \emph{Wolf} agent in the predator-prey scenario in NetLogo (a), Repast (b), \jade (c), and \fmas with ABM adaptations (d).}\label{fig:wolf-agent}\end{figure}


Should P1 not be respected, and should the agent be able to execute external actions directly, in simulation it may perform multiple actions in the same step, while the other agents are waiting their turn, breaking the illusion of simultaneity of agents' execution.

Should P2 not be respected, and should agents be able to communicate or interact directly, in simulation again they would break the illusion of simultaneity, and it would not be possible to use an appropriate communications infrastructure for each situation.

Finally, should P3 not be respected, controlling the execution of the agent would not be possible. Inability to suspend execution of an agent would mean the inability to practically simulate large numbers of agents on a single system. If agents do not respect the length of a step, then some agents would be able to do more things in one global step than others, again breaking perceived simultaneity.


% DONE try to make font one larger
% DONE adapt to include sendEvents
\newcommand{\executioncode}{\fbox{\parbox{.9\tw}{\scriptsize\axrst\lcrst

\axr	$Simulation\_step()$
\axr	\ck{global:}  $step\_time$
\axr	\ck{initially:} $step \la 0$ ; $time[a] \la 0, \forall a \in agents$ ;
\par\hskip10ex    	$pending\_messages \la \emptyset$ ; $deliverable\_messages \la \emptyset$
\bxr		$step$ \crm{\codeS{+=}} 1
\bxr		\ck{for} $a \in agents$	\ck{do}								\hfill \rule{.3\tw}{0.4pt}
\bxri			\ck{for} $ c \in contexts $								\hfill \emph{update phase}
\bxri				$ c.sendEventsTo(a) $ \axout\axout
			\hskip7ex \angles{\textrm{\scriptsize includes messages from $deliverable\_messages$}}
\bxcont\hskip3ex		\angles{\textrm{\scriptsize agents process events, update state, but initiate no actions}}
\bxr		\ck{for} $a \in filter\_active(agents)$	\ck{do}				\hfill \rule{.3\tw}{0.4pt}
\bxri			\ck{switch} $a.type$ :									\hfill \emph{agent step phase}
\bxri			\ck{case} \emph{step-wise}:
\bxri				$a.step()$
\bxcont\hskip3ex		\angles{\textrm{\scriptsize pulls events and messages not received at step 4}}
\bxcont\hskip3ex		\angles{\textrm{\scriptsize actions submitted to contexts, as \emph{pending}}}
\bxcont\hskip3ex		\angles{\textrm{\scriptsize messages added as pending in $pending\_messages$}}
\bxro			\ck{case} \emph{behavior-based}:
\bxri				\ck{while} $time[a] < step * step\_time$
% \axin\bxcont\hskip3ex		\angles{\textrm{\scriptsize deliver messages in $deliverable\_messages$ to agent $a$}}
\bxri					$ b \la a.next\_behavior() $
\bxcont\hskip3ex			\angles{\textrm{\scriptsize actions and messages added as pending}}
\bxr					$ \Delta t \la$ \ck{measure-time}: $ b.run() $
\bxr					$ time[a] \; \crm{\codeS{+=}} \Delta t $
\axout\bxro		\ck{case} \emph{event-driven}:
\bxri				\ck{if} $time[a] < step * step\_time$
% \axin\bxcont\hskip3ex		\angles{\textrm{\scriptsize deliver messages in $deliverable\_messages$ to agent $a$}}
\bxri					\ck{@time} ti : $ a.receive\_event(\crm{ \textsc{resume}}) $
\bxcont\hskip3ex			\angles{\textrm{\scriptsize processes any events arrived since last \textsc{suspend}}}
\bxcont\hskip3ex			\angles{\textrm{\scriptsize actions and messages added as pending}}
\bxr					$ sleep(step * step\_time - time[a])$
\bxr					$ a.receive\_event(\crm{ \textsc{suspend}}) $
\bxr					\ck{wait until not} $a.is\_running()$
\bxr					\ck{@time} tf : $ time[a] \la time[a] + tf - ti $	\axout\axout\axout\axout
		 																\hfill \rule{.25\tw}{0.4pt}
\bxr		\ck{for} $c \in contexts$									\hfill \emph{apply actions phase}
\bxri			$c.applyActions()$	\hskip3ex	\angles{\textrm{\scriptsize clears pending actions}}
\bxro		$ m \la filter\_deliverable\_messages(pending\_messages) $
\bxr		$ deliverable\_messages \la deliverable\_messages \cup m $
\bxr		$ pending\_messages \la pending\_messages \setminus m $
}}}

\newlength{\linenumberspace}
\newcommand{\counterspace}[1][3.5mm]{\setlength{\linenumberspace}{#1}}\counterspace

\counterspace[3ex]
\newcounter{currentindent}
\renewcommand{\ax}{\setcounter{currentindent}{0}\axwork}
\renewcommand{\axr}[1][0ex]{\setcounter{currentindent}{0}\par\parbox[c]{\linenumberspace}{\hskip1ex}\axwork\hspace*{#1}}
\newcommand{\axwork}{\ifnum \value{currentindent} < \value{indentlen}\addtocounter{currentindent}{1}{\color{lightgray}\vrule}\hspace*{2ex}\axwork\fi}
\renewcommand{\axin}{\addtocounter{indentlen}{1}}
\renewcommand{\axout}{\addtocounter{indentlen}{-1}}
\renewcommand{\bx}{\parbox[c]{\linenumberspace}{\normalfont\scriptsize\lc.\hspace*{1ex} }\ax}



\begin{figure}[t]\centering\fbox{\parbox{.98\tw}{\begin{tabular}{p{.43\tw}p{.54\tw}}\axrst\lcrst\scriptsize\raggedright
\bxr 	start all entities
\bxr 	for each step
\bxri		push events from each simulation context to each simulation object
\bxr		\texttt{step()} each simulation object
\bxr		simulation contexts execute actions
& \axrst\scriptsize\raggedright
\axr
\axr
\axr 	\ra\ no interactions between simulation objects added here, but internal state can be updated
\axr	\ra\ objects register pending actions to the contexts
\axr	\ra\ this is when actions are actually executed
\end{tabular}}}
\caption{High-level view of the process of executing simulation objects.}\label{fig:execution-phases}\end{figure}


\begin{figure}[th!]\centering\executioncode
\caption{Pseudo-code for one step / one time unit of the simulation, with cases for each type of internal agent architecture. We use \ck{measure-time} and \ck{@time} constructs to signify measurement of the time for a statement to complete and the time at which a statement gets to run, respectively.}\label{fig:executor}\end{figure}


\subsection{Execution}%\label{sec:}



% DONE table with high-level view of sexecution phases

The discussion about execution is important because while in MAS frameworks and network-distributed deployments agents control their own execution or the execution is organized in behaviors, whereas in ABM frameworks execution is usually step-wise (tick-based) or reflex-based (in reaction to events)\footnote{GAMA also supports equation-driven dynamics.}.

% DONE itemize types
However, completely isolating the agent mind from the point of view of interaction with the environment, communications, and execution, means that the pace of execution could be controlled. To show this, we consider three types of internal agent architectures: \emph{step-wise} -- like in most ABM applications, in which the decision making policy is contained in a \codeS{step()} method which performs one unit of the agent's activity, with all agents performing roughly the same amount of processing in one step; \emph{behavior-based} -- like in \jade or SPADE, in which the agent is defined by a set of behaviors that react to events (e.g. messages) or are scheduled, with the behaviors themselves not blocking the agent and not taking more than a reasonable amount of time; and \emph{event-driven} -- like, for instance, in \fmas[], in which the agent is built around a queue of events, which it processes in order, one at a time. 

In any case, according to principles P1 and P2, performing any action (including communicative acts) is done via a context, which, depending on the type of scenario (\real\ or \sim) performs the action \emph{immediately} or \emph{defers} it to a later time.

% DONE mention somewhere that actions are never instantaneous, and the time to execute an action is the agent step. Same with comms. Maybe put this where steps are defined

If the three principles are respected, execution can be \emph{suspended}, and execution speed can be \emph{controlled}. The execution is detailed in Figure \ref{fig:executor}. Since the realization of actions is decoupled from the time at which the action is requested in the agent code, then the following conditions are obtained: 		\begin{itemize}
	\item no actions are \emph{actually} executed during the \emph{agent step phase} (the state of the environment is not changed), so during their activity all agents \emph{perceive} the same environment, before any action from that step is applied;
	\item all actions are realized (applied to the environment) during the \emph{update phase}, providing the appearance of simultaneity;
	\item subject to cooperation from the agent code (behaviors / event processing do not block or take disproportionately longer than other agents), each agent step takes more or less the same amount of time, \emph{chosen} to be enough for the decision process but also sufficiently granular for sequential interactions to appear natural -- during a step an agent can perform about one action, or can send about one message in a conversation;
	\item no messages are delivered instantaneously, and message delivery for any message takes at least one step, and may take more depending on how the function $filter\_deliverable\_messages$ is implemented;
	\item for \emph{event-driven} agents, messages and other events \emph{can} be delivered at any time, as the agent is suspended and will only be able to process them after the \textsc{resume} event.
																\end{itemize}
When agents run in \real\ scenarios, they can be executed independently, in their own threads, and interaction can take place in the same manner as in \sim\ scenarios, just that they do not need to be buffered any more. The \emph{Context Link} components, adapted to the \real\ scenario, can relay the perceptions and the actions directly from and to the appropriate external components, without buffering. Similarly, messages can be relayed to the agent as they are received via the \emph{Communications Infrastructure}.
 


\begin{figure}[t]\centering

\scalebox{.8}{\begin{tikzpicture}[
    >=Stealth,
    timeline/.style={thick,->},
    msg/.style={->,thick},
    event/.style={circle,fill,inner sep=1.3pt},
    node distance=12mm and 16mm,
    every node/.style={font=\small}
]

% Timeline starts
\node (a1start) {};
\node[below=3mm of a1start] (a2start) {};

\draw[timeline] (a1start.center) -- ++(9,0) node[right] {$a_1$};
\draw[timeline] (a2start.center) -- ++(9,0) node[right] {$a_2$};

% Events on a1
\node[event,right=22mm of a1start] (send1) {};
\node[event,right=42mm of send1] (recv1) {};

% Event on a2
\node[event,below=4.6mm of $(send1)!0.5!(recv1)$] (recv2) {};

\node[above=1mm of send1] {send};
\node[above=1mm of recv1] {receive};
\node[below=1mm of recv2] {receive/send};

\draw
([xshift=4mm]send1.north) -- ([xshift=-4mm]recv1.north) node[midway,above=6pt] {\emph{wait}};

% Messages
\draw[msg] (send1) -- (recv2); \draw[msg] (recv2) -- (recv1);
\end{tikzpicture}}

(a)

\scalebox{.8}{
\begin{tikzpicture}[
    >=Stealth,
    seg/.style={thick},
    msg/.style={->,thick},
    event/.style={circle,fill,inner sep=1.3pt},
    node distance=10mm and 16mm,
    every node/.style={font=\small}
]

% Left a1 segment
\node (a1l) {};
\draw[seg] ($(a1l)+(-10mm,0)$) -- ($(a1l)+(22mm,0)$);

% Right a1 segment
\node[right=66mm of a1l] (a1r) {};
\draw[seg] ($(a1r)+(-10mm,0)$) -- ($(a1r)+(22mm,0)$) node[right] {$a_1$};

% a2 segment
\node[below=9mm of a1l] (a2) {};
\draw[seg] ($(a2)+(25mm,0)$) -- ($(a2)+(55mm,0)$) node[right] {$a_2$};

% Time not perceived
% \node[align=center] at ($(a1l)!0.5!(a1r)+(0.5,0mm)$)
% {time\\not perceived};

% Separator
\draw[dashed] ($(a1r)+(-12mm,7mm)$)
-- ($(a1r)+(-12mm,-17mm)$);

% Communication region
\draw ($(a1l)+(0mm,-5mm)$)
    rectangle
    ($(a1l)+(78mm,-7mm)$);

\node at ($(a1r)+(22mm,-6mm)$) {comms};

% Step labels
\node at ($(a2)+(8mm,-8mm)$) {step $t$};
\node at ($(a2)+(72mm,-8mm)$) {step $t+1$};

% Left send
\node[event,right=10mm of a1l] (send1) {};
\draw[msg] (send1) -- ++(0,-5mm);
\node[above=2mm] at (send1) {send};

% Receive/send on a2
\node[event,right=28mm of a2] (recv2) {}; \node[above=3mm of recv2] (src-recv2) {};
\node[below=2mm] at (recv2) {receive};
\draw[msg] (src-recv2) -- (recv2);

\node[event,right=20mm of recv2] (send2) {};
\draw[msg] (send2) -- ++(0,4mm);
\node[below=2mm] at (send2) {send};

% Right receive
\node[event,left=5mm of a1r] (recv1) {}; \node[below=4mm of recv1] (src-recv1) {};
\draw[msg] (src-recv1) -- (recv1);
\node[above=2mm] at (recv1) {receive};

\end{tikzpicture}}

(b)
\caption{(a) a round-trip message between agents $a_1$ and $a_2$ in \real\ or in a \sim\ scenario, as \emph{perceived} by the agents. (b) the same interaction, in step-based execution.}\label{fig:timeline}\end{figure}


\section{Proof-of-Concept Modeling and Implementation}%\label{sec:}

We have performed a primary validation of the principles presented in the previous section by creating a proof-of-concept implementation of a classic ABM scenario -- the predator-prey scenario. In this scenario, a number of \emph{wolf} agents and a number of \emph{sheep} agents share the same discrete environment in which sheep consume grass and wolves eat sheep.


\subsection{Prerequisites}%\label{sec:}

We have validated the principles by implementing the scenario as an ABM simulation in a framework that was initially built for \real\ deployments. We have chosen for this implementation the \fmas framework, not only because it is built in our team and we have more control over it, but because its flexibility and modularity make the implementation much easier\footnote{\fmas is open source and available at \href{github.com/andreiolaru-ro/FLASH-MAS}{https://github.com/andreiolaru-ro/FLASH-MAS}. This work is based on the \codeS{abms} branch, due to pe merged during 2026.}.

\fmas is a MAS framework built around the idea that all persistent elements in a MAS are \emph{entities} sharing a uniform interface \cite{OSF19}. Entities, some of which can be distributed, are placed in the context of one another and are able to access the functionality of their containers. In \fmas[], each agent normally (\real) has its own execution thread, in which a queue of events is processed and disseminated to sub-agent entities called \emph{shards}, each shard managing an aspect of the agent's functionality, such as messaging, remote operation, graphical interface, goal management, etc. Among other predefined entities there are the \emph{nodes} -- representing the presence of the framework on a machine -- and \emph{pylons} -- representing communication infrastructures that span across multiple nodes. However, any custom type of entity can be defined and integrated seamlessly into the framework.

Central to \fmas is that entities are placed \emph{in the context of} one another, such that each entity has access to the functionality of entities in the context of which it is placed. For instance, agents, but also their shards, have access to the pylons that contain them. Or, if an agent is placed in the context of a node, its shards have access to functionality offered by the node, etc.

\subsection{Components}%\label{sec:}

For the implementation, we have asked the question: \emph{can we run a simulation in a framework primarily built for network-deployed applications and, if yes, what are the components needed to be added in the framework to support ABM simulation}?

Following the entity-based principle of the \fmas framework, we have first identified which are the different types of entities needed to run an ABM simulation. The criteria by which we have decided to separate components (rather than just have a monolithic approach) was which components could we want to be able to implement differently, or customize for different functionality, while leaving the others untouched. As such, we have identified several \textbf{types of entities}: the \emph{simulation}, the \emph{executor}, \emph{simulation contexts}, \emph{environment link shards}, and \emph{reporter}. The relations between these types of entities are summarized in Table \ref{tab:relation}.

\begin{figure}[t]\centering
\picSww[.9]{arch}
\caption{The entities and relations among them in a simulation setup. \emph{Agents} use \emph{environment link shards} to connect to \emph{contexts}. The \emph{simulation} creates and configures all other entities. The \emph{executor} steps the agents and instructs the execution of actions to the contexts. The \emph{reporter} obtains information from the contexts to be visualized.}\label{fig:components}
\end{figure}

The \textbf{simulation} takes the place of the \emph{node} in an \real\ deployment to manage the simulation and the entities within it. Beside the executor, the simulation contains the \emph{simulation objects} -- the entities that are \emph{inside} the simulation, such as agents -- and \emph{simulation contexts} -- the entities which are not inside the simulation, and that represent the environment of the simulated objects.

The \textbf{executor} handles execution control, such as stepping the entities that support step-wise execution, and suspending and resuming entities that do not.

\textbf{Simulation contexts} are any entities that represent the environment and anything that is \emph{outside} of the agent's mind. There are several simulation contexts that are general to many ABM applications, such as the spatial context (\emph{where} the agents are located), the temporal context (\emph{when} things should happen in the simulation), social context (\emph{who} interacts with an agent), and agent management context (creating and destroying agents).

When an agent or another entity requests a context to perform an action, the action is added to a \emph{queue} and performed when the executor signals that all the agents have completed their step (see Figure \ref{fig:executor}). Since the agents are not able to obtain an \emph{immediate} feedback for their actions, contexts \emph{store} meta-data for the actions, such as the status (pending / completed / failed), action result, and the originating entity. The status and the result of the action can be checked by the agent later on.

\textbf{Simulation objects} are any entities that are an \emph{object} of the simulation. They are part of the simulation and are being studied through it. These are usually agents, but there could be other entities as well. For instance, to eschew the need to represent patches as agents, as in NetLogo, patches may be their own type of first-class entities.

An \textbf{Environment Link Shard} (\emph{ELS}) is an entity that is part of an agent or another simulated object and ensures the link between the entity and the various contexts that is a part of. While the implementation supports multiple ELS for the same simulation object, it is easier to just use one for the usual cases. The reason why we should have the ELS as an interface between the simulated object and the simulation contexts is twofold: (1) to separate from the agent's mind the concern of discovering and managing the link with the simulation contexts and to offer a single point of relation to the contexts; and (2) to ensure that the agent code can use the same constructs, that access the functionality of the ELS, without concern for how exactly the functionality of the contexts is accessed, offering flexibility when moving between the \sim\ and \real\ scenarios. We will show some examples below.

\textbf{Reporters} are entities that allow the visualization and reporting on the state of simulated objects. They are similar to contexts, but they do not offer functionality to the simulated objects and are not visible to them, rather they obtain information about the objects via the contexts or directly via accessible properties of the objects.

\textbf{Agent Groups} are a helper entity that enables the loading and management of groups of identical agents. The group \emph{loads} the agents and configures them, following rules specific to the group.

\dx[diagram with entities]

\begin{table}[t]\centering\begin{tabular}{
							 | >{\scriptsize\raggedright\arraybackslash}p{.22\tw}
							 | >{\scriptsize\raggedright\arraybackslash}p{.15\tw}
							 | >{\scriptsize\raggedright\arraybackslash}p{.15\tw}
							 | >{\scriptsize\raggedright\arraybackslash}p{.42\tw} |}\hline
Entity				 & Direct context & Other context & How context is used \\\hline
simulation			 & --			& --
				& -- \\\hline
executor			 & simulation	& --
				& access to the list of entities in the simulation \\\hline
simulation context
(\emph{sim-context}) & executor		& simulation
				& simulation: access to other simulation contexts, access to list of simulation objects, access to execution status \\\hline
simulation object
(\emph{sim-object})	 & sim-context	& executor, simulation
				& sim-context: access to environment and communication \\\hline
agent group\par (is a
 \emph{sim-object})	 & sim-context	& executor, simulation
				& sim-context: access to environment and communication \\\hline
agent \par (is a
 \emph{sim-object})	 & agent group \emph{or} sim-context & executor, simulation
				& sim-context: access top environment and communication; agent group: coordination with other agents in the group \\\hline
shard				 & agent		& sim-context, executor, simulation
				& agent: access to other shards; sim-context: access to environment and communication \\\hline
\emph{ELS}			 & sim-object	& sim-context, executor, simulation
				& sim-context: access to environment and communication \\\hline
reporter			&	executor	& simulation
				& simulation: access to data avout sim-contexts and sim-objects \\\hline
\end{tabular}\caption{Relations between types of entities and their contexts. $A$ is a direct context of $B$ if no other entity $C$ is a context of $B$ and in the context of $A$.}\label{tab:relation}\end{table}


The implementation uses the existing \fmas \textbf{communications pylon} abstraction as a provider for communication services, and the \emph{messaging shard} as interface to the pylon. In \real\ scenarios, messages will be delivered immediately; in \sim\ scenarios, messages are kept as \emph{pending} and delivered in the next step.


\subsection{Deployment and Functionality}%\label{sec:}


\begin{figure}[t]\centering\begin{minipage}{.5\tw}\scriptsize
\begin{verbatim}
-load_order simulation;executor;context
-package abms.wolfSheepPredation
-simulation sim classpath:Simulation
  -executor StepWise:StepWise steps:100
    -context AgentManagement:agentManagement
    -context Space:space width:100 height:100
    -context Random:random seed:64
    -context ProximityCommunication:comms
      -WolfSheepGroup g sheepCount:5000
                        wolfCount:2000
                        grassCount:500
\end{verbatim}
% {\centering\small (a) \par}
% \hrule
% \begin{verbatim}
% -load_order WolfSheepGroup
% -package abms.wolfSheepPredation";
% -loader WolfSheepGroup";
% -node base
%   -WolfSheepGroup g sheepCount:5000
%                     wolfCount:2000
%                     grassCount:500";
% \end{verbatim}
% {\centering\small (b) \par}
\end{minipage}\hskip2ex
\begin{minipage}{.45\tw}\centering\picSww[1]{wolf-sheep-5000-sel}\end{minipage}\par
(a) \hskip.5\tw (b)

\vskip1ex
\begin{minipage}{.6\tw}\scriptsize
\begin{verbatim}
-load_order simulation;executor;context
-package abms.smartMeeting
-simulation sim classpath:Simulation
  -executor StepWise:StepWise steps:60
    -context AgentManagement:agentManagement
    -context Random:random seed:51
    -context GraphCommunication:communication
    -context Space:space topology:graph
      nodes:lobby,r1,r2,r3,r4,r5,r6
      edges:lobby-r1,lobby-r2,lobby-r3,r1-r4,r3-r5,r5-r6
    -SmartMeetingGroup g
      -agent Auction n:1 releaseAfterSteps:20
      -agent Room n:6 capacity:8
      	 equipment:PROJECTOR,WHITEBOARD,VIDEO_CONFERENCE
      -agent Person n:3 auctionAgent:auction0
\end{verbatim}
\end{minipage}
\hskip1ex\vrule\hskip1ex
\begin{minipage}{.35\tw}\scriptsize
\begin{verbatim}
-package abms.smartMeeting
-node lobby
  -pylon WSRegions:p-lobby
    -agent Auction:action0
        releaseAfterSteps:20
    -agent Room:lobby
    -agent Person:p1
        auctionAgent:auction0
-node r1
  -pylon WSRegions:p-r1
    -agent Room:r1 capacity:8
        equipment:PROJECTOR
-node r2
  -pylon WSRegions:p-r2
    -agent Room:r2 capacity:8
        equipment:WHITEBOARD
...
\end{verbatim}
\end{minipage}
\hspace*{.15\tw} (c) \hskip.45\tw (d)
\caption{Deployment configurations in \fmas for various scenarios: (a) the wolf-sheep multi-agent system in a \sim\ scenario; (b) simple visualization for the wolf-sheep scenario, cropped from a 7000 agent deployment; (c), (d) deployment configurations for the smart room scenario, in \sim\ and \real, respectively.}\label{fig:deployment}\end{figure}


% Following the modular approach in \fmas[], deployment of a multi-agent system is configured via a configuration specifying the entities to be loaded, as shown in Figure \ref{fig:deployment} (a) and (b). The \emph{simulation} entity handles the loading of the other entities; the \emph{agent group} entity handles the loading and configuration of the \emph{wolf} and \emph{sheep} agents. The configuration is similar in a \sim\ scenario and in a \real\ scenario, with the difference of the components necessary for the \sim\ scenario -- the simulation, executor, and contexts. The change in functionality of the \emph{Context Link} / the \emph{Environment Link Shard} is covered via the \emph{recommended shard} functionality by which entities are able to request hints for the implementation of shard from their contexts. However, it is only the implementation of the \emph{Link} shard that changes. The agent code remains the same.

To validate whether a MAS framework can run ABM simulations, and how agent code can be switched between \sim\ and \real\ scenarios, we have implemented several applications using \fmas and the \emph{simulation contexts} that we have developed. Among these, a classic wolf-sheep scenario and an application for the dynamic allocation of meeting rooms.

Deployment of these scenarios uses the hierarchical, entity-type-based configuration in \fmas[]. Configuration is similar in the two types of scenarios, except for simulation contexts and communication platforms in \sim\ and \real\ scenarios, respectively.

The simulation contexts that we have developed to support \sim\ scenarios can be \emph{reused} between applications, for instance the \codeS{AgentManagement} and \codeS{Random} contexts, as well as the \codeS{Space} context, even if using different \emph{topologies}.

The wolf-sheep simulation has been deployed with 5000 sheep and 2000 wolves, to evaluate if increasing the number of agents has a significant overhead. As execution of the agents was sequential, no problems were encountered. Further testing will be performed with larger numbers of agents and more complex behaviors, studying the impact of the number of agents on the performance of the simulation.



\dx[action status, get actions]

\dx[loading, agent groups]



\section{Discussion}%\label{sec:}

\dx[extending principles to other frameworks]

% NO (more space) expand discussion

Even if the principles presented in Section \ref{sec:principles} have been developed while designing and implementing simulation features in the \fmas framework, they have been created as general guidelines that could be applied in the case of other MAS frameworks.

In JaCaMo-sim, the decoupling of agent code from the environment is done via Execution Contexts. Moreover, JaCaMo has the capability to run on different underlying communication infrastructures, both \jade[-]based (slow, but network-capable) and local (fast, but constrained to one node). However, as artifacts are programmed in Java, and not as higher-level entities, their execution cannot be controlled as well as for agents.

\jade would require several changes to become capable of local simulations. More flexibility is required from changing the message transport protocol. Behavior execution can be changed to allow the control of behavior execution. Agents are already isolated from their executors (the developer does not create the thread that the agent runs on), so from this point of view simulation would be possible. However, as highlighted by \cite{Car16}, blocking calls are an issue, as well as some of the temporal management. \jade has not been built as a modular framework, which makes the replacement of the framework components difficult.

Conversely, enabling the running of ABM-specific agent code in real-life deployments also brings challenges. In NetLogo and GAMA, the use of specific programming languages hinders interoperation with outside components, as they would need the addition of dedicated language constructs.

Repast, with agents written in Java and with its reliance on contexts, comes closest to having the ability to deploy agents in a real-life scenario, with the condition, of course, of building adequate interaction infrastructures and environment abstractions.


\nx[comparison of existing framework features]


\section{Conclusions and Future Work}%\label{sec:}

% We are now in a continuing process of researching means of reconciling ABM platforms with MAS frameworks and building a set of tools that allow both simulation and real-time deployment with the same code.

We have observed that reconciling ABM platforms with MAS frameworks cannot be achieved, when agents are programmed in a general-purpose programming language, without code respecting several principles when interacting with the environment, timing, and communicating with other agents, which must be done via dedicated components. Agent code must allow for execution control.

% future
This research has a long way to go. We envision bringing simulation capabilities to applications using agents programmed in domain-specific languages, such as ASTRA or Jason. We plan a series of complex scenario deployments to test the limits of our approach, as well as the development of visualization and monitoring tools that allow for the quantitative evaluation of these scenarios.

% intention to set up principles and propose F-MAS as a good candidate; it is welcome to propose collaborations and applications

% the rest of the steps

% \begin{credits}
\subsubsection{\ackname} This research is supported by the project ``Romanian Hub for Artificial Intelligence -- HRIA'', Smart Growth, Digitization and Financial Instruments Program, 2021-2027, MySMIS no. 334906.
% \end{credits}

\bibliographystyle{splncs04}
% \bibliography{../_bib/bib,../_bib/mypublications}
\bibliography{bib,mypublications}
\end{document} 



