重定位方法、机器人及计算机可读存储介质与流程

文档序号:24291148发布日期:2021-03-17 00:39阅读:103来源:国知局
重定位方法、机器人及计算机可读存储介质与流程

本申请属于机器人技术领域,尤其涉及一种重定位方法、机器人及计算机可读存储介质。



背景技术:

机器人在使用过程中,由于各种原因(如异常掉电等)容易导致机器人的定位失效,因此需要对机器人进行重定位。现有技术中,主要通过模板匹配方法或者梯度匹配方法来进行机器人的重定位,模板匹配方法和梯度匹配方法的核心都侧重于大块区域或者长边界的匹配影响。但因机器人所构建的地图往往为2d格栅地图,其仅能描述物体或者墙壁等同等高度上的边界信息,因此对于长走廊区域或者多墙壁的路口位置,2d格栅地图中所描述的边界信息的相似性较高,使得大块区域或者长边界之间的区分度往往不是很明显,从而造成机器人重定位的误报成功率较高,影响用户体验。



技术实现要素:

本申请实施例提供了一种重定位方法、机器人及计算机可读存储介质,可以有效解决机器人重定位的误报成功率较高的问题,提高用户体验。

第一方面,本申请实施例提供了一种重定位方法,可以包括:

获取机器人所在的目标场景的全局导航地图和当前扫描图,并根据所述全局导航地图生成局部匹配子图;

获取所述局部匹配子图中的黑色边界,确定所述黑色边界的长度以及确定所述黑色边界的曲线复杂度,并根据所述黑色边界的长度和曲线复杂度确定所述黑色边界的匹配权重;

根据所述局部匹配子图和所述当前扫描图确定重定位的估计位姿和目标黑色边界,并根据所述目标黑色边界的匹配权重获取所述当前扫描图与所述局部匹配子图之间的匹配值,所述目标黑色边界为所述局部匹配子图与所述当前扫描图之间相匹配的黑色边界;

当所述匹配值大于预设的匹配阈值时,将所述估计位姿确定为所述机器人重定位的位姿。

可选的,所述确定所述黑色边界的长度,可以包括:

获取所述黑色边界所包含的黑色像素点的数量,并将所述黑色像素点的数量确定为所述黑色边界的长度。

在第一方面的一种可能的实现方式中,所述确定所述黑色边界的曲线复杂度,可以包括:

当所述黑色边界的长度小于预设的基准长度时,将所述黑色边界的曲线复杂度确定为预设值;

当所述黑色边界的长度大于或等于所述基准长度时,以所述黑色边界的一个端点为圆心、以所述基准长度为半径绘制第一圆形,并获取所述第一圆形与所述黑色边界的交点;

确定所述黑色边界中位于所述圆心与所述交点之间的目标黑色像素点,并确定所述目标黑色像素点与目标直线之间的距离,所述目标直线为根据所述圆心和所述交点确定的直线;

当所述距离中存在大于预设距离阈值的距离时,将所述黑色边界的曲线复杂度增加一个计数单位;

以所述交点为圆心、以所述基准长度为半径绘制第二圆形;

当所述第二圆形与所述黑色边界之间存在新的交点时,则返回执行所述确定所述黑色边界中位于所述圆心与所述交点之间的目标黑色像素点,并确定所述目标黑色像素点与目标直线之间的距离的步骤以及后续步骤,直至所述第二圆形与所述黑色边界之间不存在新的交点,得到所述黑色边界的曲线复杂度。

可选的,所述根据所述黑色边界的长度和曲线复杂度确定所述黑色边界的匹配权重,可以包括:

根据下述公式计算得到所述黑色边界的匹配权重:

其中,wi为第i条黑色边界的匹配权重,di(r)为第i条黑色边界的曲线复杂度,li为第i条黑色边界的长度,r为基准长度。

示例性的,所述根据所述全局导航地图生成局部匹配子图,可以包括:

确定自适应匹配区域;

对所述全局导航地图进行预处理,得到优化导航地图;

根据所述自适应匹配区域和所述优化导航地图生成所述局部匹配子图。

在第一方面的一种可能的实现方式中,所述确定自适应匹配区域,可以包括:

获取重定位的定位模式;

当所述定位模式为全局重定位时,获取所述机器人的全局定位位置以及导航失效前所述机器人所在的第一位置,并根据所述全局定位位置和所述第一位置生成所述自适应匹配区域;

当所述定位模式为局部重定位时,获取所述机器人的全局定位位置、导航失效前所述机器人所在的第一位置以及用户指定的第二位置,并根据所述全局定位位置、所述第一位置以及所述第二位置生成所述自适应匹配区域。

可选的,所述根据所述全局定位位置和所述第一位置生成所述自适应匹配区域,可以包括:

以所述全局定位位置为圆心、以第一预设长度为半径绘制第三圆形,并以所述第一位置为圆心、以所述第一预设长度为半径绘制第四圆形;

当所述第三圆形与所述第四圆形相交或者相容时,将包含所述第三圆形与所述第四圆形的最小外接矩形确定为所述自适应匹配区域;

当所述第三圆形与所述第四圆形相离,或者所述第四圆形不存在时,将以所述全局定位位置为中心点、以第二预设长度为边长的矩形区域确定为所述自适应匹配区域。

第二方面,本申请实施例提供了一种重定位装置,可以包括:

匹配子图生成模块,用于获取机器人所在的目标场景的全局导航地图和当前扫描图,并根据所述全局导航地图生成局部匹配子图;

匹配权重确定模块,用于获取所述局部匹配子图中的黑色边界,确定所述黑色边界的长度以及确定所述黑色边界的曲线复杂度,并根据所述黑色边界的长度和曲线复杂度确定所述黑色边界的匹配权重;

