基于RRT的机器人自主探索建图
一、方法讲解:
本项目分为三个部分:机器人周围一定范围内基于RRT的全局检测,
根据上一步检测的未知区域点执行sklearn.cluster.MeanShift聚类,获取聚类中心;
根据聚类中心计算各点增益,取最大增益点为目标,调用move_base规划路径和控制机器人行走。
二、各部分详解:
2.1 基于RRT的全局检测:检测未知区域点并发布
以机器人为中心,激光采样范围为半径的正方形区域内,采用RRT算法计算未知区域点:如果RRT计算的某点在要计算的地图范围内,并且该点在地图内的状态为空闲区域点,则将该点加入RRT树;如果该点在地图的状态为未知状态区域,则该点不加入RRT树,并将该点发布出去;
2.2 根据上一步检测的未知区域点执行sklearn.cluster.MeanShift聚类,获取聚类中心:
该部分订阅全局检测的未知区域点,并利用MeanShift算法获取聚类中心;
2.3 根据聚类中心计算各点增益,取最大增益点为目标,调用move_base规划路径和控制行走。
根据设定的信息半径,和上一步的聚类中心,结合聚类中心离机器人的距离,计算各个聚类中心的信息增益,然后取信息增益最大的点作为目标点,调用move_base来向该点移动;新的聚类中心和增益不停被计算,因此在运动过程中目标点可能会改变,或者因为移动地图中原来的目标点变为空闲区域,则新的目标点会被计算。
三、效果展示:
建图算法采用gmapping,激光角度220度.,激光范围14米。
蓝色线:全局RRT树;
绿色点:地图状态未知区域点
绿色线:move_base全局规划
紫色线:机器人移动轨迹。
例一:





例二、


仿真环境下:左下角、底部及右下角图建歪了。



仿真模型大小:70米*64米

基于RRT的机器人自主探索建图的更多相关文章
- SLAM+语音机器人DIY系列:(六)SLAM建图与自主避障导航——2.google-cartographer机器人SLAM建图
		
摘要 通过前面的基础学习,本章进入最为激动的机器人自主导航的学习.在前面的学习铺垫后,终于迎来了最大乐趣的时刻,就是赋予我们的miiboo机器人能自由行走的生命.本章将围绕机器人SLAM建图.导航避障 ...
 - 基于ros2 dashing的建图导航探索
		
基于ros2 dashing的建图导航探索 1. 环境准备 安装ros2 dashing, 参考链接: https://index.ros.org/doc/ros2/Installation/Dash ...
 - 除了ROS ,机器人自主定位导航还能怎么做?
		
博客转载自:https://www.leiphone.com/news/201609/10QD7yp7JFV9H9Ni.html 雷锋网(公众号:雷锋网)按:本文作者科技剪刀手,思岚科技技术顾问. 随 ...
 - cartographer环境建立以及建图测试(详细级)
 - 机器人自主移动的秘密:实际应用中,SLAM究竟是如何实现的?(二)
		
博客转载自:https://www.leiphone.com/news/201612/FRzmoEI8Iud6CmT2.html 雷锋网(公众号:雷锋网)按:本文作者SLAMTEC(思岚科技公号sla ...
 - 基于 Mathematica 的机器人仿真环境(机械臂篇)[转]
		
完美的教程,没有之一,收藏学习. 目的 本文手把手教你在 Mathematica 软件中搭建机器人的仿真环境,具体包括以下内容(所使用的版本是 Mathematica 11.1,更早的版本可能缺少某些 ...
 - 【BZOJ-2879】美食节   最小费用最大流 + 动态建图
		
2879: [Noi2012]美食节 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1366 Solved: 737[Submit][Status] ...
 - 使用hector-slam和Kinect V1建图
		
一.建图实际操作 下载源码测试源码,depthimage_to_laserscan,参考https://blog.csdn.net/u010925447/article/details/5649468 ...
 - 通过gmapping和伪造的odom,完成Kinect建图
		
传感器信息: 环境深度信息:sensor_msgs/laserScan -----> RGBD三维点云数据:通过ros功能包depthimage to laserscan完成深度相机数据转换成激 ...
 
随机推荐
- 一、小程序连接MySql数据库
			
前言:我用的是wafer2 node.解决方案 下面连接有环境配置及搭建流程(https://github.com/tencentyun/wafer2-quickstart-nodejs) ,连接是官 ...
 - eCharts.js使用心得
			
最近刚刚做了一个项目,需求是使用eCharts实现实时监控,可以动态的增加和删除数据,可以全屏展示,趁着现在还没忘干净,整理一下使用过程中出现的问题和经验.可能有分析的不到位的地方,不喜勿喷! 一.图 ...
 - Element-ui组件--pagination分页
			
一般写后台系统都会有很多的列表,有列表就相应的要用到分页,根据项目中写的几个分页写一下我对分页的理解,就当是学习笔记了. 这是Element-ui提供的完整的例子 <template> ...
 - JQ常用方法(哈哈)
			
1ajax请求 $(function(){ $("#send").click(function(){ $.ajax({ type:"get" ...
 - Mysql:case when then end 的用法
			
0.创建一张数据表 表名为 test_when_case CREATE TABLE `test_when_case` ( `id` int(11) unsigned NOT NULL AUTO_INC ...
 - vue 改变我们插值的符号{{}}改为${}
			
delimiters的作用是改变我们插值的符号.Vue默认的插值是双大括号{{}}.但有时我们会有需求更改这个插值的形式. delimiters:['${','}'] 现在我们的插值形式就变成了${} ...
 - 对文件 I/O,标准 I/O 的缓冲的理解
			
1.标准I/O缓冲区 要理解标准I/O,就要先知道文件I/O的业务逻辑. 下面图示为文件I/O 如执行下面的代码: write(fd, buf2, sizeof(buf2)); 图中 buf:就是bu ...
 - 笔记-python-coroutine
			
笔记-python-coroutine 1. 协程 1.1. 协程的概念 协程,又称微线程,纤程.英文名Coroutine.协程是一种用户态的轻量级线程. 线程是系统级别的,它们是由操 ...
 - 4.Mongodb数据查询2
			
1.limit &skip (1)Limit 方法limit():用于读取指定数量的文档 语法: db.集合名称.find().limit(NUMBER) 参数NUMBER表示要获取文档的条数 ...
 - 发送广播重新挂载SD卡,使图库可以及时显示自己保存的图片(无需手机重启)
			
我们或许经常会遇到这种情况,明明保存了图片,但是当你打开图片时,却没有找到这张图片,手机重启之后才能看到.这是因为SD卡并没有重新挂载,图库也无法把这张图片加载进去,解决这个问题非常简单,只需要我们模 ...