libSBNW
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Macros
Modules
Pages
graphfab
math
allen.h
Go to the documentation of this file.
1
/*== SAGITTARIUS =====================================================================
2
* Copyright (c) 2012, Jesse K Medley
3
* All rights reserved.
4
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are met:
7
* Redistributions of source code must retain the above copyright
8
notice, this list of conditions and the following disclaimer.
9
* Redistributions in binary form must reproduce the above copyright
10
notice, this list of conditions and the following disclaimer in the
11
documentation and/or other materials provided with the distribution.
12
* Neither the name of The University of Washington nor the
13
names of its contributors may be used to endorse or promote products
14
derived from this software without specific prior written permission.
15
16
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
17
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE
20
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
*/
27
28
//== FILEDOC =========================================================================
29
34
//== BEGINNING OF CODE ===============================================================
35
36
#ifndef __SBNW_ALLEN_H_
37
#define __SBNW_ALLEN_H_
38
39
//== INCLUDES ========================================================================
40
41
#include "
graphfab/core/SagittariusCore.h
"
42
#include "
graphfab/math/min_max.h
"
43
44
//-- C++ code --
45
#ifdef __cplusplus
46
47
namespace
Graphfab
{
48
49
class
Interval {
50
public
:
52
Interval(
const
Real
a,
const
Real
b) {
53
if
(a <= b) {
54
_a = a;
55
_b = b;
56
}
else
{
57
_a = b;
58
_b = a;
59
}
60
}
61
63
Real
a()
const
{
return
_a; }
64
66
Real
& a() {
return
_a; }
67
68
Real
b()
const
{
return
_b; }
69
70
Real
& b() {
return
_b; }
71
private
:
73
Real
_a, _b;
74
};
75
77
inline
Real
allenDist(
const
Real
u,
const
Real
v,
const
Real
x,
const
Real
y) {
78
if
(!(v < x || y < u))
79
//intersect
80
return
0.;
81
Real
a = x-v, b=u-y;
//one will be negative
82
return
max(a,b);
83
}
84
86
inline
Real
allenOrdered(
const
Real
u,
const
Real
v,
const
Real
x,
const
Real
y) {
87
// think of it like the result of b-a, where b and a are intervals
88
if
(!(v < x || y < u))
89
//intersect
90
return
0.;
91
if
(v < x)
92
return
x-v;
//positive
93
else
94
return
y-u;
//negative
95
}
96
98
inline
bool
pointInInterval(
const
Real
p,
const
Interval& i) {
99
return
(i.a() <= p && p <= i.b()) ?
true
:
false
;
100
}
101
102
}
103
104
#endif
105
106
#endif
Real
SAGITTARIUS_REAL Real
Make Real visible to C. Consider letting Real lie in top namespace.
Definition:
SagittariusCommon.h:136
Graphfab
Definition:
SagittariusCommon.cpp:38
min_max.h
Min & max for reals.
SagittariusCore.h
First file included.
Generated on Thu Sep 29 2016 10:51:55 for libSBNW by
1.8.7