main page
modules
namespaces
classes
files
Gecode home
Generated on Sat Nov 9 2013 19:18:26 for Gecode by
doxygen
1.8.4
gecode
float
view
float.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
* Vincent Barichard <Vincent.Barichard@univ-angers.fr>
6
*
7
* Copyright:
8
* Christian Schulte, 2002
9
* Vincent Barichard, 2012
10
*
11
* Last modified:
12
* $Date: 2012-04-06 13:04:47 +0200 (Fri, 06 Apr 2012) $ by $Author: schulte $
13
* $Revision: 12711 $
14
*
15
* This file is part of Gecode, the generic constraint
16
* development environment:
17
* http://www.gecode.org
18
*
19
* Permission is hereby granted, free of charge, to any person obtaining
20
* a copy of this software and associated documentation files (the
21
* "Software"), to deal in the Software without restriction, including
22
* without limitation the rights to use, copy, modify, merge, publish,
23
* distribute, sublicense, and/or sell copies of the Software, and to
24
* permit persons to whom the Software is furnished to do so, subject to
25
* the following conditions:
26
*
27
* The above copyright notice and this permission notice shall be
28
* included in all copies or substantial portions of the Software.
29
*
30
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
31
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
32
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
33
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
34
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
35
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
36
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
37
*
38
*/
39
40
namespace
Gecode {
namespace
Float {
41
42
/*
43
* Constructors and initialization
44
*
45
*/
46
forceinline
47
FloatView::FloatView
(
void
) {}
48
forceinline
49
FloatView::FloatView
(
const
FloatVar
& y)
50
:
VarImpView
<
FloatVar
>(y.varimp()) {}
51
forceinline
52
FloatView::FloatView
(
FloatVarImp
* y)
53
:
VarImpView
<
FloatVar
>(y) {}
54
55
/*
56
* Value access
57
*
58
*/
59
forceinline
FloatVal
60
FloatView::domain
(
void
)
const
{
61
return
x
->
domain
();
62
}
63
forceinline
FloatNum
64
FloatView::min
(
void
)
const
{
65
return
x
->
min
();
66
}
67
forceinline
FloatNum
68
FloatView::max
(
void
)
const
{
69
return
x
->
max
();
70
}
71
forceinline
FloatNum
72
FloatView::med
(
void
)
const
{
73
return
x
->
med
();
74
}
75
forceinline
FloatVal
76
FloatView::val
(
void
)
const
{
77
return
x
->
val
();
78
}
79
80
forceinline
FloatNum
81
FloatView::size
(
void
)
const
{
82
return
x
->
size
();
83
}
84
85
86
/*
87
* Domain tests
88
*
89
*/
90
forceinline
bool
91
FloatView::zero_in
(
void
)
const
{
92
return
x
->
zero_in
();
93
}
94
forceinline
bool
95
FloatView::in
(
FloatNum
n
)
const
{
96
return
x
->
in
(n);
97
}
98
forceinline
bool
99
FloatView::in
(
const
FloatVal
&
n
)
const
{
100
return
x
->
in
(n);
101
}
102
103
104
/*
105
* Domain update by value
106
*
107
*/
108
forceinline
ModEvent
109
FloatView::lq
(
Space
& home,
int
n
) {
110
return
x
->
lq
(home,n);
111
}
112
forceinline
ModEvent
113
FloatView::lq
(
Space
& home,
FloatNum
n
) {
114
return
x
->
lq
(home,n);
115
}
116
forceinline
ModEvent
117
FloatView::lq
(
Space
& home,
FloatVal
n
) {
118
return
x
->
lq
(home,n);
119
}
120
121
forceinline
ModEvent
122
FloatView::gq
(
Space
& home,
int
n
) {
123
return
x
->
gq
(home,n);
124
}
125
forceinline
ModEvent
126
FloatView::gq
(
Space
& home,
FloatNum
n
) {
127
return
x
->
gq
(home,n);
128
}
129
forceinline
ModEvent
130
FloatView::gq
(
Space
& home,
FloatVal
n
) {
131
return
x
->
gq
(home,n);
132
}
133
134
forceinline
ModEvent
135
FloatView::eq
(
Space
& home,
int
n
) {
136
return
x
->
eq
(home,n);
137
}
138
forceinline
ModEvent
139
FloatView::eq
(
Space
& home,
FloatNum
n
) {
140
return
x
->
eq
(home,n);
141
}
142
forceinline
ModEvent
143
FloatView::eq
(
Space
& home,
const
FloatVal
&
n
) {
144
return
x
->
eq
(home,n);
145
}
146
147
148
149
/*
150
* Delta information for advisors
151
*
152
*/
153
forceinline
FloatNum
154
FloatView::min
(
const
Delta
&
d
)
const
{
155
return
FloatVarImp::min
(d);
156
}
157
forceinline
FloatNum
158
FloatView::max
(
const
Delta
&
d
)
const
{
159
return
FloatVarImp::max
(d);
160
}
161
162
163
forceinline
ModEventDelta
164
FloatView::med
(
ModEvent
me) {
165
return
VarImpView<FloatVar>::med
(me);
166
}
167
168
}}
169
170
// STATISTICS: float-var
171