This is the SARL Middleware infrastructure (MW) to control an agent team in the Agents in City Contest from the Multi Agent Contest. In particular, this is the MW for the RMIT 2018+ version of the game and server, which brings back items in shops as the 2017 edition.
The MW can be used to develop SARL agent controllers for Agents in City, providing convenient capacities and skills to sense and act in the game server.
You can see the infrastructure working by clicking on the following video:
This framework can be accessible via JitPack by adding the corresponding dependency and repository on the pom.xml
(see below).
- Java Runtime Environment (JRE) and Java Compiler (javac) v1.8+.
- Tested with SUN Java 1.8 and OpenJDK 11.
- Maven project management and comprehension tool (to meet dependencies, compile, package, run).
- The RMIT 2018+ game server edition (not the official 2018 server). This updated edition that brings back items to shop as in the 2017 version.
The following dependencies are resolved via Maven and JitPack automatically:
- SARL modules and execution engine.
- The EISMASSim environment interface connectivity that comes with the MASSim Agents in City Server (RMIT 2018+ edition).
- This is a Java API that provides high-level access to the game sever to avoid dealing with low-level XML or JSON messages. It uses the generic Environment Interface Standard (EIS) to communicate with the MASSim server (this is automatically gathered via Maven by the server package).
- The doc of the protocol and messages can be found here.
The system did not compiled anymore; see issue #13. The POM was fixed as per fix reported in SARL issue #1079.
However, the system yields error under Java 17, so we need to install and use Java 11 (linux):
$ export JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64
Maven will always use the Java set in JAVA_HOME
.
Semantic versioning is used with versions of the form Major.Minor.Patch
. Each version will rely on a particular SARL version, which is indicated via <sarl.version>
property in the POM file.
Most of the times one would just use this MW out-of-the-box to develop SARL controllers for the Agents in City game.
You can gather the MW via JitPack+GitHub by adding it as a dependency in the pom.xml
file of your SARL application as follows:
<properties>
<!-- SARL Agt City MW version - can use tag or commit hash id -->
<agtcity-sarl-mw.version>14b2889</agtcity-sarl-mw.version>
...
</properties>
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
<!-- SARL Agent City Interface -->
<dependency>
<groupId>com.github.ssardina-agts</groupId>
<artifactId>agtcity-sarl-mw</artifactId>
<version>${agtcity-sarl-mw.version}</version>
</dependency>
Alternatively, if you have the JAR file already of the MW, you can manually install it in your local Maven via mvn install:install-file
; for example:
mvn install:install-file -Dfile=agtcity-sarl-mw-1.2.0.7.2.jar -DgroupId=com.github.ssardina-agts \
-DartifactId=agtcity-sarl-mw -Dversion=1.2.0.7.2 -Dpackaging=jar
The MW comes with two simple SARL agent controllers that can be used for testing:
SingleRandomAgent
: a set of four connected entities/agents go to shops randomly and buy items.SingleGiveAgent
: two agents are connected, they go to shop1, one buys items and gives to the other.
-
Start RMIT 2018+ Game Server. From
server/
folder:$ ./startServer.sh conf/SampleConfig.json
or run it using Java itself:
$ java -jar target/server-2020-1.0-jar-with-dependencies.jar --monitor 8001 -conf conf/SampleConfig.json
Note that the configuration file (here,
conf/SampleConfig.json
) makes a reference to the team configuration file at the bottom (e.g.,conf/teams/A.json
) which is the file containing all agents allowed to connect and with which id and password. These are the ones your system will use in your agent configuration file.In the console of the server, you will see a URL link to the monitor. Click it to see the GUI interface of the game.
-
Start the SARL demo controller, either via ECLIPSE or through the CLI. For example:
$ mvn exec:java -Dexec.args="SingleRandomAgent conf/SingleAgent"
See below under Examples for more information on the two "dummy" controller examples provided here in the MW, mostly for testing and as agent templates.
-
Start the game simulation by just hitting ENTER in the Game Server console.
- The web GUI should start displaying/monitoring the simulation.
-
Enjoy! You should start seeing the agent reporting things in the console.
- You can see the simulation on the web browser.
Before explaining what the MW provides, in terms of capacities, skills, events and data structures, we need to understand the different abstractions from an actual entity entity in the game (e.g., a specific truck or drone) to a SARL agent controlling one more of those agents.
Because the framework involves the MASSIM game server, the EISMASSim Environment Interface (EI from now on) for MASSIM, and the SARL agents, there are different components and identifications that need to be well understood:
-
An entity is an agent playing in the simulation in some team, that is, a specific truck, drone, car in a team. A team will be composed of many entities of different types.
-
An entity connection represents a connection to a concrete entity in the game server (e.g., a truck or motorcycle) that can execute actions and can receive percepts. An entity connection is specified in the JSON configuration file by:
- A name of the connection, like
connectionA1
or justentityA1
. - The username (e.g.,
agentA1
) and a password to be able to successfully establish the connection to the entity in the game server. Via this credentials, the connection will link to a specific entity in the game (e.g., a specific truck).
- A name of the connection, like
-
An EI agent in the EI links/exposes an entity connection to the application. In general an EI agent may link to many entity connections, but for simplicity, the MW skill does a 1-to-1 link between EI agents and entity connections (i.e., entities on the game. So, for every entity connection, there will be a corresponding EI agent with the same name: EI agent
entityA4
in the EI will juts manage the entity connectionentityA4
(which could be, say, a truck in the game).
So, for example, EI agent entityA1
will be linked 1-to-1 to entity connection entityA1
that has a username agentA1
and a given password so as to control a truck in team A.
The MW provides:
- A capacity and associated skill
MassimTalking
to talk to the game server. - A capacity and associated skill
Reporting
to communicate information (in console). - A set of useful events.
- A class
State
that can store the current overall state of those entities connected. - Utility classes to create and update objects carrying domain information.
The main component of this infrastructure are the two capabilities provided with its corresponding skills:
C_MassimTalking
: the main capability of the MW allowing SARL agents to connect to the game server, register entities, and control such entities by receiving their sensing percepts and performing actions in the simulation. The skillS_MassimTalking
implements this capability for the Agent in City RMIT server.
The main tools provided by the C_MassimTalking
capability are:
- For setup:
- When you create the skill, you need to pass the directory where the server JSON config file is located (e.g.,
eismassimconfig.json
).- This file has the details of the game server (e.g., IP, port) as well as all the entity connections to the server (e.g.,
entityA1
orconnectionA1
).
- This file has the details of the game server (e.g., IP, port) as well as all the entity connections to the server (e.g.,
MT_registerEntityByName(entityName : String)
: register interest in controlling a given entity connection. If none is added, then it will be assumed that we will control all the connections in the server configuration file. This is useful if we do not want to control all the entity connections listed in the server configuration file, but only some of them.- Note this will NOT make the connection to the server, it will just signal the MW what will be controlled.
MT_initialize()
: will create all network connection to game server for the entities to be controlled. This will create one EI agent per entity connection, and register using each credentials.
- When you create the skill, you need to pass the directory where the server JSON config file is located (e.g.,
- For interaction with the game server:
MT_senseEntityPercepts(entityName : String) : Collection<Percept>
: sense the percepts of an entity; blocking.MT_executeAction(entityName : String, action : Action)
: instruct an entity to execute an action in the game.
- Getters:
MT_getEntitiesNames() : Set<String>
: list of entity connections registered in the MW.MT_getAllEntityData() : Map<String, EntityData>
: get theEntityData
of each registered entity.MT_getEntityData(entityName : String) : EntityData
: get theEntityData
of a given registered entity.MT_getStatus() : EnvironmentState
: get the state of the EI.MT_getStepNo() : int
: get the last simulation step number seen.
The S_MassimTalking
skill makes use of entity class EntityData
to store the latest info about each entity registered in the game. This class stores, for example, the location of the agent, its charge and load level, the items it is holding, etc.
C_Reporting
: a capability to report information. It provides two actions:
agent_says(message, param)
: says a message with varidic argumentsparam
.shouts_says(message, param)
: shouts a message with varidic argumentsparam
.
The skill S_ConsoleReporting
implements this capability by printing on console.
A set of events are provided for signaling various pieces of information related to the application (e.g., actions, percepts received, jobs available, information about entities, etc.).
Note these events are not posted automatically, but they are available to the programmer to emit.
A State
class is provided to aggregate a snapshot of the game as perceived by a SARL agent, which may sense across many entities. An object of this class can be used to carry the current snapshots of the simulator, as sensed via percepts.
So, the idea is to sense all entities and build an aggregated view (in which repeated percepts are made unique), and then act on that.
This package comes with two minimal examples that basically shows how to sense the environment, report some information, and move entities around randomly across shops known.
SingleRandomAgent
: a set of four connected entities/agents go to shops randomly and buy items.SingleGiveAgent
: two agents are connected, they go to shop1, one buys items and gives to the other.
The default Maven execution class is the booting class au.edu.rmit.agtgrp.agtcity.sarl.mw.BootMAS
which can take the agent to boot as argument or otherwise will ask the user for which one to execute:
mvn exec:java
This will ask for agent selection from the available ones and then which folder in conf/
to be used to find the eismassimconfig.json
server connection info file.
To directly specify which controller and server connection info file:
mvn exec:java -Dexec.args="SingleRandomAgent conf/SingleAgent"
If packaged with all dependencies one can use:
java -jar target/agtcity-sarl-mw-2.0.0.8.6-jar-with-dependencies.jar SingleRandomAgent
One then needs to select the single agent configuration conf/SingleAgent
, as all agents are controlled centrally.
- Sebastian Sardina (contact - [email protected])
- Bob Zhou
- Keiran Hines
This project is using the GPLv3 for open source licensing for information and the license visit GNU website (https://www.gnu.org/licenses/gpl-3.0.en.html).
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.