Login

Coherent Reaction

Show full item record




Title: Coherent Reaction
Author: Edwards, Jonathan
Other Contributors: Software Design
Advisor: Daniel Jackson
Issue Date: 2009-06-12
Abstract: Side effects are both the essence and bane of imperative programming. The programmer must carefully coordinate actions to manage their side effects upon each other. Such coordination is complex, error-prone, and fragile. Coherent reaction is a new model of change-driven computation that coordinates effects automatically. State changes trigger events called reactions that in turn change other states. A coherent execution order is one in which each reaction executes before any others that are affected by its changes. A coherent order is discovered iteratively by detecting incoherencies as they occur and backtracking their effects. Unlike alternative solutions, much of the power of imperative programming is retained, as is the common sense notion of mutable state. Automatically coordinating actions lets the programmer express what to do, not when to do it. Coherent reactions are embodied in the Coherence language, which is specialized for interactive applications like those common on the desktop and web. The fundamental building block of Coherence is the dynamically typed mutable tree. The fundamental abstraction mechanism is the virtual tree, whose value is lazily computed, and whose behavior is generated by coherent reactions.
URI: http://hdl.handle.net/1721.1/45563
Series/Report no.: MIT-CSAIL-TR-2009-024
Keywords: reactive systems, synchronous reactive programming, interactive systems, functional reactive programming, bidirectional functions

Files in this item

Files Size Format View
MIT-CSAIL-TR-2009-024.pdf 352.3Kb PDF View/Open
MIT-CSAIL-TR-2009-024.ps 1.315Mb Postscript View/Open

The following license files are associated with this item:

This item appears in the following Collection(s)

Show full item record

Creative Commons Attribution 3.0 Unported Except where otherwise noted, this item's license is described as Creative Commons Attribution 3.0 Unported

Search DSpace@MIT


Advanced Search

Browse

My Account

Links