SE Seminar: Emina Torlak, University of California, Berkeley

*********************************
There is now a CONTENT FREEZE for Mercury while we switch to a new platform. It began on Friday, March 10 at 6pm and will end on Wednesday, March 15 at noon. No new content can be created during this time, but all material in the system as of the beginning of the freeze will be migrated to the new platform, including users and groups. Functionally the new site is identical to the old one. webteam@gatech.edu
*********************************

Event Details
  • Date/Time:
    • Monday November 19, 2012 - Tuesday November 20, 2012
      11:00 am - 10:59 am
  • Location: Klaus 1116E
  • Phone:
  • URL:
  • Email:
  • Fee(s):
    N/A
  • Extras:
Contact

ndongi@cc.gatech.edu

 

Summaries

Summary Sentence: Programming with Constraint Solvers: Toward a Shared Infrastructure for Code Checking, Angelic Execution, Debugging, and Synthesis

Full Summary: No summary paragraph submitted.

Title: Programming with Constraint Solvers:  Toward a Shared Infrastructure for Code Code Checking, Angelic Execution, Debugging, and Synthesis

Abstract:

Decision procedures have helped automate key aspects of programming: coming up with a code fragment that implements a desired behavior (synthesis); establishing that an implementation satisfies a desired property (code checking); locating code fragments that cause an undesirable behavior (debugging); and running a partially implemented program to test its existing behaviors (angelic execution).  Each of these aspects is supported, at least in part, by a family of formal tools.  Most such tools are built on infrastructures that are tailored for a particular purpose, e.g., Boogie for verification and Sketch for synthesis.  But so far, no single infrastructure provides a platform for automating the full spectrum of programming activities, making it hard to share advances (in encodings, abstractions, and domain-specific optimizations) across different families of tools.

 This talk outlines a path toward a shared infrastructure for computer-aided programming, drawing lessons from a decade of collective experience in using relational constraint solvers to design and analyze software.  We start with a relational view of the heap pioneered in the early work on the Alloy language and Analyzer.  We then derive an encoding of programs in the bounded relational logic of Kodkod, which extends Alloy with support for partial models.  Next, we show by example how to use such an encoding to build a program checker, an angelic oracle, an automated debugger, and a template-based synthesis tool.  We conclude by discussing some of the challenges involved in lifting the low-level commonalities between these systems into an efficient infrastructure for prototyping and embedding of programming tools.

 Bio: Emina Torlak is a computer scientist at U.C. Berkeley.  She received her Ph.D. (2009), M.Eng. (2004) and B.Sc. (2003) in Computer Science from MIT.  Emina is interested in improving software design and development through automation.   She has developed a variety of tools for helping programmers with lightweight formal reasoning, code and memory model analysis, debugging, and testing.  Her current projects focus on software synthesis for high performance computing.

 

Additional Information

In Campus Calendar
No
Groups

College of Computing

Invited Audience
No audiences were selected.
Categories
Seminar/Lecture/Colloquium
Keywords
No keywords were submitted.
Status
  • Created By: Elizabeth Ndongi
  • Workflow Status: Published
  • Created On: Nov 14, 2012 - 4:06am
  • Last Updated: Oct 7, 2016 - 10:01pm