plain.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2014-2018, the neonavigation authors
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  *
8  * * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * * Neither the name of the copyright holder nor the names of its
14  * contributors may be used to endorse or promote products derived from
15  * this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
21  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27  * POSSIBILITY OF SUCH DAMAGE.
28  */
29 
30 #ifndef COSTMAP_CSPACE_COSTMAP_3D_LAYER_PLAIN_H
31 #define COSTMAP_CSPACE_COSTMAP_3D_LAYER_PLAIN_H
32 
33 #include <memory>
34 
35 #include <costmap_cspace_msgs/CSpace3D.h>
36 #include <costmap_cspace_msgs/CSpace3DUpdate.h>
37 #include <geometry_msgs/PolygonStamped.h>
38 #include <nav_msgs/OccupancyGrid.h>
39 
42 
43 namespace costmap_cspace
44 {
46 {
47 public:
48  using Ptr = std::shared_ptr<Costmap3dLayerPlain>;
49 
51  {
52  Polygon footprint;
53  footprint.v.resize(3);
54  for (auto& p : footprint.v)
55  {
56  p[0] = p[1] = 0.0;
57  }
58  setFootprint(footprint);
59  }
61  {
63  static_cast<double>(config["linear_expand"]),
64  static_cast<double>(config["linear_spread"]));
65  }
66 
67 protected:
69  CSpace3DMsg::Ptr map,
70  const nav_msgs::OccupancyGrid::ConstPtr& msg,
71  const UpdatedRegion& region) final
72  {
73  ROS_ASSERT(ang_grid_ > 0);
74  clearTravelableArea(map, msg);
75  generateSpecifiedCSpace(map, msg, 0);
76  for (size_t i = 1; i < map->info.angle; ++i)
77  {
78  CSpace3DMsg::copyCells(*map, 0, 0, i, *map, 0, 0, 0, map->info.width * map->info.height);
79  }
80  }
81 };
82 } // namespace costmap_cspace
83 
84 #endif // COSTMAP_CSPACE_COSTMAP_3D_LAYER_PLAIN_H
void setExpansion(const float linear_expand, const float linear_spread)
Definition: footprint.h:91
std::vector< Vec > v
Definition: polygon.h:93
static void copyCells(CSpace3DMsg &to, const int &to_x, const int &to_y, const int &to_yaw, const CSpace3DMsg &from, const int &from_x, const int &from_y, const int &from_yaw, const int &copy_cell_num)
Definition: base.h:80
void generateSpecifiedCSpace(CSpace3DMsg::Ptr map, const nav_msgs::OccupancyGrid::ConstPtr &msg, const size_t yaw)
Definition: footprint.h:255
void generateCSpace(CSpace3DMsg::Ptr map, const nav_msgs::OccupancyGrid::ConstPtr &msg, const UpdatedRegion &region) final
Definition: plain.h:68
std::shared_ptr< CSpace3DMsg > Ptr
Definition: base.h:52
void loadConfig(XmlRpc::XmlRpcValue config)
Definition: plain.h:60
std::shared_ptr< Costmap3dLayerBase > Ptr
Definition: base.h:255
#define ROS_ASSERT(cond)
void setFootprint(const Polygon footprint)
Definition: footprint.h:103
void clearTravelableArea(CSpace3DMsg::Ptr map, const nav_msgs::OccupancyGrid::ConstPtr &msg)
Definition: footprint.h:206


costmap_cspace
Author(s): Atsushi Watanabe
autogenerated on Wed May 12 2021 02:20:29