首页 / 专利库 / 联轴器,法兰和接头 / 连杆偏距 / 一种基于SCS包围结构的机器人碰撞检测方法

一种基于SCS包围结构的机器人碰撞检测方法

阅读:45发布:2020-06-04

专利汇可以提供一种基于SCS包围结构的机器人碰撞检测方法专利检索,专利查询,专利分析的服务。并且本 发明 涉及一种基于SCS包围结构的 机器人 碰撞检测 方法。采用D-H方法建立的机器人各杆 坐标系 ;采用包括两个球体和一个圆柱体的SCS包围结构,对机器人 连杆 和关节分别进行包围;求机器人各个SCS包围结构的两个球心坐标;将滚轴 工件 模型以及各个SCS包围结构向世界坐标系中的XY、YZ、XZ三个平面投影,判断滚轴工件模型与各个SCS包围结构的投影在三个平面上是否均相交;如果是,则检测到碰撞发生,重新规划机器人路径;否则,判断是否到达路径终点;如果已到达路径终点,则表明未检测到碰撞发生;如果未到达路径终点,则更新机器人状态。本发明可以比较紧密地对机器人连杆和关节进行包围,普遍适用于在三维空间中连续不定向旋转的柱形结构,加快机器人碰撞检测速度,提高机器人工作的 精度 和效率。,下面是一种基于SCS包围结构的机器人碰撞检测方法专利的具体信息内容。

1.一种基于SCS包围结构的机器人碰撞检测方法,其特征在于,包括以下步骤:
步骤1:采用D-H方法建立的机器人各杆坐标系
步骤2:采用包括两个球体和一个圆柱体的SCS包围结构,对机器人连杆和关节分别进行包围;
步骤3:求机器人各个SCS包围结构的两个球心坐标;
步骤4:将滚轴工件模型以及各个SCS包围结构向世界坐标系中的XY、YZ、XZ三个平面投影,判断滚轴工件模型与各个SCS包围结构的投影在三个平面上是否均相交;
步骤5:如果是,则检测到碰撞发生,重新规划机器人路径,返回步骤3;否则,判断是否到达路径终点;
步骤6:如果已到达路径终点,则表明未检测到碰撞发生;如果未到达路径终点,则更新机器人状态,返回步骤3。
2.根据权利要求1所述的一种基于SCS包围结构的机器人碰撞检测方法,其特征在于,所述采用D-H方法建立的机器人各杆坐标系,具体为:
坐标系{i-1}到坐标系{i}的变化矩阵为:
其中, 分别为坐标系{i}相对坐标系{i-1}的姿态矩阵和位置矩阵;θi是关节i的旋转;βi是关节i和i+1间的扭转角;αi为关节i+1的长度;di是关节i的偏距。
3.根据权利要求1所述的一种基于SCS包围结构的机器人碰撞检测方法,其特征在于,所述SCS包围结构具体为:两个球体的球心分别与圆柱体底面的两个圆心重合,SCS包围结构的球体半径与圆柱体底面半径比值大于或者等于1。
4.根据权利要求1所述的一种基于SCS包围结构的机器人碰撞检测方法,其特征在于,所述采用SCS包围结构,对机器人连杆和关节分别进行包围,使连杆或关节的两端分别在两个球体内部,连杆或者关节的中间部分在圆柱体内部。
5.根据权利要求1所述的一种基于SCS包围结构的机器人碰撞检测方法,其特征在于,所述求机器人各个SCS包围结构的两个球心坐标,具体为:
其中, 分别为坐标系{i}相对坐标系{i-1}的姿态矩阵和位置矩阵,1≤i≤n,P、W分别为坐标系{n}相对于世界坐标系的姿态矩阵和位置矩阵,球心在世界坐标系中的坐标即为(Px,Py,Pz)。
6.根据权利要求1所述的一种基于SCS包围结构的机器人碰撞检测方法,其特征在于,所述将滚轴工件模型以及各个SCS包围结构模型向世界坐标系中的XY、YZ、XZ三个平面投影,判断滚轴工件模型与各个SCS包围结构的投影在三个平面上是否均相交,包括以下步骤:
将SCS包围结构在任一平面上的投影转化为相互连接的三个部分,即第一部分为圆形:
以第一球体的球心在平面上的投影点为圆心,以第一球体的半径为半径的圆;第二部分为矩形:连接SCS包围结构在平面上的两球心投影点,形成线段,过两个投影点分别做所述线段的垂线,两投影点分别为两垂线上线段的中点,其中所述两垂线上线段的长度均等于SCS包围结构中圆柱体底面直径的长度,所述两垂线上的线段在平面上平行且相等,为矩形的一组对边;第三部分为圆形:以第二球体的球心在平面上的投影点为圆心,以第二球体的半径为半径的圆;
判断滚轴工件模型与各个SCS包围结构的投影在三个平面上是否相交,简化为判断在三个平面上,滚轴工件模型的投影与SCS包围结构投影转化后的三个部分是否相交,若在任一平面上两模型的投影不相交,则被检测的结构没有发生碰撞,当且仅当三个平面上两模型的投影均相交时,被检测的结构认定为发生了碰撞。

