Skip to content

Commit

Permalink
[Civl] Simplify and generalize invariants for ticket protocol (#834)
Browse files Browse the repository at this point in the history
Co-authored-by: Shaz Qadeer <[email protected]>
  • Loading branch information
shazqadeer and Shaz Qadeer authored Jan 16, 2024
1 parent 6ad1aff commit 2f8cbde
Showing 1 changed file with 2 additions and 8 deletions.
10 changes: 2 additions & 8 deletions Test/civl/samples/ticket.bpl
Original file line number Diff line number Diff line change
@@ -1,11 +1,6 @@
// RUN: %parallel-boogie "%s" > "%t"
// RUN: %diff "%s.expect" "%t"

function RightOpen (n: int) : [int]bool;
function RightClosed (n: int) : [int]bool;
axiom (forall x: int, y: int :: RightOpen(x)[y] <==> y < x);
axiom (forall x: int, y: int :: RightClosed(x)[y] <==> y <= x);

type Tid;

var {:layer 0,1} t: int; // next ticket to issue
Expand All @@ -18,13 +13,12 @@ var {:layer 1,2} T: [int]bool; // set of issued tickets

function {:inline} Inv1 (tickets: [int]bool, ticket: int): (bool)
{
tickets == RightOpen(ticket)
(forall i: int :: tickets[i] <==> i < ticket)
}

function {:inline} Inv2 (tickets: [int]bool, ticket: int, lock: Option Tid): (bool)
{
if (lock is None) then tickets == RightOpen(ticket)
else tickets == RightClosed(ticket)
lock is None || tickets[ticket]
}

// ###########################################################################
Expand Down

0 comments on commit 2f8cbde

Please sign in to comment.