CN114594761B - 机器人的路径规划方法、电子设备及计算机可读存储介质 - Google Patents
机器人的路径规划方法、电子设备及计算机可读存储介质 Download PDFInfo
- Publication number
- CN114594761B CN114594761B CN202210007009.XA CN202210007009A CN114594761B CN 114594761 B CN114594761 B CN 114594761B CN 202210007009 A CN202210007009 A CN 202210007009A CN 114594761 B CN114594761 B CN 114594761B
- Authority
- CN
- China
- Prior art keywords
- robot
- area
- sub
- obstacle
- region
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 56
- 230000033001 locomotion Effects 0.000 claims abstract description 85
- 230000004044 response Effects 0.000 claims abstract description 20
- 238000004590 computer program Methods 0.000 claims description 14
- 238000004891 communication Methods 0.000 claims description 6
- 230000002093 peripheral effect Effects 0.000 claims 1
- 238000010586 diagram Methods 0.000 description 18
- 238000012545 processing Methods 0.000 description 7
- 238000004422 calculation algorithm Methods 0.000 description 6
- 238000005516 engineering process Methods 0.000 description 3
- 230000007613 environmental effect Effects 0.000 description 3
- 230000007547 defect Effects 0.000 description 2
- 238000010845 search algorithm Methods 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- 230000000007 visual effect Effects 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 238000005286 illumination Methods 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000011160 research Methods 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000010408 sweeping Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05D—SYSTEMS FOR CONTROLLING OR REGULATING NON-ELECTRIC VARIABLES
- G05D1/00—Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots
- G05D1/02—Control of position or course in two dimensions
- G05D1/021—Control of position or course in two dimensions specially adapted to land vehicles
- G05D1/0231—Control of position or course in two dimensions specially adapted to land vehicles using optical position detecting means
- G05D1/0238—Control of position or course in two dimensions specially adapted to land vehicles using optical position detecting means using obstacle or wall sensors
- G05D1/024—Control of position or course in two dimensions specially adapted to land vehicles using optical position detecting means using obstacle or wall sensors in combination with a laser
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05D—SYSTEMS FOR CONTROLLING OR REGULATING NON-ELECTRIC VARIABLES
- G05D1/00—Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots
- G05D1/02—Control of position or course in two dimensions
- G05D1/021—Control of position or course in two dimensions specially adapted to land vehicles
- G05D1/0212—Control of position or course in two dimensions specially adapted to land vehicles with means for defining a desired trajectory
- G05D1/0221—Control of position or course in two dimensions specially adapted to land vehicles with means for defining a desired trajectory involving a learning process
Landscapes
- Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- Aviation & Aerospace Engineering (AREA)
- Radar, Positioning & Navigation (AREA)
- Remote Sensing (AREA)
- General Physics & Mathematics (AREA)
- Automation & Control Theory (AREA)
- Optics & Photonics (AREA)
- Electromagnetism (AREA)
- Control Of Position, Course, Altitude, Or Attitude Of Moving Bodies (AREA)
- Manipulator (AREA)
Abstract
本申请公开了一种机器人的路径规划方法、电子设备及计算机可读存储介质,该路径规划方法包括:规划机器人的全局运动路径;响应于全局运动路径规划成功,则规划机器人的局部运动路径;响应于全局运动路径规划失败,则侦测机器人周围的障碍物;基于机器人周围的障碍物,控制机器人避开障碍物,并返回执行规划机器人的全局运动路径的步骤。本申请所提供的方法能够提高机器人的环境适应能力。
Description
技术领域
本申请涉及机器人技术领域,特别是涉及一种机器人的路径规划方法、电子设备及计算机可读存储介质。
背景技术
近年来,移动机器人在家庭服务等领域迅猛发展,其相关技术也逐渐成为研究热点,其中移动机器人路径规划算法是导航技术的关键。路径规划指机器人在具有障碍物的环境中,按照一定的规则,寻找一条从机器人当前位姿到目标位姿的最优无碰撞路径。
考虑到实际环境比较复杂,障碍物形状不确定因素太高等原因,目前路径规划算法在进行路径规划时,都需要膨胀车身、障碍物或者轨迹等达到避开障碍物的目的,但是在某些场景中,机器人移动的空间比较小,在进行膨胀处理时,传感器精度以及机器人、障碍物膨胀后的膨胀判断等因素的存在,导致存在机器人在狭小空间内路径规划失败的现象。
发明内容
本申请提供一种机器人的路径规划方法、电子设备及计算机可读存储介质,能够提高机器人的环境适应能力。
本申请实施例第一方面提供一种机器人的路径规划方法,所述方法包括:规划所述机器人的全局运动路径;响应于所述全局运动路径规划成功,则规划所述机器人的局部运动路径;响应于所述全局运动路径规划失败,则侦测所述机器人周围的障碍物;基于所述机器人周围的所述障碍物,控制所述机器人避开所述障碍物,并返回执行所述规划所述机器人的全局运动路径的步骤。
本申请实施例第二方面提供一种电子设备,所述电子设备包括处理器、存储器以及通信电路,所述处理器分别耦接所述存储器、所述通信电路,所述存储器中存储有程序数据,所述处理器通过执行所述存储器内的所述程序数据以实现上述方法中的步骤。
本申请实施例第三方面提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序能够被处理器执行以实现上述方法中的步骤。
有益效果是:本申请的路径规划方法,在规划机器人的全局运动路径失败时,侦测机器人周围的障碍物,然后基于机器人周围的障碍物,控制机器人避开障碍物,使得机器人运动到空旷空间,然后再重新规划机器人的全局运动路径,其中在控制机器人运动到空旷空间的过程中,能够远离障碍物,克服传感器噪声、膨胀处理等因素带来的虚拟障碍物,进而提高机器人的环境适应能力、稳定性以及路径规划方法的鲁棒性。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。其中:
图1是本申请机器人的路径规划方法一实施方式的流程示意图;
图2是本申请机器人的路径规划方法另一实施方式的流程示意图;
图3是本申请机器人的路径规划方法另一实施方式的流程示意图;
图4是本申请机器人的路径规划方法另一实施方式的流程示意图;
图5是本申请机器人的路径规划方法另一实施方式中的部分流程示意图;
图6是一应用场景中机器人的运动示意图;
图7是第一区域的划分示意图;
图8是本申请机器人的路径规划方法另一实施方式中的部分流程示意图;
图9是一应用场景中机器人的运动示意图;
图10是一应用场景中运动空间的示意图;
图11是一应用场景中运动空间的示意图;
图12是本申请电子设备一实施方式的结构示意图;
图13是本申请电子设备另一实施方式的结构示意图;
图14是本申请计算机可读存储介质一实施方式的结构示意图;
图15是本申请计算机程序产品一实施方式的结构示意图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性的劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
参阅图1,图1是本申请机器人的路径规划方法一实施方式的流程示意图,该方法包括:
S101:规划机器人的全局运动路径。
本实施方式中的路径规划方法由控制机器人运动的电子设备执行,该电子设备可以与机器人彼此独立,也可以集成在机器人上。其中,当电子设备集成在机器人上时,电子设备具体可以是机器人中的处理器。
其中本申请对机器人的类型不做限制,其可以是任何一个可以移动的移动机器人,例如扫地机器人、救援机器人、服务机器人等。
其中电子设备在获取到机器人的当前位置以及目标位置后,根据预先存储的地图,规划从当前位置到目标位置的全局运动路径。
其中,可以采用例如A*(启发式搜索算法)、D*(动态启发式路径搜索算法)或者Dijkstra(迪科斯彻算法)等算法规划机器人的全局运动路径。
S102:判断全局运动路径是否规划成功。
若成功,则执行步骤S105,若失败,则执行步骤S103。
其中,如果获取到全局运动路径,则判定全局运动路径规划成功,否则判定全局运动路径规划失败。
S103:侦测机器人周围的障碍物。
在本实施方式中,若全局路径规划失败,则判定造成失败的原因是机器人进入了狭小空间,进而侦测机器人周围的障碍物。
其中,预先在机器人上安装传感器,用于采集机器人周围的障碍物,在本实施方式中,在机器人上安装的传感器包括深度相机以及激光雷达。
具体而言,深度相机存在视野小、噪声大、易受光照干扰、无法测量透射材料等缺点,但具有不受物体高度限制、清晰度高等优点,而激光雷达虽然无法准确测量高度较高的物体,但是具有视野大、不易受环境因素影响等优点,因此采用深度相机和激光雷达相互配合,以弥补对方存在的缺点,保证获取机器人周围的障碍物的准确率。
其中,电子设备同时与深度相机以及激光雷达连接,通过深度相机以及激光雷达采集的数据,侦测机器人周围的障碍物。
S104:基于机器人周围的障碍物,控制机器人避开障碍物。
在获取到机器人周围的障碍物后,基于机器人周围的障碍物,控制机器人运动,以避开障碍物,即控制机器人进行脱困处理。
S105:规划机器人的局部运动路径。
如果步骤S102成功获取到机器人的全局运动路径,则规划机器人的局部运动路径,即进行局部路径规划。
其中,局部路径规划也称为局部避障,在机器人的实际运动过程中,其周围的环境并不是静态不变的,可能会出现一些运动的障碍物或者出现静态地图上不存在的障碍物,而这时就需要侦测机器人周围的环境信息,如果出现新的障碍物,就需要规划机器人的局部运动路径,以避开障碍物。
其中,可以采用例如DWA(动态窗口算法)或者TEB等算法规划机器人的局部运动路径。
上述实施方式的路径规划方法,在规划机器人的全局运动路径失败时,侦测机器人周围的障碍物,然后基于机器人周围的障碍物,控制机器人避开障碍物,使得机器人运动到空旷空间,然后再重新规划机器人的全局运动路径,其中在控制机器人运动到空旷空间的过程中,能够远离障碍物,克服传感器噪声、膨胀处理等因素带来的虚拟障碍物,进而提高机器人的环境适应能力、稳定性以及路径规划方法的鲁棒性。
参阅图2,图2是本申请机器人的路径规划方法另一实施方式的流程示意图,该方法包括:
S201:规划机器人的全局运动路径。
S202:判断全局运动路径是否规划成功。
S203:侦测机器人周围的障碍物。
S204:基于机器人周围的障碍物,控制机器人避开障碍物。
S205:规划机器人的局部运动路径。
步骤S201-S205与上述实施方式中的步骤S101-S105对应相同,具体可参见上述实施方式,在此不再赘述,
S206:判断局部运动路径是否规划成功。
若成功,则执行步骤S207,若失败,则返回执行步骤S201。
其中,如果获取到局部运动路径,则判定局部运动路径规划成功,否则判定局部运动路径规划失败。
S207:控制机器人运动至目的地。
与上述实施方式不同的是,本实施方式在局部运动路径规划失败时,判定机器人当前周围可能存在障碍物,由于局部运动路径影响着全局运动路径,因此返回重新规划机器人的全局运动路径。但是如果局部运动路径规划成功,则直接控制机器人运动至目的地。
参阅图3,图3是本申请机器人的路径规划方法另一实施方式的流程示意图,该方法包括:
S301:规划机器人的全局运动路径。
S302:判断全局运动路径是否规划成功。
S303:侦测机器人周围的障碍物。
S304:基于机器人周围的障碍物,控制机器人避开障碍物。
S305:规划机器人的局部运动路径。
步骤S301-S305与上述实施方式中的步骤S101-S105对应相同,具体可参见上述实施方式,在此不再赘述,
S306:判断局部运动路径是否规划成功。
如果成功,则执行步骤S309,如果失败,则执行步骤S307。
S307:侦测机器人周围的障碍物。
S308:基于机器人周围的障碍物,控制机器人避开障碍物。
在步骤S308之后,返回执行步骤S305。
与图2实施方式不同的是,本实施方式在局部运动路径规划失败时,不再重新规划全局运动路径,而是直接控制机器人进行脱困处理。其中步骤S307与上述实施方式中的步骤S103相同,步骤S308与上述实施方式中的步骤S104相同,具体可参见上述相关内容。
S309:控制机器人运动至目的地。
考虑到机器人在避开障碍物后,可能存在其他因素导致全局路径规划失败,此时重新规划全局运动路径会一直陷入循环,为了避免该现象,参阅图4,在另一实施方式中,机器人的路径规划方法包括:
S401:规划机器人的全局运动路径。
S402:判断全局运动路径是否规划成功。
若判断规划成功,则执行步骤S408,否则执行步骤S403。
S403:获取全局路径规划连续失败的累计次数。
S404:判断累计次数是否超过次数阈值。
若判断结果为是,则执行步骤S407,否则执行步骤S405。
S405:侦测机器人周围的障碍物。
S406:基于机器人周围的障碍物,控制机器人避开障碍物。
S407:提示规划失败。
S408:规划机器人的局部运动路径。
S409:判断局部运动路径是否规划成功。
若判断规划成功,则执行步骤S410,否则返回执行步骤S401。
S410:控制机器人运动至目的地。
在本实施方式中,利用计数器对全局运动路径规划连续失败的次数进行累计,当全局运动路径规划成功时,该计数器进行清零,当步骤S402判定全局运动路径规划失败时,获取计数器的计数,如果计数超过次数阈值,则提示规划失败,不再重新规划全局运动路径,否则控制机器人进行脱困处理。
其中,次数阈值可以根据实际应用场景进行设置,例如设置为20次或者10次等。
在上述任一项实施方式中,判断机器人是否脱困成功的标准可以是:机器人的预设范围内不存在障碍物。具体而言,在基于机器人周围的障碍物,控制机器人避开障碍物的过程中,如果一旦侦测到机器人周围的预设范围内不存在障碍物,则确定机器人已经避开了障碍物,机器人脱困成功,然后重新规划机器人的全局运动路径,否则继续驱动机器人避开障碍物。
其中预设范围可以根据实际应用场景进行设置,例如,在一应用场景中,当侦测到机器人周围0.6m内都不存在障碍物时,确定机器人已经避开了障碍物。
其中考虑到在某些应用场景中,可能存在无论机器人怎么运动,其都无法避开障碍物的现象,此时为了避免流程一直停留在基于机器人周围的障碍物,控制机器人避开障碍物的步骤,对机器人的运动时长进行累计,如果累计的时长达到时长阈值时,机器人还没有避开障碍物,则强制退出控制机器人避开障碍物的步骤,返回规划机器人的全局运动路径的步骤。
其中,时长阈值可以根据实际应用场景进行设置,例如,设置为2分钟或者15分钟等。
在其他实施方式中,判断机器人是否脱困成功的标准还可以是其他,例如:机器人的运动时长达到第一阈值,也就是说,在基于机器人周围的障碍物,控制机器人运动,直至机器人的运动时长达到第一阈值。
参阅图5,在一应用场景中,基于机器人周围的障碍物,控制机器人避开障碍物的步骤,包括:
S501:获取机器人周围第一区域内的障碍物。
在一应用场景中,第一区域是以机器人为圆心,半径等于第一预设距离的圆形区域。其中,第一预设距离可以根据实际场景进行设定,例如设定为0.6m。
在其他应用场景中,第一区域还可以是例如扇形、矩形、梯形等其他形状的区域,总而言之本申请对第一区域的形状不做限制。
S502:在第一区域不存在障碍物的至少一个第一子区域中,查找对应代价值最小的第一子区域,其中,第一子区域与机器人的前进方向的偏离程度和第一子区域对应的代价值呈正比,且第一子区域距离机器人最近的点到机器人的距离等于零,距离机器人最远的点处于第一区域的轮廓上。
其中,第一子区域中的代价值预先设置好,且第一子区域与机器人的前进方向的偏离程度越大,第一子区域对应的代价值越大。
其中,不存在障碍物的第一子区域距离机器人最近的点到机器人的距离等于零,距离机器人最远的点处于第一区域的轮廓上,从而使得机器人可以在不触碰障碍物的前提下,沿着该第一子区域内的任意一条路径离开第一区域,达到脱困的目的。
结合图6,机器人的前进方向记为“Front”,第一子区域与机器人的前进方向的偏离程度指的是,机器人指向第一子区域中任意一点的方向与前进方向Front的最大夹角。
可以理解的是,第一子区域与机器人的前进方向的偏离程度越大,机器人自当前位置朝向第一子区域运动时、需要消耗的时间、能量等越多,因此设置第一子区域对应的代价值越大。
可以理解的是,当第一区域中不存在障碍物的第一子区域为一个时,该第一子区域即为对应代价值最小的第一子区域,当第一区域中不存在障碍物的第一子区域为两个以上时,需要在两个以上的第一子区域中查找对应代价值最小的第一子区域。
S503:控制机器人沿着指向对应代价值最小的第一子区域的方向运动,以避开障碍物。
其中,控制机器人沿着指向对应代价值最小的第一子区域的方向运动,以避开障碍物时,可以先在对应代价值最小的第一子区域中随机确定一点,然后控制机器人沿着指向该点的路径运动,从而达到避开障碍物的目的,或者,先在对应代价值最小的第一子区域中确定目标点,然后控制机器人沿着指向目标点的路径运动,从而达到避开障碍物的目的,其中在对应代价值最小的第一子区域的所有点中,机器人指向目标点的方向与机器人的前进方向Front的夹角最小。
为了更好地理解,结合图6对步骤S503进行说明:
假设在图6中,第一区域中存在第一子区域A和第一子区域B都不存在障碍物,而由于第一子区域A与前进方向Front的偏离程度大于第一子区域B与前进方向Front的偏离程度,因此预先设置的第一子区域A的代价值大于第一子区域B的代价值,从而控制机器人沿着指向第一子区域B的方向(例如图6中虚线箭头方向)运动,以避开障碍物。
在该应用场景中,为了提高查找的效率,步骤S502在第一区域不存在障碍物的第一子区域中,查找对应代价值最小的第一子区域,具体包括:
(a1)在第一区域预先划分的多个子区域中,查找不存在障碍物的第一子区域;其中,子区域距离机器人最近的点到机器人的距离等于零,到机器人最远的点处于第一区域的轮廓上。
其中结合图7,以将第一区域划分为12个子区域对步骤S502进行说明:
在图7中,将第一区域平均分为4个大小相等且为扇形的区域,每个区域的圆心角均为90度,将该4个区域分别记为Front区域、Left区域、Right区域以及Back区域,其中,Front区域的对称轴与机器人的前进方向Front重合,且机器人的前进方向经过Front区域,Left区域、Right区域分别位于Front区域的两侧,Back区域位于Left区域、Right区域之间。
4个大小相等的区域又分别平均被划分为3个大小相等且为扇形的子区域,也就是说,第一区域被划分为12个大小相等的子区域,可以理解的是,Front区域中存在一个对称轴与机器人的前进方向Front重合的子区域,将该子区域记为第一基准子区域F-C,第一基准子区域F-C两侧的子区域分别记为F-L、F-R。
其中,继续结合图7,在划分好子区域后,分别为多个子区域分配代价值,分配原则为:第一基准子区域F-C的代价值最小,其他的子区域中,与机器人前进方向Front的偏离程度越大,其对应的代价值越大。在图7中,子区域中的数值的绝对值表示该子区域对应的代价值,数值的正、负号表示机器人自当前位置朝向对应子区域运动时的旋转方向,在图7中,第一基准子区域F-C的代价值为0,F-L子区域、F-R子区域与机器人前进方向Front的偏离程度相同,设置F-L子区域、F-R子区域的代价值相等,均为1;R-L子区域、L-R子区域与机器人前进方向Front的偏离程度相同,但均大于F-L子区域/F-R子区域与机器人前进方向Front的偏离程度,因此设置R-L子区域、L-R子区域的代价值为2,依次类推。
本实施方式将第一区域划分为多个子区域以及为子区域分配代价值后,在查找不存在障碍物的第一子区域时,只要先分别判断多个子区域中是否存在障碍物,然后在不存在障碍物的子区域中查找代价值最小的子区域即可,可以提高查找速度以及准确率。
在上述方案中,第一基准子区域F-C的对称轴与机器人的前进方向Front重合,但是在其他实施方式中,第一基准子区域F-C的对称轴也可以与机器人的前进方向Front不重合,只要保证机器人的前进方向Front能够经过第一基准子区域F-C即可。可以理解的是,当第一基准子区域F-C的对称轴不与机器人的前进方向Front重合时,第一区域中各个子区域的代价值不再如图7中呈对称设置。
同时上述方案以将第一区域划分为12个子区域对方案进行了说明,但是本申请并不限制于此,在其他实施方式中,还可以将第一区域划分为例如4、5、6、15或者18等其他数量的子区域。
同时在其他实施方式中,划分的多个子区域大小可以不等,且形状也可以不同,只要保证子区域距离机器人最近的点到机器人的距离等于零,距离机器人最远的点处于第一区域的轮廓上即可。
参阅图8,在另一应用场景中,基于机器人周围的障碍物,控制机器人避开障碍物的步骤,包括:
S601:获取机器人周围第一区域内的障碍物。
S602:判断在第一区域中,机器人的前进方向上是否存在障碍物。
若存在,则执行步骤S603,若不存在,则执行步骤S605。
在本实施方式中,步骤S602具体包括:判断第一区域中的第一基准子区域中,是否存在障碍物,其中,机器人的前进方向经过第一基准子区域;响应于第一基准子区域中存在障碍物,则确定机器人的前进方向上存在障碍物;响应于第一基准子区域中不存在障碍物,则确定机器人的前进方向上不存在障碍物。
也就是说,判断上述第一基准子区域F-C是否存在障碍物,如果存在,则执行步骤S603,如果不存在,则执行步骤S605。
在其他实施方式中,步骤S602还可以直接判断机器人的前进方向Front是否经过障碍物,如果经过,则执行步骤S603,否则执行步骤S605。
S603:在第一区域不存在障碍物的第一子区域中,查找对应代价值最小的第一子区域。
S604:控制机器人沿着指向对应代价值最小的第一子区域的方向运动,以避开障碍物。
步骤S603与上述步骤S502相同,步骤S604与上述步骤S503相同,在此不再赘述。
S605:获取第一区域外围第二区域内的障碍物。
其中,第二区域位于第一区域的外围,且与第一区域连接,也可以理解为第二区域位于第一区域远离机器人一侧。在一应用场景中,第二区域中是以机器人为圆心,内径为第一预设距离,外径为第二预设距离的环形区域。其中,第二预设距离大于第一预设距离。例如,第一预设距离为0.6m,第二预设距离为1.5m。
在其他应用场景中,第二区域还可以是例如扇形、矩形、梯形等其他形状的区域。
具体地,如果机器人的前进方向上存在障碍物,则直接在第一区域中查找不存在障碍物且代价值最小的第一子区域,如果机器人的前进方向上不存在障碍物时,则说明机器人此时如果直接前进,可以避开障碍物,但是本应用场景为了避免机器人在前进过程中再遇到障碍物,从而导致后续路径规划失败,又要重新进行路径规划,此时还要再结合第一区域外围的第二区域进行规划。
S606:在第一区域不存在障碍物的第一子区域以及第二区域不存在障碍物的第二子区域中,查找对应代价值最小的目标子区域,第二子区域中距离机器人最近的点处于第一区域的轮廓上,距离机器人最远的点处于第二区域的轮廓上,且目标子区域包括连通的第一子区域以及第二子区域。
其中,目标区域同时包括连通的第一子区域以及第二子区域,且第二子区域距离机器人最近的点处于第一区域的轮廓上,距离机器人最远的点处于第二区域的轮廓上,从而在不触碰障碍物的前提下,机器人可以沿着目标子区域中的任意一条路径,在经过第一区域后,离开第二区域,达到脱困的目的。
其中,与上述相同,目标子区域与机器人的前进方向Front的偏离程度越大,对应的代价值越大,因此本应用场景为了降低提高,减少规划的时间,查找代价值最小的目标子区域,后续步骤S607控制机器人沿着指向目标子区域的方向运动,达到脱困的目的。
为了更好地理解,结合图9进行说明:
在图9中,假设在第一区域中,有第一子区域A1、A2、A3不存在障碍物,假设在第二区域中,有第二子区域B1、B2、B3不存在障碍物,此时目标子区域为两个,分别为包括第一子区域A2以及第二子区域B1的第一目标子区域,另一个为包括第一子区域A3以及第二子区域B2的第二目标子区域,此时从图9可以看出,第一目标子区域与机器人的前进方向的偏离程度小于第二目标子区域与机器人的前进方向的偏离程度,也就是,第一目标子区域的代价值小于第二目标子区域的代价值,因此控制机器人沿着指向第一目标子区域的方向运动,即图9中虚线箭头所示的方向。
其中,为了提高查找的效率,同样在第二区域中划分多个子区域,在本实施方式中,第二区域中的多个子区域与第一区域中的多个子区域一一对应,其中一一对应指的是,两个子区域的对称轴重合,对应的代价值相等,例如在图9中,第一区域包括12个大小相等且均为扇形的子区域,第二区域包括12个大小相等且均为扇环形的子区域。
S607:控制机器人沿着指向目标子区域的方向运动,以避开障碍物。
其中,考虑到真正对机器人产生影响的是机器人前进方向上的障碍物,因此为了减小计算量,在步骤S606之前,还可以先判断第二区域中,机器人的前进方向上是否存在障碍物,如果存在,则执行步骤S606,如果不存在,则直接控制机器人前进即可。
与判断第一区域中,机器人的前进方向上是否存在障碍物类似,在判断第二区域中,机器人的前进方向上是否存在障碍物时,具体判断第二区域中的第二基准子区域中,是否存在障碍物,如果存在,则确定机器人的前进方向上存在障碍物,如果不存在,则确定机器人的前进方向上不存在障碍物。其中,第二区域中的第二基准子区域与第一区域中的第一基准子区域对应。
需要说明的是,判断第一区域中,机器人的前进方向上是否存在障碍物以及,判断第二区域中,机器人的前进方向上是否存在障碍物均不是必经步骤,例如,在其他实施方式中,在步骤S605之后,直接执行步骤S606,或者在其他实施方式中,在步骤S601之后直接执行步骤S603,此时只需要根据第一区域中障碍物的情况而控制机器人进行脱困,或者在其他实施方式中,当步骤S602判定出第一区域中,机器人的前进方向上不存在障碍物时,控制机器人直接前进。
同时在其他实施方式中,也可以不对第一区域和第二区域进行子区域的划分,此时在查找不存在障碍物的第一子区域或者第二子区域时,可以直接将相邻两个障碍物之间的区域,确定为第一子区域或者第二子区域,或者为了保证机器人能够顺利通过,将相邻两个障碍物之间且面积大于阈值的子区域,确定为第一子区域或者第二子区域。且此时在确定第一子区域或者第二子区域的形状不固定,也可以将第一子区域或者第二子区域设定为预定形状,也可以根据实际障碍物的分布情况进行设定。
结合图10和图11,当机器人想要从图10中虚线箭头所指的位置运动到图11中虚线箭头所指的位置时,需要通过一个狭小的空间(图10中实线箭头所指处),在现有技术中,由于传感器精度以及膨胀处理等障碍物的影响,狭小空间被填充了,在规划机器人的轨迹时,判定该位置有障碍物,不可通行,从而造成路径规划失败,而在本实施方式中,由于在路径规划失败时,控制机器人进行脱困处理,使机器人运动到空旷空间后,重新规划路径,能够远离障碍物以及虚拟障碍物,从而保证机器人可以通过狭小空间。
参阅图12,图12是本申请电子设备一实施方式的结构示意图。该电子设备200包括处理器210、存储器220以及通信电路230,处理器210分别耦接存储器220、通信电路230,存储器220中存储有程序数据,处理器210通过执行存储器220内的程序数据以实现上述任一项实施方式方法中的步骤,其中详细的步骤可参见上述实施方式,在此不再赘述。
其中,电子设备200可以是控制机器人运动的任何一种类型的设备,在此不做限制。
且电子设备200可以与机器人彼此独立,也可以集成在机器人上。其中,当电子设备200集成在机器人上时,电子设备具体可以是机器人中的处理器。
参阅图13,图13是本申请电子设备一实施方式的结构示意图。该电子设备300包括全局规划模块310、局部规划模块320、侦测模块330以及脱困模块340。
全局规划模块310用于规划机器人的全局运动路径。
局部规划模块320与全局规划模块310连接,用于在全局运动路径规划成功时,规划机器人的局部运动路径。
侦测模块330与全局规划模块310连接,用于在全局运动路径规划失败时,侦测机器人周围的障碍物。
脱困模块340与侦测模块330连接,用于基于机器人周围的障碍物,控制机器人避开障碍物。
其中,在脱困模块340控制机器人避开障碍物后,全局规划模块310再次规划机器人的全局运动路径。
其中,电子设备300在工作时执行上述任一项实施方式中的步骤,详细的步骤可参见上述内容,在此不再赘述。
其中,电子设备300可以是控制机器人运动的任何一种类型的设备,在此不做限制。
且电子设备300可以与机器人彼此独立,也可以集成在机器人上。其中,当电子设备300集成在机器人上时,电子设备具体可以是机器人中的处理器。
参阅图14,图14是本申请计算机可读存储介质一实施方式的结构示意图。该计算机可读存储介质400存储有计算机程序410,计算机程序410能够被处理器执行以实现上述任一项方法中的步骤。
其中,计算机可读存储介质400具体可以为U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等可以存储计算机程序410的装置,或者也可以为存储有该计算机程序410的服务器,该服务器可将存储的计算机程序410发送给其他设备运行,或者也可以自运行该存储的计算机程序410。
参阅图15,图15是本申请计算机程序产品一实施方式的结构示意图。该计算机程序产品500包括计算机程序510,计算机程序510在被处理器执行时实现上述任一项方法中的步骤,其中详细的方法步骤可参见上述实施方式,在此不再详述。
以上所述仅为本申请的实施方式,并非因此限制本申请的专利范围,凡是利用本申请说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本申请的专利保护范围内。
Claims (11)
1.一种机器人的路径规划方法,其特征在于,所述方法包括:
规划所述机器人的全局运动路径;
响应于所述全局运动路径规划成功,则规划所述机器人的局部运动路径;
响应于所述全局运动路径规划失败,则侦测所述机器人周围的障碍物;
获取所述机器人周围第一区域内的所述障碍物;
判断在所述第一区域中,所述机器人的前进方向上是否存在所述障碍物;
响应于在所述第一区域中,所述机器人的所述前进方向上存在所述障碍物,则在所述第一区域不存在所述障碍物的至少一个第一子区域中,查找对应代价值最小的第一子区域,其中,所述第一子区域与所述机器人的前进方向的偏离程度和所述第一子区域对应的所述代价值成正比,且所述第一子区域中距离所述机器人最近的点到所述机器人的距离等于零,距离所述机器人最远的点处于所述第一区域的轮廓上;
控制所述机器人沿着指向对应代价值最小的所述第一子区域的方向运动,以避开所述障碍物;
响应于在所述第一区域中,所述机器人的所述前进方向上不存在所述障碍物,则获取所述第一区域外围第二区域内的所述障碍物;
在所述第一区域不存在所述障碍物的所述第一子区域以及所述第二区域不存在所述障碍物的第二子区域中,查找对应代价值最小的目标子区域,所述第二子区域中距离所述机器人最近的点处于所述第一区域的轮廓上,距离所述机器人最远的点处于所述第二区域的轮廓上,且所述目标子区域包括连通的所述第一子区域以及所述第二子区域;
控制所述机器人沿着指向所述目标子区域的方向运动,以避开所述障碍物;
避开所述障碍物后,返回执行规划所述机器人的全局运动路径的步骤。
2.根据权利要求1所述的方法,其特征在于,在所述规划所述机器人的局部运动路径的步骤之后,所述方法还包括:
判断所述局部运动路径是否规划成功;
响应于所述局部运动路径规划失败,则返回执行所述规划所述机器人的全局运动路径的步骤;
响应于所述局部运动路径规划成功,则控制所述机器人运动至目的地。
3.根据权利要求1所述的方法,其特征在于,在所述第一区域不存在所述障碍物的至少一个第一子区域中,查找对应代价值最小的第一子区域的步骤之前,还包括:
在所述第一区域预先划分的多个子区域中,查找不存在所述障碍物的所述第一子区域,其中,所述子区域中距离所述机器人最近的点到所述机器人的距离等于零,距离所述机器人最远的点处于所述第一区域的轮廓上。
4.根据权利要求1所述的方法,其特征在于,所述判断在所述第一区域中,所述机器人的所述前进方向上是否存在所述障碍物的步骤,包括:
判断所述第一区域中的第一基准子区域中,是否存在所述障碍物,其中,所述机器人的所述前进方向经过所述第一基准子区域;
响应于所述第一基准子区域中存在所述障碍物,则确定所述机器人的所述前进方向上存在所述障碍物;
响应于所述第一基准子区域中不存在所述障碍物,则确定所述机器人的所述前进方向上不存在所述障碍物。
5.根据权利要求1所述的方法,其特征在于,在所述第一区域不存在所述障碍物的所述第一子区域以及所述第二区域不存在所述障碍物的第二子区域中,查找对应代价值最小的目标子区域的步骤之前,还包括:
判断在所述第二区域中,所述机器人的所述前进方向上是否存在所述障碍物;
响应于在所述第二区域中,所述机器人的所述前进方向上存在所述障碍物,则执行所述在所述第一区域不存在所述障碍物的所述第一子区域以及所述第二区域不存在所述障碍物的第二子区域中,查找对应代价值最小的目标子区域的步骤;
响应于在所述第二区域中,所述机器人的前进方向上不存在所述障碍物,则控制所述机器人沿着所述前进方向运动。
6.根据权利要求5所述的方法,其特征在于,在所述第一区域不存在所述障碍物的所述第一子区域以及所述第二区域不存在所述障碍物的第二子区域中,查找对应代价值最小的目标子区域的步骤之前,还包括:
在所述第一区域预先划分的多个子区域中,查找不存在所述障碍物的所述第一子区域;
在所述第二区域预先划分的多个子区域中,查找不存在所述障碍物的所述第二子区域;
其中,所述第一区域中的多个子区域与所述第二区域中的多个子区域一一对应,且对应的两个子区域的对称轴重合,代价值相同。
7.根据权利要求1所述的方法,其特征在于,所述响应于所述全局运动路径规划失败,则侦测所述机器人周围的障碍物的步骤,包括:
响应于所述全局运动路径规划失败,则获取所述全局运动路径规划连续失败的累计次数;
响应于所述累计次数未超过次数阈值,则侦测所述机器人周围的所述障碍物;
响应于所述累计次数超过所述次数阈值,则提示规划失败。
8.根据权利要求1所述的方法,其特征在于,基于所述机器人周围第一区域内的所述障碍物,控制所述机器人避开所述障碍物的步骤,包括:
基于所述机器人周围第一区域内的所述障碍物,控制所述机器人避开所述障碍物,直至所述机器人周围的预设范围内不存在所述障碍物。
9.根据权利要求8所述的方法,其特征在于,所述基于所述机器人周围第一区域内的所述障碍物,控制所述机器人避开所述障碍物,直至所述机器人周围的预设范围内不存在所述障碍物的步骤,包括:
响应于控制所述机器人运动的时长超过时长阈值,则返回执行所述规划所述机器人的全局运动路径的步骤。
10.一种电子设备,其特征在于,所述电子设备包括处理器、存储器以及通信电路,所述处理器分别耦接所述存储器、所述通信电路,所述存储器中存储有程序数据,所述处理器通过执行所述存储器内的所述程序数据以实现如权利要求1-9任一项所述方法中的步骤。
11.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有计算机程序,所述计算机程序能够被处理器执行以实现如权利要求1-9任一项所述方法中的步骤。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210007009.XA CN114594761B (zh) | 2022-01-05 | 2022-01-05 | 机器人的路径规划方法、电子设备及计算机可读存储介质 |
PCT/CN2022/119974 WO2023130766A1 (zh) | 2022-01-05 | 2022-09-20 | 机器人的路径规划方法、电子设备及计算机可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210007009.XA CN114594761B (zh) | 2022-01-05 | 2022-01-05 | 机器人的路径规划方法、电子设备及计算机可读存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114594761A CN114594761A (zh) | 2022-06-07 |
CN114594761B true CN114594761B (zh) | 2023-03-24 |
Family
ID=81804056
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210007009.XA Active CN114594761B (zh) | 2022-01-05 | 2022-01-05 | 机器人的路径规划方法、电子设备及计算机可读存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN114594761B (zh) |
WO (1) | WO2023130766A1 (zh) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114594761B (zh) * | 2022-01-05 | 2023-03-24 | 美的集团(上海)有限公司 | 机器人的路径规划方法、电子设备及计算机可读存储介质 |
CN116125991B (zh) * | 2023-02-27 | 2023-08-15 | 麦岩智能科技(北京)有限公司 | 一种基于面向高端场景的商用服务机器人的禁区脱困、存储介质、设备 |
CN117130368B (zh) * | 2023-09-20 | 2024-09-27 | 未岚大陆(北京)科技有限公司 | 控制方法和割草机器人 |
CN117796711B (zh) * | 2024-02-29 | 2024-06-07 | 杭州华橙软件技术有限公司 | 一种机器人的脱困处理方法、机器人和存储介质 |
Family Cites Families (27)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2007213236A (ja) * | 2006-02-08 | 2007-08-23 | Sharp Corp | 自律走行ロボットの経路計画方法及び自律走行ロボット |
KR101626984B1 (ko) * | 2009-11-16 | 2016-06-02 | 엘지전자 주식회사 | 로봇 청소기 및 이의 제어 방법 |
JP6553350B2 (ja) * | 2014-11-26 | 2019-07-31 | アイシン精機株式会社 | 移動体 |
CN106774347A (zh) * | 2017-02-24 | 2017-05-31 | 安科智慧城市技术(中国)有限公司 | 室内动态环境下的机器人路径规划方法、装置和机器人 |
CN108227523B (zh) * | 2017-11-01 | 2020-01-07 | 深圳乐动机器人有限公司 | 机器人控制方法、装置、存储介质和计算机设备 |
CN108227706B (zh) * | 2017-12-20 | 2021-10-19 | 北京理工华汇智能科技有限公司 | 机器人躲避动态障碍的方法及装置 |
CN108549385B (zh) * | 2018-05-22 | 2021-05-04 | 东南大学 | 一种结合a*算法和vfh避障算法的机器人动态路径规划方法 |
CN108646765A (zh) * | 2018-07-25 | 2018-10-12 | 齐鲁工业大学 | 基于改进a*算法的四足机器人路径规划方法及系统 |
CN109213151A (zh) * | 2018-08-07 | 2019-01-15 | 北京云迹科技有限公司 | 一种路径规划方法和送货机器人 |
CN109753074A (zh) * | 2019-01-28 | 2019-05-14 | 北京猎户星空科技有限公司 | 一种机器人巡航控制方法、装置、控制设备和存储介质 |
CN110058586A (zh) * | 2019-03-12 | 2019-07-26 | 浙江大华技术股份有限公司 | 一种自动导引运输车路径冲突的避让方法及装置 |
CN114942638A (zh) * | 2019-04-02 | 2022-08-26 | 北京石头创新科技有限公司 | 机器人工作区域地图构建方法、装置 |
CN110097212B (zh) * | 2019-04-08 | 2022-03-29 | 华南理工大学 | 一种无人艇高能效协同区域探测方法 |
CN109947114B (zh) * | 2019-04-12 | 2022-03-15 | 南京华捷艾米软件科技有限公司 | 基于栅格地图的机器人全覆盖路径规划方法、装置及设备 |
CN110353573B (zh) * | 2019-06-05 | 2021-08-20 | 深圳市杉川机器人有限公司 | 扫地机器人的脱困方法、扫地机器人、计算设备及存储介质 |
CN111750861B (zh) * | 2020-05-29 | 2024-04-09 | 广州极飞科技股份有限公司 | 优选路径规划方法、装置及电子设备 |
CN111813101B (zh) * | 2020-06-04 | 2024-04-02 | 深圳优地科技有限公司 | 机器人路径规划方法、装置、终端设备及存储介质 |
CN111580530B (zh) * | 2020-06-16 | 2021-10-26 | 福勤智能科技(昆山)有限公司 | 一种定位方法、装置、自主移动设备及介质 |
CN111993415B (zh) * | 2020-07-30 | 2022-04-19 | 广州大学 | 自主巡查机器人及其移动监测方法、装置、自主巡查系统 |
CN111984014B (zh) * | 2020-08-24 | 2024-06-18 | 上海高仙自动化科技发展有限公司 | 机器人的控制方法、装置、机器人和存储介质 |
CN112269381B (zh) * | 2020-10-20 | 2022-06-17 | 安徽工程大学 | 基于改进人工鱼群算法的移动机器人路径规划方法 |
CN112859860B (zh) * | 2021-01-13 | 2024-09-27 | 宁波工业互联网研究院有限公司 | 一种机器人系统及其路径规划方法 |
CN113269837B (zh) * | 2021-04-27 | 2023-08-18 | 西安交通大学 | 一种适用于复杂三维环境的定位导航方法 |
CN113110497B (zh) * | 2021-05-08 | 2024-06-18 | 珠海一微半导体股份有限公司 | 基于导航路径的沿边绕障路径选择方法、芯片及机器人 |
CN113390417A (zh) * | 2021-06-25 | 2021-09-14 | 深圳市优必选科技股份有限公司 | 机器人及其导航方法、装置和计算机可读存储介质 |
CN113791616A (zh) * | 2021-08-25 | 2021-12-14 | 深圳优地科技有限公司 | 路径规划方法、装置、机器人和存储介质 |
CN114594761B (zh) * | 2022-01-05 | 2023-03-24 | 美的集团(上海)有限公司 | 机器人的路径规划方法、电子设备及计算机可读存储介质 |
-
2022
- 2022-01-05 CN CN202210007009.XA patent/CN114594761B/zh active Active
- 2022-09-20 WO PCT/CN2022/119974 patent/WO2023130766A1/zh unknown
Also Published As
Publication number | Publication date |
---|---|
WO2023130766A1 (zh) | 2023-07-13 |
CN114594761A (zh) | 2022-06-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN114594761B (zh) | 机器人的路径规划方法、电子设备及计算机可读存储介质 | |
CN107943025B (zh) | 机器人脱困的处理方法 | |
US10705528B2 (en) | Autonomous visual navigation | |
CN108007452B (zh) | 根据障碍物更新环境地图的方法、装置及机器人 | |
JP5086942B2 (ja) | 経路探索装置、経路探索方法、及び経路探索プログラム | |
CN110008941B (zh) | 可行驶区域检测方法、装置、计算机设备和存储介质 | |
JP2023509406A (ja) | 障害物に対するロボットの回避のためのエッジ経路の選択方法、チップ及びロボット | |
CN108628318B (zh) | 拥堵环境检测方法、装置、机器人及存储介质 | |
CN113156956B (zh) | 机器人的导航方法、芯片及机器人 | |
US10262538B1 (en) | Database management for potential pull-off areas | |
US20200103915A1 (en) | Determining Changes in Marker Setups for Robot Localization | |
CN113190010B (zh) | 一种沿边绕障路径规划方法、芯片及机器人 | |
CN113110497B (zh) | 基于导航路径的沿边绕障路径选择方法、芯片及机器人 | |
CN111552290B (zh) | 一种机器人沿墙找直线的方法及清扫方法 | |
CN113110499B (zh) | 一种通行区域的判定方法、路线搜索方法、机器人及芯片 | |
CN114812539B (zh) | 地图探索、地图使用方法、装置、机器人和存储介质 | |
CN114543815A (zh) | 基于基因调控网络的多智能体导航控制方法、设备及介质 | |
CN112306049B (zh) | 自主机器人及其避障方法、装置和存储介质 | |
CN114136318A (zh) | 一种机器智能导航方法和装置 | |
CN113085848B (zh) | 无人驾驶压路机的控制方法、装置、电子设备及存储介质 | |
CN114594772A (zh) | 机器人、路径规划方法、装置和存储介质 | |
CN116661458A (zh) | 机器人行进控制方法、机器人及存储介质 | |
CN117008595A (zh) | 行进路径规划方法及装置、自移动机器人和存储介质 | |
CN113110473B (zh) | 基于连通性的区域判定方法、芯片及机器人 | |
JP2019212184A (ja) | 車両干渉防止システム、接近判定装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
TA01 | Transfer of patent application right | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20220622 Address after: Room 1152, area B, 11 / F, building 1, 158 Shuanglian Road, Huangpu District, Shanghai, 201702 Applicant after: Midea Group (Shanghai) Co.,Ltd. Applicant after: MIDEA GROUP Co.,Ltd. Address before: 201799 room 1152, block B, floor 11, building 1, No. 158 Shuanglian Road, Qingpu District, Shanghai Applicant before: Midea Group (Shanghai) Co.,Ltd. |
|
GR01 | Patent grant | ||
GR01 | Patent grant |