说明书全文

一种基于SCS包围结构的机器人碰撞检测方法

技术领域

[0001] 本发明属于机器人技术领域,具体的说是一种基于SCS(Sphere-Cylinder-Sphere,球体-圆柱体-球体)包围结构的机器人碰撞检测方法。

背景技术

[0002] 机器人技术是实现先进制造技术的重要基础之一,正不断向高精度、高效率、高协调性方向发展。机器人技术中的多自由度机器人是工业机器人的一种。为了提高机器人运动过程中的安全性,需要设计相应的碰撞检测,避免机器人与工件之间发生碰撞,从而使机器人在各种作业情况下都能安全快速准确地到达给定的位置
[0003] 早期的碰撞检测大多是基于格子或者BSP树的。基于格子的碰撞检测实现简单但精度不够,不属于严格意义的3D碰撞检测。基于BSP树的碰撞检测需要很长的处理时间,占用较多的资源容量。
[0004] 当前多采用基于包围体的碰撞检测算法。包围体技术是在1976年由Clark提出的,基本思想是用一个简单的几何形体将动画场景中的几何形体围住,通过构造树状层次结构来逼近真实的包围体。基于层次包围体的碰撞检测算法根据包围体类型的不同可以区分为:包围球体、AABB轴对齐包围体、OBB有向包围体、K-DOP包围体等。OBB和K-DOP包围体方法虽然紧密性较好,但复杂度比较高,旋转更新慢,不适合多关节机器人在运动过程中需持续旋转这一特点。包围球的方法不需要旋转更新,AABB的旋转更新快,适合工业机器人的碰撞检测,但二者包装的紧密性较差,降低了碰撞检测的精度。由于机器人的关节以及连杆多为柱形,并且机器人在运动过程中各关节和连杆需要不断旋转,持续求解包围体位置比较复杂,因而直接用于碰撞检测的包围球和AABB轴对齐包围体方法有一定的局限性。

发明内容

