Skip to content

Commit

Permalink
feat: pointcloud based probabilistic occupancy grid map (#624)
Browse files Browse the repository at this point in the history
* initial commit

Signed-off-by: Yukihiro Saito <yukky.saito@gmail.com>

* ci(pre-commit): autofix

* change param

Signed-off-by: Yukihiro Saito <yukky.saito@gmail.com>

* update readme

Signed-off-by: Yukihiro Saito <yukky.saito@gmail.com>

* add launch

Signed-off-by: Yukihiro Saito <yukky.saito@gmail.com>

* ci(pre-commit): autofix

* update readme

Signed-off-by: Yukihiro Saito <yukky.saito@gmail.com>

* ci(pre-commit): autofix

* fix typo

Signed-off-by: Yukihiro Saito <yukky.saito@gmail.com>

* update readme

Signed-off-by: Yukihiro Saito <yukky.saito@gmail.com>

* ci(pre-commit): autofix

* cosmetic change

Signed-off-by: Yukihiro Saito <yukky.saito@gmail.com>

* add single frame mode

Signed-off-by: Yukihiro Saito <yukky.saito@gmail.com>

* ci(pre-commit): autofix

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
  • Loading branch information
yukkysaito and pre-commit-ci[bot] authored Apr 8, 2022
1 parent 5df08c0 commit 0b70df0
Show file tree
Hide file tree
Showing 32 changed files with 1,155 additions and 113 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -76,8 +76,8 @@ def add_launch_arg(name: str, default_value=None):
extra_arguments=[{"use_intra_process_comms": LaunchConfiguration("use_intra_process")}],
),
ComposableNode(
package="laserscan_to_occupancy_grid_map",
plugin="occupancy_grid_map::OccupancyGridMapNode",
package="probabilistic_occupancy_grid_map",
plugin="occupancy_grid_map::LaserscanBasedOccupancyGridMapNode",
name="occupancy_grid_map_node",
remappings=[
("~/input/laserscan", LaunchConfiguration("output/laserscan")),
Expand Down
2 changes: 1 addition & 1 deletion launch/tier4_simulator_launch/launch/simulator.launch.xml
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@
<group>
<push-ros-namespace namespace="occupancy_grid_map"/>
<!-- Occupancy Grid -->
<include file="$(find-pkg-share laserscan_to_occupancy_grid_map)/launch/laserscan_to_occupancy_grid_map.launch.py">
<include file="$(find-pkg-share probabilistic_occupancy_grid_map)/launch/laserscan_based_occupancy_grid_map.launch.py">
<arg name="input_obstacle_pointcloud" value="true"/>
<arg name="input_obstacle_and_raw_pointcloud" value="false"/>
<arg name="input/obstacle_pointcloud" value="/perception/obstacle_segmentation/pointcloud"/>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
<arg name="input/laserscan" default="/perception/occupancy_grid_map/virtual_scan/laserscan"/>
<arg name="input/occupancy_grid_map" default="/perception/object_recognition/detection/validation/occupancy_grid_based/single_frame_occupancy_grid_map"/>

<node pkg="laserscan_to_occupancy_grid_map" exec="laserscan_to_occupancy_grid_map_node" name="single_frame_laserscan_occupancy_grid_map" output="screen">
<node pkg="probabilistic_occupancy_grid_map" exec="laserscan_based_occupancy_grid_map_node" name="single_frame_laserscan_occupancy_grid_map" output="screen">
<remap from="~/input/laserscan" to="$(var input/laserscan)"/>
<remap from="~/output/occupancy_grid_map" to="$(var input/occupancy_grid_map)"/>
<param name="input_obstacle_pointcloud" value="false"/>
Expand Down
46 changes: 0 additions & 46 deletions sensing/laserscan_to_occupancy_grid_map/CMakeLists.txt

This file was deleted.

64 changes: 64 additions & 0 deletions sensing/probabilistic_occupancy_grid_map/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
cmake_minimum_required(VERSION 3.5)
project(probabilistic_occupancy_grid_map)

if(NOT CMAKE_CXX_STANDARD)
set(CMAKE_CXX_STANDARD 14)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(CMAKE_CXX_EXTENSIONS OFF)
endif()
if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang")
add_compile_options(-Wall -Wextra -Wpedantic)
endif()

find_package(ament_cmake_auto REQUIRED)
find_package(eigen3_cmake_module REQUIRED)
find_package(Eigen3 REQUIRED)
find_package(PCL REQUIRED)
ament_auto_find_build_dependencies()

# PointcloudBasedOccupancyGridMap
ament_auto_add_library(pointcloud_based_occupancy_grid_map SHARED
src/pointcloud_based_occupancy_grid_map/pointcloud_based_occupancy_grid_map_node.cpp
src/pointcloud_based_occupancy_grid_map/occupancy_grid_map.cpp
src/updater/occupancy_grid_map_binary_bayes_filter_updater.cpp
)

target_link_libraries(pointcloud_based_occupancy_grid_map
${PCL_LIBRARIES}
)

rclcpp_components_register_node(pointcloud_based_occupancy_grid_map
PLUGIN "occupancy_grid_map::PointcloudBasedOccupancyGridMapNode"
EXECUTABLE pointcloud_based_occupancy_grid_map_node
)

# LaserscanBasedOccupancyGridMap
ament_auto_add_library(laserscan_based_occupancy_grid_map SHARED
src/laserscan_based_occupancy_grid_map/laserscan_based_occupancy_grid_map_node.cpp
src/laserscan_based_occupancy_grid_map/occupancy_grid_map.cpp
src/updater/occupancy_grid_map_binary_bayes_filter_updater.cpp
)

target_link_libraries(laserscan_based_occupancy_grid_map
${PCL_LIBRARIES}
)

rclcpp_components_register_node(laserscan_based_occupancy_grid_map
PLUGIN "occupancy_grid_map::LaserscanBasedOccupancyGridMapNode"
EXECUTABLE laserscan_based_occupancy_grid_map_node
)


if(BUILD_TESTING)
find_package(ament_lint_auto REQUIRED)
list(APPEND AMENT_LINT_AUTO_EXCLUDE
# To avoid conflicts between cpplint and uncrustify w.r.t. inclusion guards
ament_cmake_uncrustify
)
ament_lint_auto_find_test_dependencies()
endif()

ament_auto_package(
INSTALL_TO_SHARE
launch
)
11 changes: 11 additions & 0 deletions sensing/probabilistic_occupancy_grid_map/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# probabilistic_occupancy_grid_map

## Purpose

This package outputs the probability of having an obstacle as occupancy grid map.
![pointcloud_based_occupancy_grid_map_sample_image](./image/pointcloud_based_occupancy_grid_map_sample_image.gif)

## References/External links

- [Pointcloud based occupancy grid map](pointcloud-based-occupancy-grid-map.md)
- [Laserscan based occupancy grid map](laserscan-based-occupancy-grid-map.md)
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,8 @@
* Author: Eitan Marder-Eppstein
*********************************************************************/

#ifndef LASERSCAN_TO_OCCUPANCY_GRID_MAP__COST_VALUE_HPP_
#define LASERSCAN_TO_OCCUPANCY_GRID_MAP__COST_VALUE_HPP_
#ifndef COST_VALUE_HPP_
#define COST_VALUE_HPP_

#include <algorithm>

Expand All @@ -74,4 +74,4 @@ struct CostTranslationTable
static const CostTranslationTable cost_translation_table;
} // namespace occupancy_cost_value

#endif // LASERSCAN_TO_OCCUPANCY_GRID_MAP__COST_VALUE_HPP_
#endif // COST_VALUE_HPP_
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,12 @@
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef LASERSCAN_TO_OCCUPANCY_GRID_MAP__LASERSCAN_TO_OCCUPANCY_GRID_MAP_NODE_HPP_
#define LASERSCAN_TO_OCCUPANCY_GRID_MAP__LASERSCAN_TO_OCCUPANCY_GRID_MAP_NODE_HPP_
#ifndef LASERSCAN_BASED_OCCUPANCY_GRID_MAP__LASERSCAN_BASED_OCCUPANCY_GRID_MAP_NODE_HPP_
#define LASERSCAN_BASED_OCCUPANCY_GRID_MAP__LASERSCAN_BASED_OCCUPANCY_GRID_MAP_NODE_HPP_

#include "laserscan_to_occupancy_grid_map/occupancy_grid_map.hpp"
#include "laserscan_to_occupancy_grid_map/updater/occupancy_grid_map_binary_bayes_filter_updater.hpp"
#include "laserscan_to_occupancy_grid_map/updater/occupancy_grid_map_updater_interface.hpp"
#include "laserscan_based_occupancy_grid_map/occupancy_grid_map.hpp"
#include "updater/occupancy_grid_map_binary_bayes_filter_updater.hpp"
#include "updater/occupancy_grid_map_updater_interface.hpp"

#include <builtin_interfaces/msg/time.hpp>
#include <laser_geometry/laser_geometry.hpp>
Expand Down Expand Up @@ -48,10 +48,10 @@ using sensor_msgs::msg::PointCloud2;
using tf2_ros::Buffer;
using tf2_ros::TransformListener;

class OccupancyGridMapNode : public rclcpp::Node
class LaserscanBasedOccupancyGridMapNode : public rclcpp::Node
{
public:
explicit OccupancyGridMapNode(const rclcpp::NodeOptions & node_options);
explicit LaserscanBasedOccupancyGridMapNode(const rclcpp::NodeOptions & node_options);

private:
PointCloud2::SharedPtr convertLaserscanToPointCLoud2(const LaserScan::ConstSharedPtr & input);
Expand Down Expand Up @@ -98,4 +98,4 @@ class OccupancyGridMapNode : public rclcpp::Node

} // namespace occupancy_grid_map

#endif // LASERSCAN_TO_OCCUPANCY_GRID_MAP__LASERSCAN_TO_OCCUPANCY_GRID_MAP_NODE_HPP_
#endif // LASERSCAN_BASED_OCCUPANCY_GRID_MAP__LASERSCAN_BASED_OCCUPANCY_GRID_MAP_NODE_HPP_
Original file line number Diff line number Diff line change
Expand Up @@ -49,8 +49,8 @@
* David V. Lu!!
*********************************************************************/

#ifndef LASERSCAN_TO_OCCUPANCY_GRID_MAP__OCCUPANCY_GRID_MAP_HPP_
#define LASERSCAN_TO_OCCUPANCY_GRID_MAP__OCCUPANCY_GRID_MAP_HPP_
#ifndef LASERSCAN_BASED_OCCUPANCY_GRID_MAP__OCCUPANCY_GRID_MAP_HPP_
#define LASERSCAN_BASED_OCCUPANCY_GRID_MAP__OCCUPANCY_GRID_MAP_HPP_

#include <nav2_costmap_2d/costmap_2d.hpp>
#include <rclcpp/rclcpp.hpp>
Expand Down Expand Up @@ -85,10 +85,10 @@ class OccupancyGridMap : public nav2_costmap_2d::Costmap2D

bool worldToMap(double wx, double wy, unsigned int & mx, unsigned int & my) const;

rclcpp::Logger logger_{rclcpp::get_logger("occupancy_grid_map")};
rclcpp::Logger logger_{rclcpp::get_logger("laserscan_based_occupancy_grid_map")};
rclcpp::Clock clock_{RCL_ROS_TIME};
};

} // namespace costmap_2d

#endif // LASERSCAN_TO_OCCUPANCY_GRID_MAP__OCCUPANCY_GRID_MAP_HPP_
#endif // LASERSCAN_BASED_OCCUPANCY_GRID_MAP__OCCUPANCY_GRID_MAP_HPP_
Loading

0 comments on commit 0b70df0

Please sign in to comment.