匹配值确定模块,用于根据所述局部匹配子图和所述当前扫描图确定重定位的估计位姿和目标黑色边界,并根据所述目标黑色边界的匹配权重获取所述当前扫描图与所述局部匹配子图之间的匹配值,所述目标黑色边界为所述局部匹配子图与所述当前扫描图之间相匹配的黑色边界;

位姿确定模块,用于当所述匹配值大于预设的匹配阈值时,将所述估计位姿确定为所述机器人重定位的位姿。

第三方面,本申请实施例提供了一种机器人,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述第一方面中任一项所述的重定位方法。

第四方面,本申请实施例提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现上述第一方面中任一项所述的重定位方法。

第五方面,本申请实施例提供了一种计算机程序产品,当计算机程序产品在机器人上运行时,使得机器人执行上述第一方面中任一项所述的重定位方法。

可以理解的是,上述第二方面至第五方面的有益效果可以参见上述第一方面中的相关描述,在此不再赘述。

本申请实施例与现有技术相比存在的有益效果是:

本申请实施例中,在需要进行机器人的重定位时,获取机器人所在的目标场景的全局导航地图和当前扫描图,并根据所述全局导航地图生成局部匹配子图;获取所述局部匹配子图中的黑色边界,确定所述黑色边界的长度以及确定所述黑色边界的曲线复杂度,并根据所述黑色边界的长度和曲线复杂度确定所述黑色边界的匹配权重;根据所述局部匹配子图和所述当前扫描图确定重定位的估计位姿和目标黑色边界,并根据所述目标黑色边界的匹配权重获取所述当前扫描图与所述局部匹配子图之间的匹配值,所述目标黑色边界为所述局部匹配子图与所述当前扫描图之间相匹配的黑色边界;当所述匹配值大于预设的匹配阈值时,将所述估计位姿确定为所述机器人重定位的位姿,以根据黑色边界的长度和曲线复杂度来设定黑色边界的匹配权重,提高小件物体或者细小区域的匹配影响,从而有效解决重定位中高误报成功率的问题,提高重定位的鲁棒性,提升用户体验。

附图说明

为了更清楚地说明本申请实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。

图1是本申请一实施例提供的重定位方法的流程示意图;

图2是本申请一实施例提供的确定自适应匹配区域的流程示意图;

图3和图4是本申请实施例提供的确定自适应匹配区域的应用场景示意图;

图5是本申请一实施例提供的确定黑色边界的曲线复杂度的流程示意图;

图6是本申请一实施例提供的对全局导航地图进行预处理的流程示意图;

图7是本申请一实施例提供的重定位装置的结构示意图;

图8是本申请一实施例提供的终端设备的结构示意图。

具体实施方式

以下描述中,为了说明而不是为了限定,提出了诸如特定系统结构、技术之类的具体细节,以便透彻理解本申请实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本申请。在其它情况中,省略对众所周知的系统、装置、电路以及方法的详细说明,以免不必要的细节妨碍本申请的描述。

应当理解,当在本申请说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。

还应当理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。

如在本申请说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。

另外,在本申请说明书和所附权利要求书的描述中,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。

在本申请说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。

机器人在使用过程中,由于各种原因(如异常掉电等)容易导致机器人的定位失效,因此需要对机器人进行重定位。现有技术中,主要通过模板匹配方法或者梯度匹配方法来进行机器人的重定位,模板匹配方法和梯度匹配方法的核心都侧重于大块区域或者长边界的匹配影响。但因机器人所构建的地图往往为2d格栅地图,其仅能描述物体或者墙壁等同等高度上的边界信息,因此对于长走廊区域或者多墙壁的路口位置,2d格栅地图中所描述的边界信息的相似性较高,使得大块区域或者长边界之间的区分度往往不是很明显,从而造成机器人重定位的误报成功率较高,影响用户体验。

其中,误报成功是指机器人在栅格地图中重定位的位姿不是当前机器人所处位置和朝向在地图中的真实映射,即误报成功是指机器人将一个错误的位姿确定为了机器人重定位的位姿。

为解决上述技术问题,现有技术往往通过增加相机来引入丰富、复杂的视觉特征,从而利用丰富、复杂的视觉特征的匹配来降低机器人重定位的误报成功率,提高重定位的鲁棒性。虽然通过增加相机可以在一定程度上解决机器人重定位的误报成功率较高的问题,但却会带来极高的硬件成本,难以在实际场景中广泛使用。

为解决上述技术问题,本申请实施例提供了一种重定位方法,该方法在需要进行机器人的重定位时,可以根据黑色边界的长度和曲线复杂度来设定黑色边界的匹配权重,提高小件物体或者细小区域在重定位中的匹配影响,从而可以在不增加硬件成本的基础上,有效解决重定位中高误报成功率的问题,提高重定位的鲁棒性,提升用户体验。

请参阅图1,图1是本申请实施例提供的重定位方法的流程示意图。其中,所述重定位方法可以应用于机器人、手机、平板电脑、可穿戴设备等具有定位功能的终端设备上,本申请实施例对终端设备的具体类型不作任何限制,以下将以终端设备为机器人为例进行示例性说明。如图1所示,所述重定位方法可以包括:

s101、获取机器人所在的目标场景的全局导航地图和当前扫描图,并根据所述全局导航地图生成局部匹配子图;

其中,目标场景是指机器人当前所在位置对应的场景。全局导航地图是指通过激光同步定位与建图(simultaneouslocalizationandmapping,slam)技术对包含目标场景的环境进行地图构建所得到的2d格栅地图。全局导航地图中的一个图像像素可以对应实际场景中的一个5cm*5cm的正方形区域。当前扫描图是指机器人在其当前所在位置处,采集单帧或者多帧的激光扫描数据,并根据激光扫描数据生成的图像。类似的,当前扫描图中的一个图像像素也对应实际应用场景中的一个5cm*5cm的正方形区域。