[0005] 为了克服机器人现有包围体碰撞检测算法的计算速度慢,检测精度低等缺点,本发明提供一种基于SCS包围结构的机器人碰撞检测方法,根据机器人的结构特点,可以大幅度提高碰撞检测效率,同时在一定程度上提高机器人工作过程中的安全性和碰撞检测精度。
[0006] 本发明为实现上述目的所采用的技术方案是:一种基于SCS包围结构的机器人碰撞检测方法,包括以下步骤:
[0007] 步骤1:采用D-H方法建立的机器人各杆坐标系
[0008] 步骤2:采用包括两个球体和一个圆柱体的SCS包围结构,对机器人连杆和关节分别进行包围;
[0009] 步骤3:求机器人各个SCS包围结构的两个球心坐标;
[0010] 步骤4:将滚轴工件模型以及各个SCS包围结构向世界坐标系中的XY、YZ、XZ三个平面投影,判断滚轴工件模型与各个SCS包围结构的投影在三个平面上是否均相交;
[0011] 步骤5:如果是,则检测到碰撞发生,重新规划机器人路径,返回步骤3;否则,判断是否到达路径终点;
[0012] 步骤6:如果已到达路径终点,则表明未检测到碰撞发生;如果未到达路径终点,则更新机器人状态,返回步骤3。
[0013] 所述采用D-H方法建立的机器人各杆坐标系,具体为:
[0014] 坐标系{i-1}到坐标系{i}的变化矩阵为:
[0015]
[0016] 其中, 分别为坐标系{i}相对坐标系{i-1}的姿态矩阵和位置矩阵;θi是关节i的旋转;βi是关节i和i+1间的扭转角;αi为关节i+1的长度;di是关节i的偏距。
[0017] 所述SCS包围结构具体为:两个球体的球心分别与圆柱体底面的两个圆心重合,SCS包围结构的球体半径与圆柱体底面半径比值大于或者等于1。
[0018] 所述采用SCS包围结构,对机器人连杆和关节分别进行包围,使连杆或关节的两端分别在两个球体内部,连杆或者关节的中间部分在圆柱体内部。
[0019] 所述求机器人各个SCS包围结构的两个球心坐标,具体为:
[0020]
[0021]
[0022] 其中, 分别为坐标系{i}相对坐标系{i-1}的姿态矩阵和位置矩阵,1≤i≤n,P、W分别为坐标系{n}相对于世界坐标系的姿态矩阵和位置矩阵,球心在世界坐标系中的坐标即为(Px,Py,Pz)。
[0023] 所述将滚轴工件模型以及各个SCS包围结构模型向世界坐标系中的XY、YZ、XZ三个平面投影,判断滚轴工件模型与各个SCS包围结构的投影在三个平面上是否均相交,包括以下步骤:
[0024] 将SCS包围结构在任一平面上的投影转化为相互连接的三个部分,即第一部分为圆形:以第一球体的球心在平面上的投影点为圆心,以第一球体的半径为半径的圆;第二部分为矩形:连接SCS包围结构在平面上的两球心投影点,形成线段,过两个投影点分别做所述线段的垂线,两投影点分别为两垂线上线段的中点,其中所述两垂线上线段的长度均等于SCS包围结构中圆柱体底面直径的长度,所述两垂线上的线段在平面上平行且相等,为矩形的一组对边;第三部分为圆形:以第二球体的球心在平面上的投影点为圆心,以第二球体的半径为半径的圆;
[0025] 判断滚轴工件模型与各个SCS包围结构的投影在三个平面上是否相交,简化为判断在三个平面上,滚轴工件模型的投影与SCS包围结构投影转化后的三个部分是否相交,若在任一平面上两模型的投影不相交,则被检测的结构没有发生碰撞,当且仅当三个平面上两模型的投影均相交时,被检测的结构认定为发生了碰撞。
[0026] 本发明具有以下优点及有益效果:
[0027] 一是碰撞检测速度快。SCS包围结构普遍适用于在三维空间中连续不定向旋转的柱形结构,机器人的结构特点和运动特点符合这一需求。在碰撞检测阶段,只需定位球心的坐标就可得出碰撞检测结果。
[0028] 二是检测精度较高。采用SCS层次包围结构与大部分工业机器人的结构相吻合,可以比较紧密将机器人包围,提高检测精度。附图说明
[0029] 图1为SCS包围结构截面示意图;
[0030] 图2采用D-H方法建立的MOTOMAN-MH6机器人运动学坐标系;
[0031] 图3为SCS包围结构在平面上的投影转化图;
[0032] 图4基于SCS包围结构的机器人碰撞检测流程图

具体实施方式

