Skip to content

ruth561/VerifiedDBM

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DBM Algorithm and Data Structures Verified using Creusot

What is this?

This repository contains the implementation of the DBM (Differential Bound Matrix) algorithm and its associated data structures in Rust. The DBM algorithm is widely used for time constraint management in real-time system. To enhance robustness, these implementations have been formally verified using Creusot.

What Properties are Verified?

We have verified the following properties for each DBM operation:

  • Changes on these operations
  • Preservation of canonicity in these operations

DBM Operations

Implemented and Formally Verified Features

  • up
  • down
  • free
  • reset

Not Implemented Features

  • shift
  • and
  • etc...

Getting Started

To use this repository, you will need to have Creusot installed on your machine. If you haven't installed it yet, refer to the README.md in the official repository. Make sure to install version 0.1.1 of Creusot, either by installing from source ref v0.1.1 or by downloading the source from the release page.

Next, clone this repository and then move into to the dbm-creusot directory:

$ git clone https://github.com/ruth561/VerifiedDBM.git
$ cd dbm-creusot

Now, all necessary procedures are completed! To perform proofs for each DBM operation, please execute the following command:

$ cargo creusot why3 ide

Overview of the Repository

All implementations for DBM operations are contained within the src/ directory. We have implemented each DBM operation in separate files. For example, the down operation is implemented in the src/down.rs file.

Future Works

Although we have implemented these features in a simplified manner to ensure successful verification, more accurate implementations are needed for practical use. Future implementations should include:

  • Distinguishing between (<, m) and (<=, m)
  • $k\text{-Normalization}$
  • $k,\mathcal{G}\text{-Normalization}$

About

DBM Implementation Verified by Creusot

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages