Searching for just a few words should be enough to get started. If you need to make more complex queries, use the tips below to guide you.
Article type: Research Article
Authors: Caldwell, Jamesa | Gent, Ian P.b | Nightingale, Peterb
Affiliations: [a] Department of Computer Science, University of Wyoming, 1000 E. University Ave., Laramie, WY 82071-3315, USA. E-mail: jlc@cs.uwyo.edu | [b] School of Computer Science, University of St Andrews, St Andrews, Fife KY16 9SX, UK. E-mails: ian.gent@st-andrews.ac.uk, pwn1@st-andrews.ac.uk
Abstract: Constraint programming is a family of techniques for solving combinatorial problems, where the problem is modelled as a set of decision variables (typically with finite domains) and a set of constraints that express relations among the decision variables. One key concept in constraint programming is propagation: reasoning on a constraint or set of constraints to derive new facts, typically to remove values from the domains of decision variables. Specialized propagation algorithms (propagators) exist for many classes of constraints. The concept of support is pervasive in the design of propagators. Traditionally, when a domain value ceases to have support, it may be removed because it takes part in no solutions. Arc-consistency algorithms such as AC2001 [in: Proceedings 17th International Joint Conference on Artificial Intelligence (IJCAI 2001), 2001, pp. 309–315] make use of support in the form of a single domain value. GAC algorithms such as GAC-Schema [in: Proceedings 15th International Joint Conference on Artificial Intelligence (IJCAI 97), 1997, pp. 398–404] use a tuple of values to support each literal. We generalize these notions of support in two ways. First, we allow a set of tuples to act as support. Second, the supported object is generalized from a set of literals (GAC-Schema) to an entire constraint or any part of it. We design a methodology for developing correct propagators using generalized support. A constraint is expressed as a family of support properties, which may be proven correct against the formal semantics of the constraint. We show how to derive correct propagators from the constructive proofs of the support properties. The framework is carefully designed to allow efficient algorithms to be produced. Derived algorithms may make use of dynamic literal triggers or watched literals [in: Proc. 12th International Conference on the Principles and Practice of Constraint Programming (CP 2006), 2006, pp. 182–197] for efficiency. Finally, three case studies of deriving efficient algorithms are given.
Keywords: Constraint satisfaction problem, constraint programming, formal methods
DOI: 10.3233/AIC-170740
Journal: AI Communications, vol. 30, no. 5, pp. 325-346, 2017
IOS Press, Inc.
6751 Tepper Drive
Clifton, VA 20124
USA
Tel: +1 703 830 6300
Fax: +1 703 830 2300
sales@iospress.com
For editorial issues, like the status of your submitted paper or proposals, write to editorial@iospress.nl
IOS Press
Nieuwe Hemweg 6B
1013 BG Amsterdam
The Netherlands
Tel: +31 20 688 3355
Fax: +31 20 687 0091
info@iospress.nl
For editorial issues, permissions, book requests, submissions and proceedings, contact the Amsterdam office info@iospress.nl
Inspirees International (China Office)
Ciyunsi Beili 207(CapitaLand), Bld 1, 7-901
100025, Beijing
China
Free service line: 400 661 8717
Fax: +86 10 8446 7947
china@iospress.cn
For editorial issues, like the status of your submitted paper or proposals, write to editorial@iospress.nl
如果您在出版方面需要帮助或有任何建, 件至: editorial@iospress.nl