Show simple item record

Files in this item

Item metadata

dc.contributor.authorCaldwell, James Lynn
dc.contributor.authorGent, Ian Philip
dc.contributor.authorNightingale, Peter William
dc.date.accessioned2017-09-14T16:30:07Z
dc.date.available2017-09-14T16:30:07Z
dc.date.issued2017-08-31
dc.identifier.citationCaldwell , J L , Gent , I P & Nightingale , P W 2017 , ' Generalized support and formal development of constraint propagators ' AI Communications , vol 30 , no. 5 , pp. 325-346 . DOI: 10.3233/AIC-170740en
dc.identifier.issn0921-7126
dc.identifier.otherPURE: 250936574
dc.identifier.otherPURE UUID: c3de66dd-646d-450f-8d40-d58596d798fe
dc.identifier.otherScopus: 85028711089
dc.identifier.urihttp://hdl.handle.net/10023/11664
dc.descriptionThe work of the authors has been partially supported by the following UK EPSRC grants: EP/E030394/1, EP/F031114/1, EP/H004092/1, and EP/M003728/1.en
dc.description.abstractConstraint 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 make use of support in the form of a single domain value. GAC algorithms such as GAC-Schema 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 for efficiency. Finally, three case studies of deriving efficient algorithms are given.en
dc.language.isoeng
dc.relation.ispartofAI Communicationsen
dc.rights© 2017 the Authors. This work has been made available online in accordance with the publisher’s policies. This is the author created accepted version manuscript following peer review and as such may differ slightly from the final published version. The final published version of this work is available at: https://doi.org/10.3233/AIC-170740en
dc.subjectConstraint satisfaction problemen
dc.subjectConstraint programmingen
dc.subjectFormal methodsen
dc.subjectQA75 Electronic computers. Computer scienceen
dc.subjectT-NDASen
dc.subject.lccQA75en
dc.titleGeneralized support and formal development of constraint propagatorsen
dc.typeJournal articleen
dc.description.versionPostprinten
dc.contributor.institutionUniversity of St Andrews. School of Computer Scienceen
dc.contributor.institutionUniversity of St Andrews. Centre for Interdisciplinary Research in Computational Algebraen
dc.identifier.doihttps://doi.org/10.3233/AIC-170740
dc.description.statusPeer revieweden


The following license files are associated with this item:

This item appears in the following Collection(s)

Show simple item record