moveit2
The MoveIt Motion Planning Framework for ROS 2.
Loading...
Searching...
No Matches
lazy_free_space_updater.hpp
Go to the documentation of this file.
1/*********************************************************************
2 * Software License Agreement (BSD License)
3 *
4 * Copyright (c) 2011, Willow Garage, Inc.
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 Willow Garage 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 OWNER 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/* Author: Ioan Sucan */
36
37#pragma once
38
40#include <deque>
41#include <unordered_map>
42#include <condition_variable>
43#include <thread>
44#include <rclcpp/logger.hpp>
45
47{
49{
50public:
51 LazyFreeSpaceUpdater(const collision_detection::OccMapTreePtr& tree, unsigned int max_batch_size = 10);
53
54 void pushLazyUpdate(octomap::KeySet* occupied_cells, octomap::KeySet* model_cells,
55 const octomap::point3d& sensor_origin);
56
57private:
58#ifdef __APPLE__
59 typedef std::unordered_map<octomap::OcTreeKey, unsigned int, octomap::OcTreeKey::KeyHash> OcTreeKeyCountMap;
60#elif __cplusplus >= 201103L
61 typedef std::unordered_map<octomap::OcTreeKey, unsigned int, octomap::OcTreeKey::KeyHash> OcTreeKeyCountMap;
62#else
63 typedef std::tr1::unordered_map<octomap::OcTreeKey, unsigned int, octomap::OcTreeKey::KeyHash> OcTreeKeyCountMap;
64#endif
65
66 void pushBatchToProcess(OcTreeKeyCountMap* occupied_cells, octomap::KeySet* model_cells,
67 const octomap::point3d& sensor_origin);
68
69 void lazyUpdateThread();
70 void processThread();
71
73 bool running_;
74 std::size_t max_batch_size_;
75 double max_sensor_delta_;
76
77 std::deque<octomap::KeySet*> occupied_cells_sets_;
78 std::deque<octomap::KeySet*> model_cells_sets_;
79 std::deque<octomap::point3d> sensor_origins_;
80 std::condition_variable update_condition_;
81 std::mutex update_cell_sets_lock_;
82
83 OcTreeKeyCountMap* process_occupied_cells_set_;
84 octomap::KeySet* process_model_cells_set_;
85 octomap::point3d process_sensor_origin_;
86 std::condition_variable process_condition_;
87 std::mutex cell_process_lock_;
88
89 std::thread update_thread_;
90 std::thread process_thread_;
91
92 rclcpp::Logger logger_;
93};
94} // namespace occupancy_map_monitor
void pushLazyUpdate(octomap::KeySet *occupied_cells, octomap::KeySet *model_cells, const octomap::point3d &sensor_origin)
std::shared_ptr< OccMapTree > OccMapTreePtr