Main Page
Namespaces
Classes
Files
File List
include
rotate_recovery
rotate_recovery.h
Go to the documentation of this file.
1
/*********************************************************************
2
*
3
* Software License Agreement (BSD License)
4
*
5
* Copyright (c) 2009, Willow Garage, Inc.
6
* All rights reserved.
7
*
8
* Redistribution and use in source and binary forms, with or without
9
* modification, are permitted provided that the following conditions
10
* are met:
11
*
12
* * Redistributions of source code must retain the above copyright
13
* notice, this list of conditions and the following disclaimer.
14
* * Redistributions in binary form must reproduce the above
15
* copyright notice, this list of conditions and the following
16
* disclaimer in the documentation and/or other materials provided
17
* with the distribution.
18
* * Neither the name of Willow Garage, Inc. nor the names of its
19
* contributors may be used to endorse or promote products derived
20
* from this software without specific prior written permission.
21
*
22
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33
* POSSIBILITY OF SUCH DAMAGE.
34
*
35
* Author: Eitan Marder-Eppstein
36
*********************************************************************/
37
#ifndef ROTATE_RECOVERY_H_
38
#define ROTATE_RECOVERY_H_
39
#include <
nav_core/recovery_behavior.h
>
40
#include <
costmap_2d/costmap_2d_ros.h
>
41
#include <
tf/transform_listener.h
>
42
#include <
ros/ros.h
>
43
#include <
base_local_planner/costmap_model.h
>
44
#include <geometry_msgs/Twist.h>
45
#include <geometry_msgs/Point.h>
46
#include <
angles/angles.h
>
47
48
namespace
rotate_recovery
{
53
class
RotateRecovery
:
public
nav_core::RecoveryBehavior
{
54
public
:
60
RotateRecovery
();
61
68
void
initialize
(std::string name,
tf::TransformListener
*
tf
,
69
costmap_2d::Costmap2DROS
* global_costmap,
costmap_2d::Costmap2DROS
* local_costmap);
70
74
void
runBehavior
();
75
79
~RotateRecovery
();
80
81
private
:
82
costmap_2d::Costmap2DROS
*
global_costmap_
, *
local_costmap_
;
83
costmap_2d::Costmap2D
costmap_
;
84
std::string
name_
;
85
tf::TransformListener
*
tf_
;
86
bool
initialized_
;
87
double
sim_granularity_
,
min_rotational_vel_
,
max_rotational_vel_
,
acc_lim_th_
,
tolerance_
,
frequency_
;
88
base_local_planner::CostmapModel
*
world_model_
;
89
};
90
};
91
#endif
rotate_recovery::RotateRecovery::costmap_
costmap_2d::Costmap2D costmap_
Definition:
rotate_recovery.h:83
rotate_recovery::RotateRecovery::sim_granularity_
double sim_granularity_
Definition:
rotate_recovery.h:87
costmap_2d_ros.h
transform_listener.h
rotate_recovery::RotateRecovery::tf_
tf::TransformListener * tf_
Definition:
rotate_recovery.h:85
rotate_recovery::RotateRecovery::world_model_
base_local_planner::CostmapModel * world_model_
Definition:
rotate_recovery.h:88
rotate_recovery::RotateRecovery::~RotateRecovery
~RotateRecovery()
Destructor for the rotate recovery behavior.
Definition:
rotate_recovery.cpp:77
rotate_recovery::RotateRecovery::frequency_
double frequency_
Definition:
rotate_recovery.h:87
rotate_recovery::RotateRecovery::global_costmap_
costmap_2d::Costmap2DROS * global_costmap_
Definition:
rotate_recovery.h:82
rotate_recovery::RotateRecovery::max_rotational_vel_
double max_rotational_vel_
Definition:
rotate_recovery.h:87
rotate_recovery::RotateRecovery::local_costmap_
costmap_2d::Costmap2DROS * local_costmap_
Definition:
rotate_recovery.h:82
rotate_recovery::RotateRecovery::RotateRecovery
RotateRecovery()
Constructor, make sure to call initialize in addition to actually initialize the object.
Definition:
rotate_recovery.cpp:44
tf
rotate_recovery::RotateRecovery::runBehavior
void runBehavior()
Run the RotateRecovery recovery behavior.
Definition:
rotate_recovery.cpp:81
nav_core::RecoveryBehavior
rotate_recovery::RotateRecovery::tolerance_
double tolerance_
Definition:
rotate_recovery.h:87
rotate_recovery::RotateRecovery::min_rotational_vel_
double min_rotational_vel_
Definition:
rotate_recovery.h:87
recovery_behavior.h
ros.h
tf::TransformListener
rotate_recovery::RotateRecovery::initialized_
bool initialized_
Definition:
rotate_recovery.h:86
costmap_model.h
rotate_recovery
Definition:
rotate_recovery.h:48
base_local_planner::CostmapModel
costmap_2d::Costmap2D
angles.h
costmap_2d::Costmap2DROS
rotate_recovery::RotateRecovery::name_
std::string name_
Definition:
rotate_recovery.h:84
rotate_recovery::RotateRecovery
A recovery behavior that rotates the robot in-place to attempt to clear out space.
Definition:
rotate_recovery.h:53
rotate_recovery::RotateRecovery::acc_lim_th_
double acc_lim_th_
Definition:
rotate_recovery.h:87
rotate_recovery::RotateRecovery::initialize
void initialize(std::string name, tf::TransformListener *tf, costmap_2d::Costmap2DROS *global_costmap, costmap_2d::Costmap2DROS *local_costmap)
Initialization function for the RotateRecovery recovery behavior.
Definition:
rotate_recovery.cpp:47
rotate_recovery
Author(s): Eitan Marder-Eppstein, contradict@gmail.com
autogenerated on Sun Mar 3 2019 03:44:46