Towards accessible integrated formal reasoning environments for protocol design

Computer science researchers in the programming languages and formal verification communities have produced a variety of automated tools and techniques for assisting formal reasoning tasks. However, while there exist notable successes in utilizing these tools to develop safe and secure software and hardware, both leading-edge advances and basic techniques (such as model checking, state space search, type checking, logical inference and verification, computation of congruence closures, non-interference enforcement, and so on) remain underutilized by large populations of end-users that may benefit from them when they engage in formal reasoning tasks within their own application domains. This may be in part because (1) these tools and techniques are not readily accessible to endusers who are not experts in formal systems or are simply not aware of what is available and how it can be utilized, and (2) these tools and techniques are only valuable when used in conjunction with one another and with appropriate domain-specific libraries and databases. Motivated by these circumstances, we present our ongoing efforts, built on earlier work in developing user-friendly formal verification tools, to develop a platform for assembling, instantiating, and deploying user-friendly, interactive, integrated formal reasoning environments that can assist users engaged in routine domain-specific formal reasoning tasks in application domains. This infrastructure encompasses a programming language, compilers, and other tools for building up from components, instantiating with domain-specific formal content, and finally delivering such environments in the form of ready-to-use web-based applications that can run entirely within a standard web browser. We describe current efforts to use this platform to instantiate an environment the application domain of correct network protocol design.

[1]  Rod M. Burstall ProveEasy: helping people learn to do proofs , 2000, Electron. Notes Theor. Comput. Sci..

[2]  Josef Urban,et al.  Integrated Semantic Browsing of the Mizar Mathematical Library for Authoring Mizar Articles , 2004, MKM.

[3]  Neil Mitchell Hoogle Overview , 2008 .

[4]  Cezary Kaliszyk,et al.  Web Interfaces for Proof Assistants , 2007, UITP@FLoC.

[5]  Shin Nakajima,et al.  The SPIN Model Checker : Primer and Reference Manual , 2004 .

[6]  Paul A. Cairns,et al.  Integrating Searching and Authoring in Mizar , 2007, Journal of Automated Reasoning.

[7]  Natarajan Shankar,et al.  The SAL Language Manual , 2003 .

[8]  Fairouz Kamareddine,et al.  Computerizing Mathematical Text with MathLang , 2008, LSFA.

[9]  Markus Wenzel,et al.  Isabelle, Isar - a versatile environment for human readable formal proof documents , 2002 .

[10]  Marta Z. Kwiatkowska,et al.  PRISM 4.0: Verification of Probabilistic Real-Time Systems , 2011, CAV.

[11]  Rob Miller,et al.  Code Completion from Abbreviated Input , 2009, 2009 IEEE/ACM International Conference on Automated Software Engineering.

[12]  Assaf J. Kfoury,et al.  A User-friendly Interface for a Lightweight Verification System , 2012, Electron. Notes Theor. Comput. Sci..

[13]  John Matthews,et al.  Pragmatic equivalence and safety checking in Cryptol , 2009, PLPV '09.

[14]  Alan Bundy,et al.  Constructing Induction Rules for Deductive Synthesis Proofs , 2006, CLASE.

[15]  Daniel Jackson,et al.  Software Abstractions - Logic, Language, and Analysis , 2006 .

[16]  Jörg H. Siekmann,et al.  Proof Development with Omega-MEGA: sqrt(2) Is Irrational , 2002, LPAR.

[17]  Piotr Rudnicki,et al.  An Overview of the MIZAR Project , 1992 .

[18]  Daniel Jackson,et al.  Alloy: a lightweight object modelling notation , 2002, TSEM.

[19]  Andrea Asperti,et al.  User Interaction with the Matita Proof Assistant , 2007, Journal of Automated Reasoning.

[20]  Andrei Lapets User-friendly Support for Common Concepts in a Lightweight Verifier , 2010 .

[21]  Chad E. Brown,et al.  Verifying and Invalidating Textbook Proofs Using Scunak , 2006, MKM.

[22]  Azer Bestavros,et al.  Formal Verification of SLA Transformations , 2011, 2011 IEEE World Congress on Services.

[23]  Bor-Yuh Evan Chang,et al.  Human-Readable Machine-Verifiable Proofs for Teaching Constructive Logic , 2001 .

[24]  Rob Miller,et al.  Keyword programming in java , 2007, ASE '07.

[25]  Victor Luchangco,et al.  The Fortress Language Specification Version 1.0 , 2007 .

[26]  Aarne Ranta,et al.  An Extensible Proof Text Editor , 2000, LPAR.