Title of article :
Proofs of randomized algorithms in Coq
Author/Authors :
Philippe Audebaud، نويسنده , , Christine Paulin-Mohring، نويسنده ,
Issue Information :
ماهنامه با شماره پیاپی سال 2009
Pages :
22
From page :
568
To page :
589
Abstract :
Randomized algorithms are widely used for finding efficiently approximated solutions to complex problems, for instance primality testing and for obtaining good average behavior. Proving properties of such algorithms requires subtle reasoning both on algorithmic and probabilistic aspects of programs. Thus, providing tools for the mechanization of reasoning is an important issue. This paper presents a new method for proving properties of randomized algorithms in a proof assistant based on higher-order logic. It is based on the monadic interpretation of randomized programs as probabilistic distributions (Giry, Ramsey and Pfeffer). It does not require the definition of an operational semantics for the language nor the development of a complex formalization of measure theory. Instead it uses functional and algebraic properties of unit interval. Using this model, we show the validity of general rules for estimating the probability for a randomized algorithm to satisfy specified properties. This approach addresses only discrete distributions and gives rules for analyzing general recursive functions.We apply this theory to the formal proof of a program implementing a Bernoulli distribution from a coin flip and to the (partial) termination of several programs. All the theories and results presented in this paper have been fully formalized and proved in the Coq proof assistant.
Keywords :
Proof of partial and total correctness , Functional language , Axiomatic semantics , Probability framing , Call-by-value , Randomized algorithms , Monadic interpretation
Journal title :
Science of Computer Programming
Serial Year :
2009
Journal title :
Science of Computer Programming
Record number :
1080076
Link To Document :
بازگشت