在全局导航地图和当前扫描图中,黑色区域表示激光扫描到的物体或者墙壁等的边界,白色区域表示机器人可通行的区域,而灰色区域表示机器人未知的区域。黑色边界的长短和曲线复杂度一定程度上决定了物体或者墙壁的可被轻易移动或者改变的属性。其中,黑色边界越长、曲线复杂度越小,在真实场景中通常代表的是不会被轻易移动或者改变的大件物体或者墙壁等;反之,则代表能被轻易移动或者改变的小件物体,例如沙发、桌椅等。

可选地,在根据全局导航地图生成局部匹配子图之前,可以先对全局导航地图进行预处理,生成单像素宽度的黑色边界和无独立黑色像素点区域的优化导航地图,以避免黑色边界中多余的黑色像素点影响黑色边界的匹配权重的确定,并避免激光自身噪点对机器人重定位的影响。同时,可以确定自适应匹配区域。然后,可以根据自适应匹配区域和优化导航地图生成局部匹配子图。具体地,可以将优化导航地图中与自适应匹配区域相对应的局部区域确定为局部匹配子图。

其中,对全局导航地图进行预处理的内容将在后续进行详细描述。下面先介绍自适应匹配区域的确定过程。请参阅图2,图2示出了本申请实施例提供的确定自适应匹配区域的流程示意图。如图2所示,所述确定自适应匹配区域可以包括:

s201、获取重定位的定位模式;

重定位的定位模式可以包括全局重定位和局部重定位。本申请实施例可以根据重定位时,用户是否指定位置来确定重定位的定位模式。具体地,当用户指定位置,且所指定的位置为有效位置时,则可以确定定位模式为局部重定位。当用户未指定位置,或者所指定的位置为无效位置时,则可以确定定位模式为全局重定位。有效位置是指该位置位于全局导航地图中的白色区域,无效位置是指该位置位于全局导航地图中的黑色区域或者灰色区域。用户可以通过在全局导航地图中进行位置输入或者点击特定位置来进行位置指定。

s202、当所述定位模式为全局重定位时,获取所述机器人的全局定位位置以及导航失效前所述机器人所在的第一位置,并根据所述全局定位位置和所述第一位置生成所述自适应匹配区域;

本申请实施例中,全局定位位置可以根据视觉粗重定位算法来确定,该视觉粗重定位算法可以基于词袋模型(bagofwords,bow)技术来实现。示例性的,在通过激光slam技术进行地图构建中,每生成一帧激光关键帧时,可以同步采集一帧当前时刻的图像,利用词袋模型对该帧图像处理,并将该激光关键帧对应的位姿与该帧图像进行关联保存。在进行重定位时,可以采集机器人当前所在位置的图像,然后可以通过词袋模型对该图像进行相似检索,如果检索到与该图像对应的目标图像,则可以将该目标图像所对应的位姿中的位移信息确定为全局定位位置,否则可以认为全局定位位置不存在。其中,目标图像为地图构建中同步采集的图像中的任一帧图像。

具体地,所述根据所述全局定位位置和所述第一位置生成所述自适应匹配区域,可以包括:

s2021、以所述全局定位位置为圆心、以第一预设长度为半径绘制第三圆形,并以所述第一位置为圆心、以所述第一预设长度为半径绘制第四圆形;

s2022、当所述第三圆形与所述第四圆形相交或者相容时,将包含所述第三圆形与所述第四圆形的最小外接矩形确定为所述自适应匹配区域;

s2023、当所述第三圆形与所述第四圆形相离,或者所述第四圆形不存在时,将以所述全局定位位置为中心点、以第二预设长度为边长的矩形区域确定为所述自适应匹配区域。

对于上述s2021至s2023,当全局定位位置和第一位置存在且均为有效位置时,则可以分别以全局定位位置l0和第一位置l1为圆心、以第一预设长度为半径画圆,得到第三圆形和第四圆形。如图3中的(a)所示,若第三圆形301与第四圆形302相交或者相容,则合并两圆所覆盖的范围,并将所覆盖范围的最小外接矩形303确定为自适应匹配区域。如图3中的(b)所示,若第三圆形301与第四圆形302相离,则可以将以全局定位位置l0为中心点、以第二预设长度为边长的正方形区域304确定为自适应匹配区域。自适应匹配区域的描述格式可以为左上角的起始坐标以及该区域所对应的区域长度和区域宽度。

应理解,本申请实施例中的相容是指第三圆形与第四圆形重合。相离是指第三圆形与第四圆形外离。第一预设长度和第二预设长度可以根据具体情况确定,例如,可以将第一预设长度确定为100像素,即对应的实际距离为5m,将第二预设长度确定为140像素,即对应的实际距离为7m。

当第一位置不存在或者为无效位置时,可以将以全局定位位置为中心、以第二预设长度为边长的正方形区域确定为自适应匹配区域,即可以将图3中的(b)所示的正方形区域确定为自适应匹配区域。当全局定位位置不存在或者为无效位置时,则可以直接返回重定位失败,并退出全局重定位的定位模式。

s203、当所述定位模式为局部重定位时,获取所述机器人的全局定位位置、导航失效前所述机器人所在的第一位置以及用户指定的第二位置,并根据所述全局定位位置、所述第一位置以及所述第二位置生成所述自适应匹配区域。

具体地,所述根据所述全局定位位置、所述第一位置以及所述第二位置生成所述自适应匹配区域可以包括:

