g2o
Main Page
Modules
Namespaces
Classes
Files
File List
File Members
g2o
types
data
robot_laser.h
Go to the documentation of this file.
1
// g2o - General Graph Optimization
2
// Copyright (C) 2011 R. Kuemmerle, G. Grisetti, W. Burgard
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
7
// met:
8
//
9
// * Redistributions of source code must retain the above copyright notice,
10
// this list of conditions and the following disclaimer.
11
// * Redistributions in binary form must reproduce the above copyright
12
// notice, this list of conditions and the following disclaimer in the
13
// documentation and/or other materials provided with the distribution.
14
//
15
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
16
// IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
17
// TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
18
// PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19
// HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
21
// TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
22
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
23
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
24
// 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
#ifndef G2O_ROBOT_LASER_H
28
#define G2O_ROBOT_LASER_H
29
30
#include "
raw_laser.h
"
31
#include "
g2o_types_data_api.h
"
32
#include "
g2o/core/hyper_graph_action.h
"
33
34
namespace
g2o
{
35
42
class
G2O_TYPES_DATA_API
RobotLaser
:
public
RawLaser
43
{
44
public
:
45
EIGEN_MAKE_ALIGNED_OPERATOR_NEW
;
46
RobotLaser
();
47
~
RobotLaser
();
48
49
virtual
bool
write(std::ostream& os)
const
;
50
virtual
bool
read(std::istream& is);
51
52
SE2
laserPose
()
const
{
return
_odomPose * _laserParams.laserPose;}
53
const
SE2
&
odomPose
()
const
{
return
_odomPose;}
54
void
setOdomPose(
const
SE2
& odomPose);
55
56
protected
:
57
SE2
_odomPose
;
59
double
_laserTv, _laserRv, _forwardSafetyDist, _sideSaftyDist,
_turnAxis
;
60
};
61
62
#ifdef G2O_HAVE_OPENGL
63
class
G2O_TYPES_DATA_API
RobotLaserDrawAction:
public
DrawAction
{
64
public
:
65
RobotLaserDrawAction();
66
virtual
HyperGraphElementAction
* operator()(
HyperGraph::HyperGraphElement
* element,
67
HyperGraphElementAction::Parameters
* params_ );
68
protected
:
69
virtual
bool
refreshPropertyPtrs(
HyperGraphElementAction::Parameters
* params_);
70
IntProperty
* _beamsDownsampling;
71
FloatProperty
* _pointSize;
72
FloatProperty
* _maxRange;
73
};
74
#endif
75
76
}
77
78
#endif
g2o::RobotLaser::odomPose
const SE2 & odomPose() const
Definition:
robot_laser.h:53
G2O_TYPES_DATA_API
#define G2O_TYPES_DATA_API
Definition:
g2o_types_data_api.h:29
g2o::HyperGraphElementAction
Abstract action that operates on a graph entity.
Definition:
hyper_graph_action.h:74
g2o::DrawAction
draw actions
Definition:
hyper_graph_action.h:180
raw_laser.h
g2o::RobotLaser
laser measurement obtained by a robot
Definition:
robot_laser.h:42
g2o::SE2
represent SE2
Definition:
se2.h:40
g2o::Property< int >
g2o::RobotLaser::laserPose
SE2 laserPose() const
Definition:
robot_laser.h:52
g2o::HyperGraphElementAction::Parameters
Definition:
hyper_graph_action.h:76
g2o::RobotLaser::_odomPose
SE2 _odomPose
Definition:
robot_laser.h:57
g2o_types_data_api.h
g2o
Definition:
dl_wrapper.cpp:54
hyper_graph_action.h
g2o::RobotLaser::_turnAxis
double _turnAxis
Definition:
robot_laser.h:59
g2o::HyperGraph::HyperGraphElement
Definition:
hyper_graph.h:84
g2o::RobotLaser::EIGEN_MAKE_ALIGNED_OPERATOR_NEW
EIGEN_MAKE_ALIGNED_OPERATOR_NEW
Definition:
robot_laser.h:45
g2o::RawLaser
Raw laser measuerement.
Definition:
raw_laser.h:46
Generated on Mon Mar 18 2019 20:14:39 for g2o by
1.8.11