[0033] 下面结合附图及实施例对本发明做进一步的详细说明,基于SCS包围结构的机器人碰撞检测方法流程如图4所示。
[0034] 1.在初始阶段,以MOTOMAN-MH6机器人为对象,如图2所示,采用D-H方法建立的机器人各杆坐标系,其中,坐标系{0}三个坐标轴方向与世界坐标系中相应的X、Y、Z坐标轴方向一致,坐标系{i-1}到坐标系{i}的变化矩阵为:
[0035]
[0036] 其中, 分别为坐标系{i}相对坐标系{i-1}的姿态矩阵和位置矩阵;θi是关节i的旋转角;βi是关节i和i+1间的扭转角;αi为关节i+1的长度;di是关节i的偏距。
[0037] 2.采用Sphere-Cylinder-Sphere(球体-圆柱体-球体)包围结构,对机器人连杆和关节分别进行包围。如图1所示,其中:SCS包围结构由球体S1,圆柱体C,以及球体S2组成;两个球体的球心分别与圆柱体底面的两个圆心重合;SCS包围结构的球体半径与圆柱体底面半径比值大于或者等于1;采用SCS包围空间对机器人各个连杆和关节进行包围,并且保证机器人各个连杆和关节在SCS包围结构内部。包围特点为:连杆或者关节的两端分别在两个球体内部,连杆或者关节的中间主体部分在圆柱体内部。
[0038] 3.在碰撞检测阶段一,利用代数解析法求机器人各个SCS包围结构的两个球心坐标。
[0039] 求各个SCS包围结构的两个球心坐标,求解过程为:
[0040]
[0041]
[0042] 其中, 分别为坐标系{i}相对坐标系{i-1}的姿态矩阵和位置矩阵,P、W分别为坐标系{n}相对于世界坐标系的姿态矩阵和位置矩阵,球心在世界坐标系中的坐标即为(Px,Py,Pz)。
[0043] 4.在碰撞检测阶段二,将滚轴工件模型以及各个SCS包围结构向世界坐标系中的XY、YZ、XZ三个平面投影。
[0044] 采用常见的包围结构对滚轴工件模型进行包围,之后向世界坐标系中的XY、YZ、XZ三个平面投影。
[0045] SCS包围结构在任一平面上的投影可以转化为相互连接的三个部分。如图示3所示,第一部分为圆形:以S1的球心在平面上的投影点为圆心,以S1的半径为半径的圆。第二部分为矩形:连接SCS包围结构在平面上的两球心投影点,形成线段O1O2,过两个投影点分别做O1O2的垂线L1,L2,其中O1为L1上线段AB的中点,O2为L2上线段CD的中点,其中AB、CD的长度均等于圆柱体底面直径的长度,矩形ABDC即为所求。第三部分为圆形:以S2的球心在平面上的投影点为圆心,以S2的半径为半径的圆。
[0046] 判断滚轴工件模型与各个SCS包围结构的投影在三个平面上是否相交,可以简化为判断在三个平面上,滚轴工件模型的投影与SCS包围结构模型投影转化后的三个部分是否相交,若在任一平面上两模型的投影不相交,则被检测的结构没有发生碰撞,当且仅当三个平面上两模型的投影均相交时,被检测的结构认定为发生了碰撞。
[0047] 5.在碰撞检测阶段三:如果检测到碰撞发生,重新规划机器人路径,进行碰撞检测;如果未检测到碰撞发生,判断机器人是否到达路径规划终点,若未达到终点,更新机器人状态,进行碰撞检测。
[0048] 在结束阶段:如果在机器人运动路径中始终未检测到碰撞发生,则认定规划路径安全,碰撞检测结束。
高效检索全球专利

专利汇是专利免费检索,专利查询,专利分析-国家发明专利查询检索分析平台,是提供专利分析,专利查询,专利检索等数据服务功能的知识产权数据服务商。

我们的产品包含105个国家的1.26亿组数据,免费查、免费专利分析。

申请试用

分析报告

专利汇分析报告产品可以对行业情报数据进行梳理分析,涉及维度包括行业专利基本状况分析、地域分析、技术分析、发明人分析、申请人分析、专利权人分析、失效分析、核心专利分析、法律分析、研发重点分析、企业专利处境分析、技术处境分析、专利寿命分析、企业定位分析、引证分析等超过60个分析角度,系统通过AI智能系统对图表进行解读,只需1分钟,一键生成行业专利分析报告。

申请试用

QQ群二维码
意见反馈