Skip to content

Latest commit

 

History

History
77 lines (62 loc) · 5.75 KB

README.md

File metadata and controls

77 lines (62 loc) · 5.75 KB

HLola logo

HLola

HLola is a Haskell implementation of the Stream Runtime Verification language Lola. In this repository, you will find the source code of HLola, example specifications, and the steps to use the engine and define new specifications. For more information, visit the HLola official website.

Docker image

We provide a Docker image ready to build and execute HLola specifications out of the box.

You can run the image with no arguments to execute a batch of specifications:

$> docker run imdeasoftware/hlola:tacas

or you can run a set of specifications passing their ids as arguments. You can also pass the argument --live to see the monitors work online. For example:

$> docker run imdeasoftware/hlola:tacas --live PLTLCSV # or
$> docker run imdeasoftware/hlola:tacas MTLJSON # or
$> docker run imdeasoftware/hlola:tacas --live UAV2

See the following section to find out the specification ids.

List of example specifications

Description of example specifications

  • PLTL example: a Past-Linear Temporal Logic (PLTL) property for a sender/receiver model taken from [1]:

      G (sender.state = waitForAck => Y (H sender.state != waitForAck))
    

    which states that, it Globally holds that if the sender is waitingForAck, then Yesterday (i.e. at the previous instant), Historically it held that the sender state was not waitingForAck. In other words, the sender waits for acknowledgement at most once during the execution. The only input stream is the state of the sender at each instant. The only output stream is the value of the property at each instant. (TOFIX)

  • MTL example: a Metric Temporal Logic (MTL) property to establish deadlines between environment events and the corresponding system responses taken from [2]:

    G (alarm => (F[0,10] allclear || F[10,10] shutdown))
    

    The property assesses that an alarm is followed by a shutdown event in exactly 10 time units unless all clear is sounded first. The only input stream is the event happening at each instant. The only output stream is the value of the property at each instant.

  • Pinescript example: TradingView is an online charting platform for stock exchange, which offers a series-oriented language to create customized studies and signals (called Pinescript) and run them in the company servers. We have implemented the indicators of Pinescript in HLola as a library, and we show the implementation of a trading strategy using the HLola Pinescript library. The input streams are the close and high values of a stock at each day. The output streams indicate how much stock to buy or sell every day.

  • UAV specification 1: This specification is an online monitor to assess two properties over the flight of an UAV in real time:

    1. That the UAV does not fly over forbidden regions, and
    2. That the UAV is in good position when it takes a picture.

    The input streams of this specification consist of the state of the UAV at every instant and the onboard camera events to detect when a picture is being captured. The output streams are the values of properties 1. and 2.

  • UAV specification 2: This specification estimates the trajectory of a flying UAV to assess if it will reach its target destination. Fly gif

    The input streams are data on the state of the vehicle at every instant and its target destination. The output stream shows how close to the target destination will the vehicle fly.

  • Libraries: These files encompass the implementations of the libraries PLTL, MTL, Quantitative Metric Temporal Logic (QMTL) and Pinescript.

References

[1]: Alessandro Cimatti, Marco Roveri and Daniel Sheridan "Bounded Verification of Past LTL". In Proc. of the 5th Int'l Conf on Formal Methods in Computer-Aided Design (FMCAD'04)', pp 245-259, vol 3312 of LNCS, Springer, 2004.

[2]: Ouaknine J., Worrell J. (2008) Some Recent Results in Metric Temporal Logic. In: Cassez F., Jard C. (eds) Formal Modeling and Analysis of Timed Systems. FORMATS 2008. Lecture Notes in Computer Science, vol 5215. Springer, Berlin, Heidelberg.