Software Abstractions: Logic, Language, and Analysis

Front Cover
MIT Press, Feb 12, 2016 - Computers - 376 pages
0 Reviews

An approach to software design that introduces a fully automated analysis giving designers immediate feedback, now featuring the latest version of the Alloy language.

In Software Abstractions Daniel Jackson introduces an approach to software design that draws on traditional formal methods but exploits automated tools to find flaws as early as possible. This approach—which Jackson calls “lightweight formal methods” or “agile modeling”—takes from formal specification the idea of a precise and expressive notation based on a tiny core of simple and robust concepts but replaces conventional analysis based on theorem proving with a fully automated analysis that gives designers immediate feedback. Jackson has developed Alloy, a language that captures the essence of software abstractions simply and succinctly, using a minimal toolkit of mathematical notions. This revised edition updates the text, examples, and appendixes to be fully compatible with Alloy 4.

 

What people are saying - Write a review

We haven't found any reviews in the usual places.

Contents

Introduction
1
A Whirlwind Tour
5
Logic
33
Language
85
Analysis
141
Examples
171
Exercises
233
Alloy Language Reference
259
Kernel Semantics
295
Diagrammatic Notation
299
Alternative Approaches
301
References
337
Index
345
Copyright

Other editions - View all

Common terms and phrases

About the author (2016)

Daniel Jackson is Professor in the Department of Electrical Engineering and Computer Science and leads the Software Design Group at the Computer Science and Artificial Intelligence Lab at MIT.

Bibliographic information