s2031、以所述全局定位位置为圆心、以所述第一预设长度为半径绘制第三圆形,以所述第一位置为圆心、以所述第一预设长度为半径绘制第四圆形,并以所述第二位置为圆心、以所述第一预设长度为半径绘制第五圆形;

s2032、当所述第五圆形与所述第三圆形相交或者相容,且所述第五圆形与所述第四圆形相交或者相容时,将包含所述第三圆形、所述第四圆形以及所述第五圆形的最小外接矩形确定为所述自适应匹配区域;

s2033、当所述第五圆形与所述第三圆形相离,或者所述第五圆形与所述第四圆形相离时,将以所述第二位置为中心点、以所述第二预设长度为边长的矩形区域确定为所述自适应匹配区域。

对于上述s2031至s2033,在局部重定位中,用户指定的第二位置l2一般为有效位置。此时,当全局定位位置l0和第一位置l1存在且均为有效位置时,则可以分别以全局定位位置l0、第一位置l1和第二位置l2为圆心、以第一预设长度为半径画圆,得到第三圆形401、第四圆形402和第五圆形403。如图4中的(a)所示,若第五圆形403与第三圆形401相交或者相容,且第五圆形403与第四圆形402相交或者相容,则合并三个圆形所覆盖的范围,并将所覆盖范围的最小外接矩形404确定为自适应匹配区域。如图4中的(b)和(c)所示,若第五圆形403与第四圆形402相离,或者第五圆形403与第三圆形401相离,则可以将以第二位置l2为中心、以第二预设长度为边长的正方形区域405确定为自适应匹配区域。同样地,第一预设长度可以为100像素,第二预设长度可以为140像素。

当全局定位位置不存在或者为无效位置,或者当第一位置不存在或者为无效位置时,可以将以第二位置为中心、以第二预设长度为边长的正方形区域确定为自适应匹配区域。

s102、获取所述局部匹配子图中的黑色边界,确定所述黑色边界的长度以及确定所述黑色边界的曲线复杂度,并根据所述黑色边界的长度和曲线复杂度确定所述黑色边界的匹配权重;

本申请实施例中,在生成局部匹配子图后,可以利用黑色像素的区域生长算法来获取局部匹配子图中的黑色边界。区域生长算法中的种子点可以按照从左向右、从上向下的顺序在全局导航地图中进行选取,其中,所选取的种子点为选取当前未被划分至任一黑色边界的黑色像素点。

示例性的,黑色边界的长度可以使用黑色边界所包含的黑色像素点的数量来衡量。即对于任一条黑色边界,可以获取该黑色边界所包含的黑色像素点的数量,并可以将黑色像素点的数量确定为该黑色边界的长度。例如,当某一黑色边界所包含的黑色像素点的数量为6个时,则可以确定该黑色边界的长度为6个像素。

在确定黑色边界的长度后,则可以根据黑色边界的长度来确定黑色边界的曲线复杂度。请参阅图5,图5示出了本申请实施例提供的确定黑色边界的曲线复杂度的流程示意图。如图5所示,所述确定所述黑色边界的曲线复杂度可以包括:

s501、获取所述黑色边界的长度;

s502、当所述黑色边界的长度小于预设的基准长度时,将所述黑色边界的曲线复杂度确定为预设值;

其中,黑色边界的曲线复杂度是指黑色边界的分形维数。预设的基准长度和预设值可以根据具体情况设置。例如,可以将基准长度r设置为10个像素,可以将预设值设置为0。即对于每一条黑色边界,当该黑色边界的长度小于10个像素时,则可以将该黑色边界的曲线复杂度设置为0。

s503、当所述黑色边界的长度大于或等于所述基准长度时,以所述黑色边界的一个端点为圆心、以所述基准长度为半径绘制第一圆形,并获取所述第一圆形与所述黑色边界的交点;

s504、确定所述黑色边界中位于所述圆心与所述交点之间的目标黑色像素点,并确定所述目标黑色像素点与目标直线之间的距离,所述目标直线为根据所述圆心和所述交点确定的直线;

s505、当所述距离中存在大于预设的距离阈值的距离时,将所述黑色边界的曲线复杂度增加一个计数单位;

s506、以所述交点为圆心、以所述基准长度为半径绘制第二圆形;

s507、当所述第二圆形与所述黑色边界之间存在新的交点时,则返回执行所述确定所述黑色边界中位于所述圆心与所述交点之间的目标黑色像素点,并确定所述目标黑色像素点与目标直线之间的距离的步骤以及后续步骤,直至所述第二圆形与所述黑色边界之间不存在新的交点,得到所述黑色边界的曲线复杂度。

对于上述s503至s507,对于每一条黑色边界,当该黑色边界的长度大于或者等于基准长度r时,即当黑色边界的长度大于或者等于10个像素时,可以将该黑色边界的一端点作为起点,并以该起点为圆心画一个半径为基准长度的第一圆形,第一圆形可以与该黑色边界相交于另一点,所相交的点即为第一圆形与该黑色边界之间的交点。然后,可以确定包含该起点与该交点的直线,并确定该黑色边界上位于该起点与该交点之间的目标黑色像素点,并计算各目标黑色像素点与该直线之间的距离。若存在至少一个目标像素点与该直线之间的距离大于预设的距离阈值,则可以将该黑色边界的曲线复杂度增加一个计数单位,例如增加一个像素;否则该黑色边界的曲线复杂度保持不变。其中,预设的距离阈值可以根据具体情况设置,例如可以将距离阈值设置为2个像素,对于每一条黑色边界,该黑色边界的曲线复杂度的初始值可以为0。然后,再以上述交点为起点,并以该起点为圆心画一个半径为基准长度的第二圆形,并确定第二圆形与该黑色边界之间是否存在新的交点,依次类推执行上述操作,直至该黑色边界上无新的交点生成,此时,所得到的曲线复杂度即为该黑色边界的曲线复杂度。

