Using and building an automatic program verifier
This presentation is the property of its rightful owner.
Sponsored Links
1 / 7

Using and Building an Automatic Program Verifier PowerPoint PPT Presentation


  • 55 Views
  • Uploaded on
  • Presentation posted in: General

Using and Building an Automatic Program Verifier. K. Rustan M. Leino Research in Software Engineering ( RiSE ) Microsoft Research, Redmond. Lecture 2 LASER Summer School 2011 Elba, Italy 7 September 2011. Termination.

Download Presentation

Using and Building an Automatic Program Verifier

An Image/Link below is provided (as is) to download presentation

Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author.While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server.


- - - - - - - - - - - - - - - - - - - - - - - - - - E N D - - - - - - - - - - - - - - - - - - - - - - - - - -

Presentation Transcript


Using and building an automatic program verifier

Using and Building an Automatic Program Verifier

K. Rustan M. Leino

Research in Software Engineering (RiSE)

Microsoft Research, Redmond

Lecture 2

LASER Summer School 2011

Elba, Italy

7 September 2011


Termination

Termination

  • A variant function is an expression whose values goes down (in some well-founded ordering) with every iteration/call

At the time of the call, the callee’s variant function must be less than the caller’s

while (B){ S;}

method M(){ P();}

At the time a loop back-edge is taken, the value of the variant function must be less than at the beginning of the iteration


Proving termination

Proving termination

demo

Termination


Motivation for using lemmas

Motivation for using lemmas

demo

FindZero


Lemmas induction

Lemmas, induction

demo

Gauss2


Exercises

Exercises

  • McCarthy

    • http://rise4fun.com/Dafny/6bq

  • Coincidence

    • http://rise4fun.com/Dafny/WvG

  • Saddleback search

    • http://rise4fun.com/Dafny/U5h

  • Max is transitive

    • http://rise4fun.com/Dafny/z9J

  • Reverse-Reverse

    • http://rise4fun.com/Dafny/1g


Links

Links

  • Dafny

    • research.microsoft.com/dafny

    • rise4fun.com/Dafny/tutorial/guide

  • rise4fun

    • rise4fun.com

  • Verification Corner

    • research.microsoft.com/verificationcorner


  • Login