main page
modules
namespaces
classes
files
Gecode home
Generated on Tue Jan 28 2020 00:00:00 for Gecode by
doxygen
1.8.17
test
float
channel.cpp
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, 2006
9
* Vincent Barichard, 2012
10
*
11
* Last modified:
12
* $Date: 2016-06-27 20:51:18 +0200 (Mon, 27 Jun 2016) $ by $Author: schulte $
13
* $Revision: 15132 $
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
#include "
test/float.hh
"
41
42
#include <
gecode/minimodel.hh
>
43
44
namespace
Test
{
namespace
Float {
45
47
namespace
Channel {
48
50
class
Int
:
public
Test
{
51
public
:
53
Int
(
Gecode::FloatNum
st)
54
:
Test
(
"Channel::Int"
,2,-1,2,st,
CPLT_ASSIGNMENT
,false) {}
56
virtual
MaybeType
solution
(
const
Assignment
&
x
)
const
{
57
Gecode::FloatNum
tmp;
58
return
(((modf(
x
[0].
min
(),&tmp)==0) ||
59
(modf(
x
[0].
max
(),&tmp)==0))
60
&& (
x
[0]==
x
[1])) ?
MT_TRUE
:
MT_FALSE
;
61
}
63
virtual
void
post
(
Gecode::Space
& home,
Gecode::FloatVarArray
&
x
) {
64
using namespace
Gecode
;
65
IntVar
iv(home,-1000,1000);
66
channel
(home,
x
[0], iv);
67
channel
(home, iv,
x
[1]);
68
}
69
};
70
72
class
Bool
:
public
Test
{
73
public
:
75
Bool
(
Gecode::FloatNum
st)
76
:
Test
(
"Channel::Bool"
,2,0,1,st,
CPLT_ASSIGNMENT
,false) {}
78
virtual
MaybeType
solution
(
const
Assignment
&
x
)
const
{
79
Gecode::FloatNum
tmp;
80
return
(((modf(
x
[0].
min
(),&tmp)==0) ||
81
(modf(
x
[0].
max
(),&tmp)==0))
82
&& (
x
[0]==
x
[1])) ?
MT_TRUE
:
MT_FALSE
;
83
}
85
virtual
void
post
(
Gecode::Space
& home,
Gecode::FloatVarArray
&
x
) {
86
using namespace
Gecode
;
87
BoolVar
bv(home,0,1);
88
channel
(home,
x
[0], bv);
89
channel
(home, bv,
x
[1]);
90
}
91
};
92
93
Gecode::FloatNum
step1
= 0.7;
94
Gecode::FloatNum
step2
= 0.1;
95
96
Int
ci
(
step1
);
97
Bool
cb
(
step2
);
99
100
}
101
}}
102
103
// STATISTICS: test-float
104
minimodel.hh
Test::Float::Channel::Bool
Test channel between float and Boolean
Definition:
channel.cpp:72
Test::Float::Channel::Bool::solution
virtual MaybeType solution(const Assignment &x) const
Check whether x is solution.
Definition:
channel.cpp:78
Test::Float::MT_FALSE
@ MT_FALSE
Definition:
float.hh:56
Test::Float::Channel::cb
Bool cb(step2)
Gecode::Float::Limits::min
const FloatNum min
Smallest allowed float value.
Definition:
float.hh:850
Gecode::Space
Computation spaces.
Definition:
core.hpp:1748
Test::Float::MT_TRUE
@ MT_TRUE
Definition:
float.hh:57
Gecode
Gecode toplevel namespace
float.hh
Test::Float::Channel::step2
Gecode::FloatNum step2
Definition:
channel.cpp:94
x
Node * x
Pointer to corresponding Boolean expression node.
Definition:
bool-expr.cpp:253
Test::Float::Channel::Int::solution
virtual MaybeType solution(const Assignment &x) const
Check whether x is solution.
Definition:
channel.cpp:56
Test::Float::Channel::ci
Int ci(step1)
Test::Float::Channel::step1
Gecode::FloatNum step1
Definition:
channel.cpp:93
Gecode::FloatNum
double FloatNum
Floating point number base type.
Definition:
float.hh:110
Gecode::BoolVar
Boolean integer variables.
Definition:
int.hh:494
Test::Float::CPLT_ASSIGNMENT
@ CPLT_ASSIGNMENT
Definition:
float.hh:66
Test::Float::Channel::Bool::post
virtual void post(Gecode::Space &home, Gecode::FloatVarArray &x)
Post constraint on x.
Definition:
channel.cpp:85
Gecode::IntVar
Integer variables.
Definition:
int.hh:353
Test::Float::Channel::Int
Test channel between float and integer
Definition:
channel.cpp:50
Test::Float::Channel::Int::post
virtual void post(Gecode::Space &home, Gecode::FloatVarArray &x)
Post constraint on x.
Definition:
channel.cpp:63
Test::Float::Channel::Bool::Bool
Bool(Gecode::FloatNum st)
Construct and register test.
Definition:
channel.cpp:75
Test::Float::MaybeType
MaybeType
Type for comparisons and solutions.
Definition:
float.hh:55
Gecode::FloatVarArray
Float variable array.
Definition:
float.hh:1031
Test::Float::Channel::Int::Int
Int(Gecode::FloatNum st)
Construct and register test.
Definition:
channel.cpp:53
Test
General test support.
Definition:
afc.cpp:43
Test::Float::Assignment
Base class for assignments
Definition:
float.hh:84
Gecode::Float::Limits::max
const FloatNum max
Largest allowed float value.
Definition:
float.hh:848
Gecode::channel
void channel(Home home, const SetVarArgs &x, const SetVarArgs &y)
Definition:
channel.cpp:76