src
RobotStateObserver.cpp
Go to the documentation of this file.
1
/* Copyright (c) 2017, TU Wien
2
All rights reserved.
3
4
Redistribution and use in source and binary forms, with or without
5
modification, are permitted provided that the following conditions are met:
6
* Redistributions of source code must retain the above copyright
7
notice, this list of conditions and the following disclaimer.
8
* Redistributions in binary form must reproduce the above copyright
9
notice, this list of conditions and the following disclaimer in the
10
documentation and/or other materials provided with the distribution.
11
* Neither the name of the <organization> nor the
12
names of its contributors may be used to endorse or promote products
13
derived from this software without specific prior written permission.
14
15
THIS SOFTWARE IS PROVIDED BY TU Wien ''AS IS'' AND ANY
16
EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18
DISCLAIMED. IN NO EVENT SHALL TU Wien BE LIABLE FOR ANY
19
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25
*/
26
#include <
tuw_multi_robot_route_to_path/RobotStateObserver.h
>
27
28
#include <math.h>
29
#include <limits.h>
30
#include <
ros/ros.h
>
31
32
namespace
tuw_multi_robot_route_to_path
33
{
34
RobotStateObserver::RobotStateObserver
()
35
{
36
currentStep
= 0;
37
}
38
int
RobotStateObserver::init
(
const
std::vector<PathSegment> &_path)
39
{
40
currentStep
= 0;
41
path_
= _path;
42
43
return
currentStep
;
44
}
45
int
RobotStateObserver::getStep
(
const
Eigen::Vector2d &_odom,
bool
&_changed)
46
{
47
float
minDist = FLT_MAX;
48
bool
inSeg;
49
int
cstep =
currentStep
;
50
51
for
(
int
i =
currentStep
; i <
path_
.size(); i++)
52
{
53
float
d
=
distanceToSegment
(
path_
[i], _odom);
54
55
if
(
d
< minDist)
56
{
57
currentStep
= i;
58
minDist =
d
;
59
}
60
}
61
62
_changed = cstep !=
currentStep
;
63
64
return
currentStep
;
65
}
66
67
float
RobotStateObserver::distanceToSegment
(
PathSegment
_s, Eigen::Vector2d _p)
68
{
69
Eigen::Vector2d n = _s.
goal
- _s.
start
;
70
Eigen::Vector2d pa = _s.
start
- _p;
71
72
float
c = n.dot(pa);
73
74
// Closest point is a
75
if
(c > 0.0
f
)
76
return
pa.dot(pa);
77
78
Eigen::Vector2d bp = _p - _s.
goal
;
79
80
// Closest point is b
81
if
(n.dot(bp) > 0.0f)
82
return
bp.dot(bp);
83
84
// Closest point is between a and b
85
Eigen::Vector2d e = pa - n * (c / n.dot(n));
86
87
88
return
e.dot(e);
89
}
90
}
91
tuw_multi_robot_route_to_path::RobotStateObserver::init
int init(const std::vector< PathSegment > &_path)
Definition:
RobotStateObserver.cpp:38
tuw_multi_robot_route_to_path::PathSegment
Definition:
RobotStateObserver.h:37
ros.h
tuw_multi_robot_route_to_path::PathSegment::start
Eigen::Vector2d start
Definition:
RobotStateObserver.h:39
tuw_multi_robot_route_to_path::RobotStateObserver::currentStep
int currentStep
Definition:
RobotStateObserver.h:54
tuw_multi_robot_route_to_path::PathSegment::goal
Eigen::Vector2d goal
Definition:
RobotStateObserver.h:40
f
f
tuw_multi_robot_route_to_path::RobotStateObserver::getStep
int getStep(const Eigen::Vector2d &_odom, bool &_changed)
Definition:
RobotStateObserver.cpp:45
d
d
tuw_multi_robot_route_to_path::RobotStateObserver::RobotStateObserver
RobotStateObserver()
Definition:
RobotStateObserver.cpp:34
tuw_multi_robot_route_to_path::RobotStateObserver::distanceToSegment
float distanceToSegment(PathSegment _s, Eigen::Vector2d _p)
Definition:
RobotStateObserver.cpp:67
tuw_multi_robot_route_to_path
Definition:
LocalBehaviorControllerNode.h:46
tuw_multi_robot_route_to_path::RobotStateObserver::path_
std::vector< PathSegment > path_
Definition:
RobotStateObserver.h:53
RobotStateObserver.h
tuw_multi_robot_local_behavior_controller
Author(s): Benjamin Binder
autogenerated on Wed Mar 2 2022 01:10:04