A Complementary Approach to Incorrectness Typing
By: Celia Mengyue Li, Sophie Pull, Steven Ramsay
Potential Business Impact:
Finds mistakes in computer programs automatically.
We introduce a new two-sided type system for verifying the correctness and incorrectness of functional programs with atoms and pattern matching. A key idea in the work is that types should range over sets of normal forms, rather than sets of values, and this allows us to define a complement operator on types that acts as a negation on typing formulas. We show that the complement allows us to derive a wide range of refutation principles within the system, including the type-theoretic analogue of co-implication, and we use them to certify that a number of Erlang-like programs go wrong. An expressive axiomatisation of the complement operator via subtyping is shown decidable, and the type system as a whole is shown to be not only sound, but also complete for normal forms.
Similar Papers
A Complementary Approach to Incorrectness Typing
Programming Languages
Finds errors in computer programs automatically.
Type-Based Incorrectness Reasoning
Programming Languages
Finds bugs in computer programs automatically.
From Traces to Program Incorrectness: A Type-Theoretic Approach
Programming Languages
Finds bugs in computer programs by watching how they work.