Getting Formal Verification into Design Flow

  • Authors:
  • Arvind;Nirav Dave;Michael Katelman

  • Affiliations:
  • Computer Science and Artificial Intelligence Lab, Massachusetts Institute of Technology, Cambridge, USA MA 02139;Computer Science and Artificial Intelligence Lab, Massachusetts Institute of Technology, Cambridge, USA MA 02139;Department of Computer Science, University of Illinois at Urbana-Champaign, Urbana, USA IL 61801

  • Venue:
  • FM '08 Proceedings of the 15th international symposium on Formal Methods
  • Year:
  • 2008

Quantified Score

Hi-index 0.00

Visualization

Abstract

The ultimate goal of formal methods is to provide assurances about the quality, performance, security, etc. of systems. While formal tools have advanced greatly over the past two decades, widespread proliferation has not yet occurred, and the full impact of formal methods is still to be realized. This paper presents some ideas on how to catalyze the growth of formal techniques in day-to-day engineering practice. We draw on our experience as hardware engineers that want to use, and have tried to use, formal methods in our own designs. The points we make have probably been made before. However we illustrate each one with concrete designs. Our examples support three major themes: (1) correctness depends highly on the application and even a collection of formal methods cannot handle the whole problem; (2) high-level design languages can facilitate the interaction between design and formal methods; and (3) formal method tools should be presented as integrated debugging aids as opposed to one requiring mastering a foreign language or esoteric concepts.