其中,新的交点是指除已作为起点以外的交点,即新的交点为除前述所绘制的圆形的圆心以外的点。例如,当第一次绘制的第二圆形与该黑色边界之间存在交点a和交点b,而交点a为第一圆形的圆心时,则此时的第二圆形与该黑色边界之间存在的新的交点为交点b。例如,当第二次绘制的第二圆形与该黑色边界之间存在交点c和交点d,而交点c为第一次绘制的第二圆形的圆心时,则此时的第二圆形与该黑色边界之间存在的新的交点为交点d。

示例性的,所述根据所述黑色边界的长度和曲线复杂度确定所述黑色边界的匹配权重包括:

根据下述公式计算得到所述黑色边界的匹配权重:

其中,wi为第i条黑色边界的匹配权重,di(r)为第i条黑色边界的曲线复杂度,li为第i条黑色边界的长度,r为基准长度。

由s501至s507可知,对于大件物体或者墙壁等,其所具有的黑色边界的长度较长或者曲线复杂度较小,而对于小件物体,其所具有的黑色边界的长度较小或者曲线复杂度较大,因此在根据上述公式进行黑色边界的匹配权重的设置时,可以使得大件物体或者墙壁等的黑色边界具有相对较小的匹配权重,使得小件物体或者细小区域等的黑色边界具有相对较大的匹配权重,以通过提高小件物体或者细小区域的匹配权重,来提高小件物体或者细小区域等在重定位中的匹配影响,从而可以在不增加硬件成本的基础上,降低重定位的误报成功率,提高重定位的鲁棒性。

本申请实施例中,也可以在获取全局导航地图后,通过区域生长算法获取全局导航地图中的所有黑色边界,并可以利用上述的确定方式确定出所有黑色边界的匹配权重。因此,当需要进行机器人重定位时,可以在确定局部匹配子图后,直接根据全局导航地图中的黑色边界以及黑色边界的匹配权重,来获取局部匹配子图中的黑色边界以及黑色边界的匹配权重,可以有效减少重定位中,黑色边界以及黑色边界的匹配权重的确定过程,提高重定位效率。

需要说明的是,在得到局部匹配子图中各黑色边界的匹配权重后,可以对匹配权重进行归一化处理,以方便后续处理。具体地,可以将各黑色边界的匹配权重与所有黑色边界的匹配权重之和的比值,确定为各黑色边界归一化后的匹配权重。例如,在局部匹配子图包括黑色边界a、黑色边界b、黑色边界c和黑色边界d,且黑色边界a的匹配权重为wa,黑色边界b的匹配权重为wb,黑色边界c的匹配权重为wc,黑色边界d的匹配权重为wd时,黑色边界a归一化后的匹配权重可以为wa/(wa+wb+wc+wd),黑色边界b归一化后的匹配权重可以为wb/(wa+wb+wc+wd),黑色边界c归一化后的匹配权重可以为wc/(wa+wb+wc+wd),黑色边界d归一化后的匹配权重可以为wd/(wa+wb+wc+wd)。

s103、根据所述局部匹配子图和所述当前扫描图确定重定位的估计位姿和目标黑色边界,并根据所述目标黑色边界的匹配权重获取所述当前扫描图与所述局部匹配子图之间的匹配值,所述目标黑色边界为所述局部匹配子图与所述当前扫描图之间相匹配的黑色边界;

具体地,可以利用模板匹配方法或者梯度匹配方法,获取局部匹配子图与当前扫描图之间相匹配的目标黑色边界,并确定重定位的估计位姿。其中,当局部匹配子图中的某一条黑色边界在当前扫描图中存在一条独立的黑色边界与之紧密贴合或者重合,则局部匹配子图中的该黑色边界即为目标黑色边界。在确定局部匹配子图中的所有目标黑色边界后,可以将各目标黑色边界的匹配权重进行相加,以作为当前扫描图与局部匹配子图之间的匹配值s0。其中,黑色边界之间是否紧密贴合或者重合,可以根据黑色边界之间的相似度确定,相似度的确定方式可以为现有技术的任一方式,本申请实施例对此不作具体限定。

可以理解的是,利用模板匹配方法或者梯度匹配方法进行位姿确定为现有技术,本申请实施例对此不作限定。

s104、当所述匹配值大于预设的匹配阈值时,将所述估计位姿确定为所述机器人重定位的位姿。

其中,预设的匹配阈值可以根据具体情况设置,例如,可以将预设的匹配阈值设置为0.85至0.95之间的任一数值。因此,当前扫描图与局部匹配子图之间的匹配值s0大于匹配阈值时,表示此次重定位成功,并将估计位姿确定为重定位的位姿。否则,可以认为此次重定位失败,并输出失败反馈信息,以及建议选择其他位置重新进行重定位。

下面将对全局导航地图进行预处理进行详细描述。请参阅图6,图6示出了对全局导航地图进行预处理的流程示意图。如图6所示,对全局导航地图进行预处理,可以包括:

s601、对所述全局导航地图进行三值化处理,得到三值地图。

所述全局导航地图中的各个像素点的像素值范围一般为[0,255],为方便处理,可以对所述全局导航地图进行三值化处理,将各个像素点的像素值仅设置为0、205和255三种,分别表示黑色、灰色和白色,从而得到三值地图。在本申请实施例的一种具体实现中,可以根据下式对所述全局导航地图进行三值化处理:

