Go to the documentation of this file.
37 TrackingOctomapServer::TrackingOctomapServer(
const std::string& filename) :
50 ROS_ERROR(
"Could not open requested file %s, exiting.", filename.c_str());
57 std::string changeSetTopic =
"changes";
58 std::string changeIdFrame =
"/talker/changes";
60 private_nh.
param(
"topic_changes", changeSetTopic, changeSetTopic);
67 ROS_WARN(
"OctoMapServer: It might not be useful to publish changes and at the same time listen to them."
68 "Setting 'track_changes' to false!");
101 pcl::PointCloud<pcl::PointXYZI> changedCells = pcl::PointCloud<pcl::PointXYZI>();
104 for (KeyBoolMap::const_iterator iter = startPnt; iter != endPnt; ++iter) {
118 pnt.intensity = 1000;
121 pnt.intensity = -1000;
124 changedCells.push_back(pnt);
129 sensor_msgs::PointCloud2 changed;
134 ROS_DEBUG(
"[server] sending %d changed entries", (
int)changedCells.size());
142 pcl::PointCloud<pcl::PointXYZI> cells;
144 ROS_DEBUG(
"[client] size of newly occupied cloud: %i", (
int)cells.points.size());
146 for (
size_t i = 0; i < cells.points.size(); i++) {
147 pcl::PointXYZI& pnt = cells.points[i];
void updateInnerOccupancy()
OcTreeNode * search(const OcTreeKey &key, unsigned int depth=0) const
virtual ~TrackingOctomapServer()
pcl::PointCloud< pcl::PointXYZ > PCLPointCloud
virtual size_t size() const
size_t calcNumNodes() const
KeyBoolMap::const_iterator changedKeysBegin() const
point3d keyToCoord(const OcTreeKey &key) const
bool readBinary(const std::string &filename)
OcTreeKey coordToKey(const point3d &coord) const
void insertScan(const tf::Point &sensorOrigin, const PCLPointCloud &ground, const PCLPointCloud &nonground)
update occupancy map with a scan labeled as ground and nonground. The scans should be in the global m...
ros::Publisher pubChangeSet
virtual void publishAll(const ros::Time &rostime=ros::Time::now())
void fromROSMsg(const sensor_msgs::PointCloud2 &cloud, pcl::PointCloud< T > &pcl_cloud)
void publish(const boost::shared_ptr< M > &message) const
Publisher advertise(AdvertiseOptions &ops)
void resetChangeDetection()
ros::Subscriber subChangeSet
double getResolution() const
void trackCallback(sensor_msgs::PointCloud2Ptr cloud)
nav_msgs::OccupancyGrid m_gridmap
Subscriber subscribe(const std::string &topic, uint32_t queue_size, const boost::function< void(C)> &callback, const VoidConstPtr &tracked_object=VoidConstPtr(), const TransportHints &transport_hints=TransportHints())
virtual void insertScan(const tf::Point &sensorOrigin, const PCLPointCloud &ground, const PCLPointCloud &nonground)
update occupancy map with a scan labeled as ground and nonground. The scans should be in the global m...
bool isNodeOccupied(const OcTreeNode &occupancyNode) const
KeyBoolMap::const_iterator changedKeysEnd() const
std::string change_id_frame
void enableChangeDetection(bool enable)
T param(const std::string ¶m_name, const T &default_val) const
void toROSMsg(const pcl::PointCloud< T > &cloud, sensor_msgs::Image &msg)
virtual OcTreeNode * updateNode(const OcTreeKey &key, bool occupied, bool lazy_eval=false)
unsigned int getTreeDepth() const
octomap_server
Author(s): Armin Hornung
autogenerated on Mon Jan 2 2023 03:18:15