Generated on Thu Jan 16 2025 00:00:00 for Gecode by doxygen 1.14.0
set-rel.hpp
Go to the documentation of this file.
1/* -*- mode: C++; c-basic-offset: 2; indent-tabs-mode: nil -*- */
2/*
3 * Main authors:
4 * Christian Schulte <schulte@gecode.org>
5 *
6 * Copyright:
7 * Christian Schulte, 2005
8 *
9 * This file is part of Gecode, the generic constraint
10 * development environment:
11 * http://www.gecode.org
12 *
13 * Permission is hereby granted, free of charge, to any person obtaining
14 * a copy of this software and associated documentation files (the
15 * "Software"), to deal in the Software without restriction, including
16 * without limitation the rights to use, copy, modify, merge, publish,
17 * distribute, sublicense, and/or sell copies of the Software, and to
18 * permit persons to whom the Software is furnished to do so, subject to
19 * the following conditions:
20 *
21 * The above copyright notice and this permission notice shall be
22 * included in all copies or substantial portions of the Software.
23 *
24 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
28 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
29 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
30 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
31 *
32 */
33
34#ifdef GECODE_HAS_SET_VARS
35
36namespace Gecode {
37
38 /*
39 * Operations for set relations
40 *
41 */
43 SetCmpRel::SetCmpRel(const SetExpr& l0, SetRelType srt0, const SetExpr& r0)
44 : l(l0), r(r0), srt(srt0) {}
45
48
50 SetRel::SetRel(const SetExpr& e0, SetRelType srt, const SetExpr& e1)
51 : _e0(e0), _srt(srt), _e1(e1) {}
52
55 : _e0(r.l), _srt(r.srt), _e1(r.r) {}
56
57 forceinline void
58 SetRel::post(Home home, bool t) const {
59 if (t)
60 _e0.post(home,_srt,_e1);
61 else if (_srt == SRT_EQ)
62 _e0.post(home,SRT_NQ,_e1);
63 else if (_srt == SRT_NQ)
64 _e0.post(home,SRT_EQ,_e1);
65 else {
66 BoolVar b(home,0,0);
67 _e0.post(home,b,true,_srt,_e1);
68 }
69 }
70
71 forceinline void
72 SetRel::post(Home home, BoolVar b, bool t) const {
73 _e0.post(home,b,t,_srt,_e1);
74 }
75
76}
77
78#endif
79
80// STATISTICS: minimodel-any
Boolean integer variables.
Definition int.hh:515
Home class for posting propagators
Definition core.hpp:856
Comparison relation (for two-sided comparisons)
SetRelType srt
Which relation.
SetExpr l
Left side of relation.
SetExpr r
Right side of relation.
SetCmpRel(const SetExpr &l, SetRelType srt, const SetExpr &r)
Constructor.
Definition set-rel.hpp:43
Set expressions
void post(Home home, bool t) const
Post propagators for relation (or negated relation if t is false)
Definition set-rel.hpp:58
SetRel(void)
Default constructor.
Definition set-rel.hpp:47
SetRelType
Common relation types for sets.
Definition set.hh:649
@ SRT_NQ
Disequality ( )
Definition set.hh:651
@ SRT_EQ
Equality ( )
Definition set.hh:650
Gecode toplevel namespace
Post propagator for SetVar SetOpType SetVar SetRelType r
Definition set.hh:773
#define forceinline
Definition config.hpp:194