其中,i0(x,y)、i1(x,y)分别为所述全局导航地图和所述三值地图中的任意一个像素点的像素值,minpixel、maxpixel均为预设的像素阈值,其具体取值可以根据具体情况进行设置,本申请实施例中根据工程实践,优选将minpixel设置为50,将maxpixel设置为240。当所述全局导航地图中的某一像素点的像素值小于minpixel时,那么在所述三值地图中与该像素点相同位置的像素点的像素值即为0,当所述全局导航地图中的某一像素点的像素值大于或等于minpixel且小于maxpixel时,那么在所述三值地图中与该像素点相同位置的像素点的像素值即为205,当所述全局导航地图中的某一像素点的像素值大于或等于maxpixel时,那么在所述三值地图中与该像素点相同位置的像素点的像素值即为255。

s602、对所述三值地图进行二值化处理,得到二值地图。

对所述三值地图进行二值化处理,也即将各个像素点的像素值仅设置为0和255两种,分别表示黑色和白色,从而得到二值地图。具体地,二值化时需要对所述三值地图逐个像素遍历,如果其像素值为205或者255,即灰色或白色,则将所述二值地图对应位置的像素值设置为255,即白色;如果其像素值为黑色0,需在以其位置为中心,3×3网格范围内判断其是否存在黑色像素相连或者灰黑白相连的有效结构,存在,说明是有效的物体或者墙壁的边界,则所述二值地图对应位置的像素值需要保持黑色0,否则,其很可能是孤立的传感器噪点,需要过滤掉,故将所述二值地图对应位置像素设置为白色255。

s603、对所述三值地图和所述二值地图进行边界填充,得到三值填充地图和二值填充地图。

首先,提取所述二值地图的黑色边界。本申请实施例中可以利用区域生长算法提取并保存所述二值地图中的所有黑色边界,所述区域生长算法实现既可基于广度优先遍历,也可基于深度优先遍历。

然后,分别以所述二值地图的黑色边界中的各个黑色像素点为中心,对所述三值地图和所述二值地图进行边界填充,得到所述三值填充地图和所述二值填充地图。

以所述二值地图的黑色边界中的任意一个黑色像素点为例,边界填充的具体过程可以包括:

步骤a、在三值目标像素点的八邻域中查找白色像素点。

所述三值目标像素点为在所述三值地图中与二值目标像素点相同位置的像素点,所述二值目标像素点为所述二值地图的黑色边界中的任意一个像素点。

若查找到白色像素点,则执行步骤b,若未查找到白色像素点,则无需进行任何处理。

步骤b、依次记录在重影检测线上扫描到的各个像素点,直至扫描到灰色像素点为止。

所述重影检测线为由查找到的白色像素点指向所述三值目标像素点的射线。在申请本实施例中,可以预先设置一个在所述重影检测线的方向上最大可扫描的相连像素个数的阈值,将该阈值记为maxdetectedpixel,其具体取值可以根据具体情况进行设置,本申请实施例中优选将其设置为5。一般地,在工程实践中,栅格化地图中一个像素表示5厘米,若此阈值设置为5,因可填充的有效重影检测线必须以黑灰两个相连像素截止,故最大可填充连续3个白色像素宽度的重影区域,即处理间隔不超过15厘米距离的重影。

若记录的像素点的个数小于预设的阈值(即maxdetectedpixel)且记录的最后一个像素点为黑色像素点,则执行步骤c,否则,则无需进行任何处理。

步骤c、对所述二值地图和所述三值地图中的待填充像素点进行填充。

具体地,可以将所述记录的像素点中的白色像素点确定为所述三值地图中的待填充像素点,将所述二值地图中与所述三值地图中的待填充像素点相同位置的像素点确定为所述二值地图中的待填充像素点,最后,将所述二值地图的待填充像素点和所述三值地图中的待填充像素点均设置为黑色像素点。

遍历所述二值地图的黑色边界中的各个黑色像素点,分别执行步骤a至步骤c的过程,对所述三值地图和所述二值地图进行边界填充,最终得到的边界填充后的三值地图即为所述三值填充地图,最终得到的边界填充后的二值地图即为所述二值填充地图,此时,边界重影问题已被转化为边界贴合问题。

s604、对所述二值填充地图进行边界细化,得到二值细化地图。

为了解决边界贴合问题,此处需对地图进行细化处理,即将地图中所有多像素聚集的粗边界都细化为一个像素宽度。本申请实施例中可以采用二值图像边缘细化算法对所述二值填充地图进行边界细化,得到二值细化地图。所述二值图像边缘细化算法包括但不限于hilditch、pavlidis、rosenfeld细化算法以及索引表细化算法等。

s605、根据所述二值细化地图对所述三值填充地图进行边界细化,得到三值细化地图。

在经过边界细化得到的所述二值细化地图中,清除掉了很多多余的黑色像素,改变了墙体或物体的实际边界,故需要执行合并操作,同步更新到所述三值填充地图。具体地,首先可以将所述三值填充地图中与所述二值细化地图中的黑色像素点相同位置的像素点设置为黑色像素点,然后确定所述三值填充地图中的待细化像素点,所述待细化像素点为与所述二值细化地图中的白色像素点相同位置的黑色像素点。若所述待细化像素点的八邻域中的白色像素点数目大于灰色像素点数目,则将所述待细化像素点设置为白色像素点;若所述待细化像素点的八邻域中的白色像素点数目不大于灰色像素点数目,则将所述待细化像素点设置为灰色像素点。经过以上处理,即可得到所述三值细化地图。

