Knowledge-Based Synthesis of Distributed Systems Using Event Structures
- unofficial copies PDF, PS
- Cornell Tech Report http://hdl.handle.net/1813/5639
- Also in the Logic for Programming, Artificial Intelligence, and Reasoning Lecture Notes in Computer Science, Volume 3452, 2005, pp 449-465. Link
To produce a program guaranteed to satisfy a given specification one can synthesize it from a formal constructive proof that a computation satisfying that specification exists. This process is particularly effective if the specifications are written in a high-level language that makes it easy for designers to specify their goals. We consider a high-level specification language that results from adding knowledge to a fragment of Nuprl specifically tailored for specifying distributed protocols, called event theory. We then show how high-level knowledge-based programs can be synthesized from the knowledge-based specifications using a proof development system such as Nuprl. Methods of Halpern and Zuck  then apply to convert these knowledge-based protocols to ordinary protocols. These methods can be expressed as heuristic transformation tactics in Nuprl.