Date and Time:Monday 14 April 2008, 15:30 - 16:30
Speaker: Supratik Chakraborty (IIT Bombay)
Title: Automatically Refining Abstract Interpretations
Abstract:
Abstract interpretation techniques prove properties of programs by
computing abstract fixpoints. All such analyses suffer from the
possibility of false errors. We present three techniques to automatically
refine such abstract interpretations to reduce false errors:
- a new
operator called interpolated widen, which automatically recovers precision
lost due to widen,
- a new way to handle disjunctions that arise due to
refinement, and
- a new refinement algorithm, which refines abstract
interpretations that use the join operator to merge abstract states at
join points.
We have implemented our techniques in a tool Dagger. Our
experimental results show our techniques are effective and that their
combination is even more effective than any one of them in isolation.
We also show that Dagger is able to prove properties of C programs
that are beyond current abstraction-refinement tools, such as Slam,
Blast, Armc, and an earlier tool developed by us.
(joint work with Bhargav Gulavani, Sriram Rajamani, Aditya Nori)