在本申请实施例的一种具体实现中,可以直接使用所述三值细化地图作为最终得到的结果,但是考虑到所述三值细化地图虽然已经解决了边界贴合和边界重影的问题,但同时可能加重黑色边界延伸到灰色区域和黑色墙体边界外残留一些黑色物体边界的问题,因此,在申请本实施例的另一种具体实现中,在得到三值细化地图之后,还可以提取所述二值细化地图的黑色边界(与s603中的边界提取过程类似,具体可参照前述内容,此处不再赘述),并分别以所述二值细化地图的黑色边界中的各个黑色像素点为中心,对所述三值细化地图和所述二值细化地图进行优化处理,得到三值优化地图和二值优化地图。

以所述二值细化地图的黑色边界中的任意一个黑色像素点为例,优化处理的具体过程可以包括:

首先,在三值细化目标像素点的八邻域中统计白色像素点的数目。

所述三值细化目标像素点为在所述三值细化地图中与二值细化目标像素点相同位置的像素点,所述二值细化目标像素点为所述二值细化地图的黑色边界中的任意一个像素点。

若统计的白色像素点的数目为0,则表示该黑色边界不与可通行的白色区域相邻,即为黑色边界延伸到灰色区域的情况,该情况不符合激光白黑灰的投射扫描规律,需要被滤除。具体地滤除方式为:将所述三值细化目标像素点设置为灰色像素点,并将所述二值细化目标像素点设置为白色像素点。

若统计的白色像素点的数目大于0,则可判断各条扫描线是否均在预设的距离内被黑色像素点阻隔,所述扫描线为由所述三值细化目标像素点的八邻域中灰色像素点指向所述三值细化目标像素点的射线,容易理解的,扫描线的数目与八邻域中灰色像素点的数目相同,即八邻域中任意一个灰色像素点指向所述三值细化目标像素点的射线均为一条扫描线。该预设的距离记为maxscannedpixel,其具体取值可以根据实际情况进行设置,取值依据为机器人的实际直径与栅格地图中单像素可表示的实际距离的比值,若机器人的实际直径为50公分,且栅格地图一个像素表示5公分距离,则可以将maxscannedpixel设置为10,即最大扫描存储10个像素,判断是否被黑色墙体边界阻隔。如果所述三值细化目标像素点的所有灰黑直线方向的扫描尝试都被黑色边界阻隔,表示所述三值细化目标像素点很可能来自于黑色墙体边界外残留的物体边界。因其白色区域附近不能合理放下该机器人,按其激光白黑灰的投射规律,便不可能产生该边界,故需要被滤除,滤除方式为:将所述三值细化目标像素点以及各条所述扫描线上的白色像素点均设置为灰色像素点,并将所述二值细化目标像素点设置为白色像素点。若至少有一条扫描线在预设的距离内未被黑色像素点阻隔,则无需进行任何处理。

遍历所述二值细化地图的黑色边界中的各个黑色像素点,分别执行上述优化处理过程,对所述三值细化地图和所述二值细化地图进行优化处理,最终得到的优化处理后的三值地图即为所述三值优化地图,最终得到的优化处理后的二值地图即为所述二值优化地图。

本申请实施例中,在需要进行机器人的重定位时,获取机器人所在的目标场景的全局导航地图和当前扫描图,并根据所述全局导航地图生成局部匹配子图;获取所述局部匹配子图中的黑色边界,确定所述黑色边界的长度以及确定所述黑色边界的曲线复杂度,并根据所述黑色边界的长度和曲线复杂度确定所述黑色边界的匹配权重;根据所述局部匹配子图和所述当前扫描图确定重定位的估计位姿和目标黑色边界,并根据所述目标黑色边界的匹配权重获取所述当前扫描图与所述局部匹配子图之间的匹配值,所述目标黑色边界为所述局部匹配子图与所述当前扫描图之间相匹配的黑色边界;当所述匹配值大于预设的匹配阈值时,将所述估计位姿确定为所述机器人重定位的位姿,以根据黑色边界的长度和曲线复杂度来设定黑色边界的匹配权重,提高小件物体或者细小区域的匹配影响,从而有效解决重定位中高误报成功率的问题,提高重定位的鲁棒性,提升用户体验。

对应于上文实施例所述的重定位方法,图7示出了本申请实施例提供的重定位装置的结构框图,为了便于说明,仅示出了与本申请实施例相关的部分。

请参阅图7,所述重定位装置,可以包括:

匹配子图生成模块701,用于获取机器人所在的目标场景的全局导航地图和当前扫描图,并根据所述全局导航地图生成局部匹配子图;

匹配权重确定模块702,用于获取所述局部匹配子图中的黑色边界,确定所述黑色边界的长度以及确定所述黑色边界的曲线复杂度,并根据所述黑色边界的长度和曲线复杂度确定所述黑色边界的匹配权重;

匹配值确定模块703,用于根据所述局部匹配子图和所述当前扫描图确定重定位的估计位姿和目标黑色边界,并根据所述目标黑色边界的匹配权重获取所述当前扫描图与所述局部匹配子图之间的匹配值,所述目标黑色边界为所述局部匹配子图与所述当前扫描图之间相匹配的黑色边界;

位姿确定模块704,用于当所述匹配值大于预设的匹配阈值时,将所述估计位姿确定为所述机器人重定位的位姿。

可选的,所述匹配权重确定模块702,可以包括:

边界长度确定单元,用于获取所述黑色边界所包含的黑色像素点的数量,并将所述黑色像素点的数量确定为所述黑色边界的长度。

在一种可能的实现方式中,所述匹配权重确定模块702,可以包括:

第一复杂度确定单元,用于当所述黑色边界的长度小于预设的基准长度时,将所述黑色边界的曲线复杂度确定为预设值;

