fbpx
Wikipedia

Invariant-based programming

Invariant-based programming[1] is a programming methodology where specifications and invariants are written before the actual program statements. Writing down the invariants during the programming process has a number of advantages: it requires the programmer to make their intentions about the program behavior explicit before actually implementing it, and invariants can be evaluated dynamically during execution to catch common programming errors. Furthermore, if strong enough, invariants can be used to prove the correctness of the program based on the formal semantics of program statements. A combined programming and specification language, connected to a powerful formal proof system, will generally be required for full verification of non-trivial programs. In this case a high degree of automation of proofs is also possible.

In most existing programming languages the main organizing structures are control flow blocks such as for loops, while loops and if statements. Such languages may not be ideal for invariants-first programming, since they force the programmer to make decisions about control flow before writing the invariants. Furthermore, most programming languages do not have good support for writing specifications and invariants, since they lack quantifier operators and one can typically not express higher order properties.

The idea of developing the program together with its proof originated from E.W. Dijkstra. Actually writing invariants before program statements has been considered in a number of different forms by M.H. van Emden, J.C. Reynolds and R-J Back.

See also edit

Notes edit

  1. ^ Back, Ralph-Johan: Invariant Based Programming: Basic approach and Teaching Experience, Formal Aspects of Computing, 14 February 2008, ISSN 0934-5043 (Print) 1433-299X (Online)

invariant, based, programming, programming, methodology, where, specifications, invariants, written, before, actual, program, statements, writing, down, invariants, during, programming, process, number, advantages, requires, programmer, make, their, intentions. Invariant based programming 1 is a programming methodology where specifications and invariants are written before the actual program statements Writing down the invariants during the programming process has a number of advantages it requires the programmer to make their intentions about the program behavior explicit before actually implementing it and invariants can be evaluated dynamically during execution to catch common programming errors Furthermore if strong enough invariants can be used to prove the correctness of the program based on the formal semantics of program statements A combined programming and specification language connected to a powerful formal proof system will generally be required for full verification of non trivial programs In this case a high degree of automation of proofs is also possible In most existing programming languages the main organizing structures are control flow blocks such as for loops while loops and if statements Such languages may not be ideal for invariants first programming since they force the programmer to make decisions about control flow before writing the invariants Furthermore most programming languages do not have good support for writing specifications and invariants since they lack quantifier operators and one can typically not express higher order properties The idea of developing the program together with its proof originated from E W Dijkstra Actually writing invariants before program statements has been considered in a number of different forms by M H van Emden J C Reynolds and R J Back See also editEiffel programming language Notes edit Back Ralph Johan Invariant Based Programming Basic approach and Teaching Experience Formal Aspects of Computing 14 February 2008 ISSN 0934 5043 Print 1433 299X Online Retrieved from https en wikipedia org w index php title Invariant based programming amp oldid 975976911, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.