Skip to product information
1 of 1
Regular price £42.98 GBP
Regular price £48.99 GBP Sale price £42.98 GBP
Sale Sold out
Free UK Shipping

Freshly Printed - allow 8 days lead

Constraint Handling Rules

The definitive reference on Constraint Handling Rules, from the creator of the language.

Thom Frühwirth (Author)

9780521877763, Cambridge University Press

Hardback, published 9 July 2009

320 pages, 55 exercises
25.3 x 17.8 x 2.2 cm, 0.71 kg

'The reference on Constraint Handling Rules, covering both theory and practice.' Professor Pascal Van Hentenryck, Brown University, Rhode Island

Constraint Handling Rules (CHR) is both a theoretical formalism based on logic and a practical programming language based on rules. This book, written by the creator of CHR, describes the theory of CHR and how to use it in practice. It is supported by a website containing teaching materials, online demos, and free downloads of the language. After a basic tutorial, the author describes in detail the CHR language and discusses guaranteed properties of CHR programs. The author then compares CHR with other formalisms and languages and illustrates how it can capture their essential features. Finally, larger programs are introduced and analyzed in detail. The book is ideal for graduate students and lecturers, and for more experienced programmers and researchers, who can use it for self-study. Exercises with selected solutions, and bibliographic remarks are included at the ends of chapters. The book is the definitive reference on the subject.

Preface
Part I. CHR Tutorial: 1. Getting started
2. My first CHR programs
Part II. The CHR Language: 3. Syntax and semantics
4. Properties of CHR
5. Program analysis
6. Rule-based and graph-based formalisms in CHR
Part III. CHR Programs and Applications: 7. My first CHR programs, revisited for analysis
8. Finite domain constraint solvers
9. Infinite domain constraint solvers
10. Union-find algorithm
Bibliography
List of figures
List of illustrations
Index.

Subject Areas: Artificial intelligence [UYQ], Mathematical theory of computation [UYA], Computer programming / software development [UM]

View full details