第一圆形绘制单元,用于当所述黑色边界的长度大于或等于所述基准长度时,以所述黑色边界的一个端点为圆心、以所述基准长度为半径绘制第一圆形,并获取所述第一圆形与所述黑色边界的交点;

像素点距离确定单元,用于确定所述黑色边界中位于所述圆心与所述交点之间的目标黑色像素点,并确定所述目标黑色像素点与目标直线之间的距离,所述目标直线为根据所述圆心和所述交点确定的直线;

复杂度增加单元,用于当所述距离中存在大于预设距离阈值的距离时,将所述黑色边界的曲线复杂度增加一个计数单位;

第二圆形绘制单元,用于以所述交点为圆心、以所述基准长度为半径绘制第二圆形;

第二复杂度确定单元,用于当所述第二圆形与所述黑色边界之间存在新的交点时,则返回执行所述确定所述黑色边界中位于所述圆心与所述交点之间的目标黑色像素点,并确定所述目标黑色像素点与目标直线之间的距离的步骤以及后续步骤,直至所述第二圆形与所述黑色边界之间不存在新的交点时,得到所述黑色边界的曲线复杂度。

可选的,所述匹配权重确定模块702,还可以包括:

匹配权重确定单元,用于根据下述公式计算得到所述黑色边界的匹配权重:

其中,wi为第i条黑色边界的匹配权重,di(r)为第i条黑色边界的曲线复杂度,li为第i条黑色边界的长度,r为基准长度。

示例性的,所述匹配子图生成模块701,可以包括:

匹配区域确定单元,用于确定自适应匹配区域;

预处理单元,用于对所述全局导航地图进行预处理,得到优化导航地图;

匹配子图生成单元,用于根据所述自适应匹配区域和所述优化导航地图生成所述局部匹配子图。

在一种可能的实现方式中,所述匹配区域确定单元,可以包括:

定位模式确定子单元,用于获取重定位的定位模式;

第一匹配区域确定子单元,用于当所述定位模式为全局重定位时,获取所述机器人的全局定位位置以及导航失效前所述机器人所在的第一位置,并根据所述全局定位位置和所述第一位置生成所述自适应匹配区域;

第二匹配区域确定子单元,用于当所述定位模式为局部重定位时,获取所述机器人的全局定位位置、导航失效前所述机器人所在的第一位置以及用户指定的第二位置,并根据所述全局定位位置、所述第一位置以及所述第二位置生成所述自适应匹配区域。

可选的,所述第一匹配区域确定子单元,可以包括:

第三圆形绘制分单元,用于以所述全局定位位置为圆心、以第一预设长度为半径绘制第三圆形,并以所述第一位置为圆心、以所述第一预设长度为半径绘制第四圆形;

第一匹配区域确定分单元,用于当所述第三圆形与所述第四圆形相交或者相容时,将包含所述第三圆形与所述第四圆形的最小外接矩形确定为所述自适应匹配区域;

第二匹配区域确定分单元,用于当所述第三圆形与所述第四圆形相离,或者所述第四圆形不存在时,将以所述全局定位位置为中心点、以第二预设长度为边长的矩形区域确定为所述自适应匹配区域。

需要说明的是,上述装置/单元之间的信息交互、执行过程等内容,由于与本申请方法实施例基于同一构思,其具体功能及带来的技术效果,具体可参见方法实施例部分,此处不再赘述。

所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述系统中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。

图8为本申请一实施例提供的机器人的结构示意图。如图8所示,该实施例的机器人8包括:至少一个处理器80(图8中仅示出一个)、存储器81以及存储在所述存储器81中并可在所述至少一个处理器80上运行的计算机程序82,所述处理器80执行所述计算机程序82时实现上述任意各个重定位方法实施例中的步骤。

该机器人可包括,但不仅限于,处理器80、存储器81。本领域技术人员可以理解,图8仅仅是机器人8的举例,并不构成对机器人8的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如还可以包括输入输出设备、网络接入设备等。

所述处理器80可以是中央处理单元(centralprocessingunit,cpu),该处理器80还可以是其他通用处理器、数字信号处理器(digitalsignalprocessor,dsp)、专用集成电路(applicationspecificintegratedcircuit,asic)、现场可编程门阵列(field-programmablegatearray,fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。

所述存储器81在一些实施例中可以是所述机器人8的内部存储单元,例如机器人8的硬盘或内存。所述存储器81在另一些实施例中也可以是所述机器人8的外部存储设备,例如所述机器人8上配备的插接式硬盘,智能存储卡(smartmediacard,smc),安全数字(securedigital,sd)卡,闪存卡(flashcard)等。进一步地,所述存储器81还可以既包括所述机器人8的内部存储单元也包括外部存储设备。所述存储器81用于存储操作系统、应用程序、引导装载程序(bootloader)、数据以及其他程序等,例如所述计算机程序的程序代码等。所述存储器81还可以用于暂时地存储已经输出或者将要输出的数据。

本申请实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现可实现上述各个方法实施例中的步骤。

本申请实施例提供了一种计算机程序产品,当计算机程序产品在机器人上运行时,使得机器人执行时实现可实现上述各个方法实施例中的步骤。

所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质至少可以包括:能够将计算机程序代码携带到装置/机器人的任何实体或装置、记录介质、计算机存储器、只读存储器(read-onlymemory,rom)、随机存取存储器(randomaccessmemory,ram)、电载波信号、电信信号以及软件分发介质。例如u盘、移动硬盘、磁碟或者光盘等。在某些司法管辖区,根据立法和专利实践,计算机可读介质不可以是电载波信号和电信信号。

在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。

本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。

在本申请所提供的实施例中,应该理解到,所揭露的装置/机器人和方法,可以通过其它的方式实现。例如,以上所描述的装置/机器人实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。

所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。

以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1