include
dwb_plugins
velocity_iterator.h
Go to the documentation of this file.
1
/*
2
* Software License Agreement (BSD License)
3
*
4
* Copyright (c) 2017, Locus Robotics
5
* All rights reserved.
6
*
7
* Redistribution and use in source and binary forms, with or without
8
* modification, are permitted provided that the following conditions
9
* are met:
10
*
11
* * Redistributions of source code must retain the above copyright
12
* notice, this list of conditions and the following disclaimer.
13
* * Redistributions in binary form must reproduce the above
14
* copyright notice, this list of conditions and the following
15
* disclaimer in the documentation and/or other materials provided
16
* with the distribution.
17
* * Neither the name of the copyright holder nor the names of its
18
* contributors may be used to endorse or promote products derived
19
* from this software without specific prior written permission.
20
*
21
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25
* COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32
* POSSIBILITY OF SUCH DAMAGE.
33
*/
34
35
#ifndef DWB_PLUGINS_VELOCITY_ITERATOR_H
36
#define DWB_PLUGINS_VELOCITY_ITERATOR_H
37
38
#include <
ros/ros.h
>
39
#include <nav_2d_msgs/Twist2D.h>
40
#include <
dwb_plugins/kinematic_parameters.h
>
41
42
namespace
dwb_plugins
43
{
44
class
VelocityIterator
45
{
46
public
:
47
virtual
~VelocityIterator
() {}
48
virtual
void
initialize
(
ros::NodeHandle
& nh,
KinematicParameters::Ptr
kinematics) = 0;
49
virtual
void
startNewIteration
(
const
nav_2d_msgs::Twist2D& current_velocity,
double
dt) = 0;
50
virtual
bool
hasMoreTwists
() = 0;
51
virtual
nav_2d_msgs::Twist2D
nextTwist
() = 0;
52
};
53
}
// namespace dwb_plugins
54
55
#endif // DWB_PLUGINS_VELOCITY_ITERATOR_H
dwb_plugins::VelocityIterator::initialize
virtual void initialize(ros::NodeHandle &nh, KinematicParameters::Ptr kinematics)=0
dwb_plugins::VelocityIterator::~VelocityIterator
virtual ~VelocityIterator()
Definition:
velocity_iterator.h:47
ros.h
dwb_plugins
Definition:
kinematic_parameters.h:43
dwb_plugins::VelocityIterator::startNewIteration
virtual void startNewIteration(const nav_2d_msgs::Twist2D ¤t_velocity, double dt)=0
dwb_plugins::VelocityIterator::nextTwist
virtual nav_2d_msgs::Twist2D nextTwist()=0
kinematic_parameters.h
dwb_plugins::VelocityIterator::hasMoreTwists
virtual bool hasMoreTwists()=0
dwb_plugins::KinematicParameters::Ptr
std::shared_ptr< KinematicParameters > Ptr
Definition:
kinematic_parameters.h:92
dwb_plugins::VelocityIterator
Definition:
velocity_iterator.h:44
ros::NodeHandle
dwb_plugins
Author(s):
autogenerated on Sun May 18 2025 02:47:27