/PsAlM

Pattern bAsed MIssion Specifier

Primary LanguageJava

PsAlM: Pattern bAsed MIssion Specifier

PsAlM is a Pattern bAsed MIssion Specifier implemented as a Java 1.8 application. It allows to create complex missions based on a set of Movement specification patterns. PsAlM can also send the created mission to a given planner that computes and executes it. It is fully integrated within the Co4robot project http://www.co4robots.eu/

PsAlM can be download at https://github.com/claudiomenghi/PsAlM/releases

You can consult the full list of patterns and have additional information in http://roboticpatterns.com

PsALM provides a GUI (1) that allows the definition of robotic missions requirements through a structured English grammar which uses patterns as basic building blocks and AND and OR logic operators to compose these patterns.

The SE2PT component extracts from a mission requirement the set of patterns that are composed through the AND and OR operators (2). The PT2LTL (3) and PT2CTL (4) components automatically generate LTL and CTL specifications from these patterns.

The produced LTL specification is an intermediate non-ambiguous artifact that can be used in different ways – three possible usages are presented in the figure above. The LTL formulae are (i) fed into an existing planner and used to generate plans that satisfy the mission specification (5); (ii) converted into Deterministic Buchi automata used as input to the Spectra robotic application modeling tool (6); and (iii) converted into the NuSMV input language to be used as input for model checking (7). The plans produced using the planner are (i) used as inputs by the Simbad simulation package (1), which is an autonomous robot simulation package for education and research; and (ii) performed by actual real robots (9). Produced CTL specifications are also converted into the NuSMV input language to be used as input for model checking (7).

Publications

  • Poster: Property Specification Patterns for Robotic Missions
    40th International Conference on Software Engineering (ICSE 2018), Poster Track
    Claudio Menghi, Christos Tsigkanos, Thorsten Berger, Patrizio Pelliccione, Carlo Ghezzi
  • Poster: PsAlM: Specification of dependable robotic missions
    41th International Conference on Software Engineering (ICSE 2019), Poster Track
    Claudio Menghi, Christos Tsigkanos, Thorsten Berger, Patrizio Pelliccione

Video of PsAlM in action

An overview on PsAlM

An overview on PsAlM is provided in the following figure

Image of the view text

The PsAlM GUI is organize in three different perspectives.

  • Robot Network Settings: it contains the address of a remote server able to forward the requests mission to the running robots. The server is organized in the following way. A client-server architecture is used to send mission to the running robots. A publish subscribe architecture is used to the remote application to notify the GUI of any change. For example, the publish subscribe architecture is used to notify the GUI when new locations and actions are detected
  • Pattern Panel Selection is used to specify the mission of interest by exploiting the proposed pattern catalog
  • Mission Library organizes the specified mission into a library that can be used to load, store and compose the missios of interest

Using PsAlM

Example scenarios

Coffe delivery

In this scenarios the robot has to bring the coffe to an employee. The mission is realizing by using the order visit pattern, that forces the robot to visit first the coffe room and then the office the employee and two instantaneous reaction patterns, one that asks a user to load the coffe on the robot when the kitchen is reached, the other that asks the employee to remove the coffe from the robot when the office is reached.

Fika organizer

Fika in sweden is a moment in which people have coffee accompanied with pastries, cookies or pie. The robot has to call people for the fika break. The mission is realizing by using the visit pattern (no ordering is required on how the employees are called), that forces the robot to visit two areas of a building. The instantaneous reaction patterns is used to specify that the robot should call employee for fika when each area is entered.

Fire robot

If a fire is detected the robot has to force the employee to leaving the building. The mission is realized using the patrolling pattern. The robot keeps patrolling the corridor and the kitchen. Two instantaneous reaction patterns are used to force the robot sending alerting messages to the employees.