KR20180125646A - Planning method for robot motion - Google Patents

Planning method for robot motion Download PDF

Info

Publication number
KR20180125646A
KR20180125646A KR1020170059735A KR20170059735A KR20180125646A KR 20180125646 A KR20180125646 A KR 20180125646A KR 1020170059735 A KR1020170059735 A KR 1020170059735A KR 20170059735 A KR20170059735 A KR 20170059735A KR 20180125646 A KR20180125646 A KR 20180125646A
Authority
KR
South Korea
Prior art keywords
node
detection
radius
nodes
coefficient
Prior art date
Application number
KR1020170059735A
Other languages
Korean (ko)
Other versions
KR101937269B1 (en
Inventor
박재한
배지훈
백문홍
Original Assignee
한국생산기술연구원
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by 한국생산기술연구원 filed Critical 한국생산기술연구원
Priority to KR1020170059735A priority Critical patent/KR101937269B1/en
Publication of KR20180125646A publication Critical patent/KR20180125646A/en
Application granted granted Critical
Publication of KR101937269B1 publication Critical patent/KR101937269B1/en

Links

Images

Classifications

    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1656Programme controls characterised by programming, planning systems for manipulators
    • B25J9/1664Programme controls characterised by programming, planning systems for manipulators characterised by motion, path, trajectory planning
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1674Programme controls characterised by safety, monitoring, diagnostic

Landscapes

  • Engineering & Computer Science (AREA)
  • Robotics (AREA)
  • Mechanical Engineering (AREA)
  • Manipulator (AREA)
  • Control Of Position, Course, Altitude, Or Attitude Of Moving Bodies (AREA)

Abstract

The present invention provides a robot motion path planning method capable of establishing a motion path plan even in a dynamic environment. The robot motion path planning method includes: a step (s100) of forming a plurality of nodes and detection nodes in a configuration space; a step (s200) of calculating an extended restitution coefficient by comparing a radius between a node and a neighboring node with a predetermined neighbor radius; a step (s300) of calculating a detection restitution coefficient by determining whether the detection node around each of the nodes is located at an obstacle; a step (s400) of updating a node position; a step (s600) of determining whether a radius difference between the node position updated in the step (s400) and the node position before the update is less than or equal to a predetermined tolerance value; a step (s700) of returning to the step (s200) when the step (s600) is not satisfied; and a step of ending the robot motion path planning method when the step (s700) is satisfied.

Description

로봇 모션 경로 계획방법{PLANNING METHOD FOR ROBOT MOTION}[0001] PLANNING METHOD FOR ROBOT MOTION [0002]

본 발명은 로봇의 모션을 제어하는 방법에 대한 것으로서, 특히 동적환경하에서 장애물과 충돌하지 않도록 로봇 모션의 경로를 계획하는 방법에 대한 것이다.The present invention relates to a method of controlling motion of a robot, and more particularly, to a method of planning a path of a robot motion so as not to collide with an obstacle in a dynamic environment.

일반적으로 로봇은 생산 현장에서의 작업 자동화ㆍ무인화 등을 목적으로 한 매니퓰레이터나 반송 로봇등의 산업용 로봇으로 인간을 대신하여 위험한 작업이나 단순한 반복 작업, 큰 힘을 필요로 하는 작업을 수행하였다.In general, robots are industrial robots such as manipulators and conveyor robots for automation and unmanned operation on the production site. They perform dangerous work, simple repetition work, and work requiring great power on behalf of human.

그러나, 최근에는 인간과 유사한 관절체계를 가지고 인간의 작업 및 생활공간에서 인간과 공존하며 다양한 서비스를 제공하는 인간형 로봇(humanoid robot)의 연구 개발이 활발하게 진행되고 있다.Recently, however, research and development of a humanoid robot, which has a human-like joint system and provides various services coexisting with humans in work and living spaces, is actively under way.

이러한 인간형 로봇은 전기적ㆍ기계적 메커니즘에 의해서 팔이나 손의 동작에 가깝게 운동할 수 있도록 만들어진 매니퓰레이터(manipulator)를 이용하여 작업을 수행한다. Such a humanoid robot performs work using a manipulator which is designed to move close to the motion of an arm or a hand by an electrical and mechanical mechanism.

현재 사용되고 있는 대부분의 매니퓰레이터는 여러 개의 링크(link)들이 서로 연결되어 구성된다. 각 링크들의 연결 부위를 관절(joint)이라 하는데 매니퓰레이터는 이러한 링크와 관절들 사이의 기하학적인 관계에 따라 운동 특성이 결정된다. Most manipulators currently in use are configured with multiple links linked together. The joint of each link is referred to as a joint, and the manipulator determines the motion characteristic according to the geometric relationship between the link and the joints.

이 기하학적인 관계를 수학적으로 표현한 것이 기구학(Kinematics)이며 대부분의 매니퓰레이터는 이러한 기구학적 특성(kinematicscharacteristic)을 가지고 작업을 수행하기 위한 방향(목표점)으로 로봇 선단(end-effector;이하 엔드 이펙터라 한다)을 이동시킨다.The mathematical representation of this geometric relationship is kinematics, and most manipulators have an end-effector (hereafter referred to as end effector) as a direction to perform work with kinematicscharacteristics, .

매니퓰레이터가 주어진 작업(예를 들어, 물체를 잡는 작업)을 수행하기 위해서는 매니퓰레이터가 작업을 수행하기 전의 초기 위치(시작점)에서부터 작업을 수행할 수 있는 즉, 물체를 잡을 수 있는 최종 위치(목표점)까지 매니퓰레이터의 이동 경로를 생성하는 것이 중요하다. In order for a manipulator to perform a given task (for example, to catch an object), the manipulator can perform tasks from the initial position (start point) before the task is performed, that is, to the final position It is important to create a movement path for the manipulator.

매니퓰레이터가 작업 영역 내의 장애물과 충돌하지 않는 충돌 회피 등의 구속 조건을 만족하면서 시작점과 목표점을 연결하는 경로를 계획하는 방법으로 샘플 경로 계획(Sampling Based Path Planning) 방법이 공지되어 있다.A method of sampling based path planning is known as a method of planning a path connecting a starting point and a target point while satisfying constraints such as collision avoidance in which the manipulator does not collide with obstacles in the working area.

이와 관련된 종래기술로서 한국특허공개 제10-2011-15764호가 개시되어 있다.Korean Patent Laid-Open No. 10-2011-15764 discloses a related art related thereto.

상기 종래기술에서는 도 9, 10 에 도시된 바와 같이 작업공간(WS)의 장애물 등을 매핑한 형상공간(CS)(configuration space)에서 샘플 경로 계획 방법을 이용하여 매니퓰레이터의 경로를 생성하는 기술이 공지되어 있다.In the related art, as shown in FIGS. 9 and 10, a technique of generating a path of a manipulator using a sample path planning method in a configuration space (CS) in which an obstacle or the like of a work space WS is mapped is disclosed .

그런데, 샘플 경로 계획(Sampling Based Path Planning) 방법은 산업현장 등과 같이 장애물이 이동하지 않는 정적 환경에 대해 적용이 제한된다.However, the Sampling Based Path Planning method is limited in application to static environments where obstacles do not move, such as industrial sites.

그 이유는 장애물이 움직이는 동적 환경에서는 위치가 변화된 장애물과 충돌하지 않도록 경로를 생성하기 위한 시간이 너무 많이 소요되는 처리시간이라는 구속조건에 빠르게 대응할 수 없기 때문이다.This is because, in a dynamic environment in which an obstacle is moving, a position can not quickly respond to a constraint of processing time which takes too much time to generate a path so as not to collide with a changed obstacle.

또한, 형상 공간 내부로 장애물이 진입하고 퇴출함으로써 발생하는 형상공간(CS)의 크기 내지 부피의 변형을 다루기 위한 연산능력을 구비하지 못하기 때문이다.In addition, it is impossible to have a computing ability to deal with the variation of the size and volume of the shape space CS generated by entering and exiting the obstacle into the shape space.

최근에는 장애물이 변동되는 동적환경 또는 시간에 따라 상황이 변경하는 환경에서의 로봇의 사용에 대한 요구가 증가되고 있으나, 전술한 바와 같이 이러한 동적 환경에서의 로봇의 모션 계획을 수행할 만한 방법이 제시되지 못해 더욱 문제시 되고 있다.In recent years, there has been an increasing demand for use of robots in dynamic environments where obstacles are changed or situations where circumstances change according to time. However, as described above, there is a method to perform motion planning of robots in such a dynamic environment It is becoming more problematic.

본 발명은 전술한 문제점을 해결하기 위한 것으로서, 동적 환경에서도 빠른 연산속도로 장애물을 피하여 이동할 수 있도록 매니퓰레이터의 모션 경로 계획을 수립할 수 있는 로봇 모션 경로 계획 방법을 제공하는 것을 기술적 과제로 한다.SUMMARY OF THE INVENTION It is an object of the present invention to provide a robot motion path planning method capable of establishing a motion path plan of a manipulator so as to avoid an obstacle at a high computational speed even in a dynamic environment.

본 발명은 전술한 과제를 해결하기 위해, 동적환경하에서 로봇의 이동경로를 계획하는 방법으로서, 상기 형상공간(CS)의 내부에 복수의 노드(qi)를 배치하고 상기 복수의 노드(qi)의 각각의 둘레에 일정한 간격으로 검지노드(△qj)를 형성하는 단계(s100);In order to solve the above-mentioned problems, the present invention provides a method of planning a moving path of a robot under a dynamic environment, wherein a plurality of nodes (qi) are arranged inside the shape space (CS) A step (s100) of forming an index node (DELTA qj) at regular intervals around each of them;

상기 하나의 노드(qi)와 이웃하는 노드(qi)의 사이의 반경(r)와 미리 정해진 이웃 반경(rn)를 비교하여 확장반발계수를 하기 식에 의해 연산하는 단계(s200);A step (s200) of comparing the radius r between the one node qi and the adjacent node qi to a predetermined neighboring radius rn to calculate an expansion / repulsion coefficient according to the following equation: s200;

Figure pat00001
Figure pat00001

여기서, 노드(qi), 이웃 노드(qj), 확장 반발계수(Fi 확장)는 방향성을 가지는 벡터임.Here, the node qi, the neighboring node qj, and the expansion / contraction coefficient (F i extension ) are directional vectors.

rij 는 노드(qi)와 노드(qj) 사이의 거리r ij is the distance between node (q i) and node (q j )

ηi 는 이웃하는 노드(qj)의 셋트를 의미함.η i means a set of neighboring nodes (qj).

반발포텐셜함수(f)는 0 < r ≤rn 만족시에는 거리(r)에 반비례하는 임의의 함수로 결정되며, 0 < r ≤rn 불만족시에는 O 으로 결정됨.The repulsive potential function (f) When 0 <r ≤ rn, it is determined as an arbitrary function that is inversely proportional to the distance (r), and when 0 <r ≤rn is unsatisfied, it is determined as O.

상기 각 노드 둘레의 검지노드가 장애물에 위치하는 지 여부를 판단하여 검지반발계수를 하기 식에 의해 연산하는 단계(s300);Determining whether or not the detection node around each node is located at an obstacle, and calculating the detection counterpart coefficient by the following equation (s300);

Figure pat00002
Figure pat00002

충돌검지함수(s)는 하기와 같이 결정됨The collision detection function (s) is determined as follows

s(q) = 1 (형상공간(CS)내 검지노드와 장애물 충돌 발생 경우)s (q) = 1 (when an obstacle collision occurs with the detection node in the shape space (CS))

= 0 (형상공간(CS)내 검지노드와 장애물 충돌 발생하지 않은 경우)    = 0 (no obstacle collision occurred with the detection node in the shape space (CS))

각 노드(qi)에서 하기 식을 이용하여 노드(qi)의 위치를 업데이트 하는 단계(s400);Updating (S400) the position of the node (qi) using the following equation at each node (qi);

Figure pat00003
Figure pat00003

여기서, G1, G2 는 각각 확장반발계수 Fi 확장(k) 및 검지반발계수 Fi 검지(k) 에 대한 게인(gain)값임. Here, G 1, G 2 are each expansion coefficient of restitution F i extension (k) and the restitution coefficient F i index detection gain (gain) ¹ for (k).

상기 단계(s400)에서 업데이트된 노드(qi) 위치 qi(k+1)와 업데이트 전 노드(qi) 위치 qi(k)와의 반경 차이가 미리 정해진 허용치(ε) 이하인지 여부를 판단하는 단계(s600);Determining whether the radius difference between the updated node qi (k + 1) and the updated node qi (qi) position qi (k) is equal to or smaller than a predetermined allowable value? );

Figure pat00004
Figure pat00004

상기 단계(s600)을 만족하지 못하는 경우 상기 단계(s200)으로 복귀하는 단계(s700);Returning to step s200 if the step (s600) is not satisfied (s700);

상기 단계(s700)을 만족하는 경우 로봇 모션 경로 계획 방법을 종료하는 것을 특징으로 한다.If the step (s700) is satisfied, the robot motion path planning method is terminated.

본 발명의 로봇 모션 경로 계획 방법에서, 상기 단계(s400)와 단계(s600) 사이에 이웃반경(rn)을 하기 식에 의해 업데이트하는 단계(s600)를 더 포함하는 것을 특징으로 한다.In the robot motion path planning method of the present invention, the method further includes a step (s600) of updating the neighboring radius rn between the steps (s400) and (s600) by the following equation.

Figure pat00005
Figure pat00005

G 는 게인(gain)값. G is the gain value.

Pd 는 희망하는 반발력의 합의 값으로 미리 정해진 값.Pd is a predetermined value of the sum of desired repulsive forces.

P 는 각 노드에서의 반발력의 합.P is the sum of the repulsive forces at each node.

Figure pat00006
Figure pat00006

△t = tk+1 -tk 로서 k번째 반복과 k+1 번째 반복사이의 시간차이.The time difference between kth iteration and k + 1th iteration as Δt = t k + 1 -t k .

rn(tk)는 k 번째 반복에서의 이웃 반경.r n (t k ) is the neighborhood radius in the kth iteration.

본 발명의 로봇 모션 경로 계획 방법에서, 상기 반발포텐셜함수(f)는 하기 식에 의해 결정되는 것을 특징으로 한다.In the robot motion path planning method of the present invention, the rebound potential function (f) is determined by the following equation.

f = 1/2(1/r-1/rn)2 [0 < r ≤rn 만족] f = 1/2 (1 / r-1 / rn) 2 [0 < r &

= 0 [0 < r ≤rn 만족]  = 0 [0 < r &lt; rn satisfaction]

본 발명의 로봇 모션 경로 계획 방법에서, 상기 단계(s200) 내지 단계(s400)는 각 노드에 대해 분산 쓰레드 방식으로 연산되는 것을 특징으로 한다.In the robotic motion path planning method of the present invention, the steps (s200) to (s400) are characterized by being operated in a distributed thread manner for each node.

본 발명의 로봇 모션 경로 계획 방법에서, 상기 단계(s400)은 즉, 노드(qi) 위치를 업데이트 하는 단계는 각각의 노드(qi)의 위치가 모두 업데이트될 때까지 이미 위치가 업데이트된 노드(qi)에서는 더 이상 위치 업데이트 작업을 하지 않고 대기하는 동기화방식으로 이루어지는 것을 특징으로 한다.In the robot motion path planning method of the present invention, the step (S400), i.e., the step of updating the node (qi) position, updates the position of the updated node (qi) until the position of each node ) Is characterized in that it is performed in a synchronous manner in which it waits without performing a position update operation any more.

본 발명의 로봇 모션 경로 계획 방법에서, 상기 단계(s600) 이후에 노드를 연결하여 최적 경로를 형성하는 단계(s800)를 더 포함하는 것을 특징으로 한다.In the robot motion path planning method of the present invention, the step (s600) further comprises connecting the nodes to form an optimal path (s800) after the step (s600).

본 발명의 로봇 모션 경로 계획 방법은 동적 환경의 경우에도 처리시간이라는 구속조건을 극복하면서 로봇의 모션 경로 계획을 빠른 시간 내에 도출할 수 있는 효과를 가진다.The robot motion path planning method of the present invention has an effect that the motion path planning of the robot can be derived quickly while overcoming the constraint of the processing time even in the dynamic environment.

또한, 형상공간(CS) 내부로의 장애물의 진입 및 퇴출로 인해 형상공간(CS)의 부피가 변하는 경우에도 적절하고 빠르게 로봇 모션의 경로를 계획하는 것이 가능하게 되는 장점을 가진다.In addition, even when the volume of the shape space CS changes due to entry and exit of an obstacle into the shape space CS, it is possible to plan the path of the robot motion appropriately and quickly.

도 1 은 본 발명의 로봇 모션 계획 방법을 도시하는 플로우 차트이다.
도 2 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s100)을 도시하는 도면이다.
도 3 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s200)을 도시하는 도면이다.
도 4 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s300)을 도시하는 도면이다.
도 5 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s400)을 도시하는 도면이다.
도 6 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s500)을 도시하는 도면이다.
도 7 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s700)을 도시하는 도면이다.
도 8 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s800)을 도시하는 도면이다.
도 9 은 로봇의 손이 장애물을 회피하여 이동하는 모습을 도시하는 도면이다.
도 10 는 종래기술에서 로봇 모션 계획을 형상공간(CS)에서 수행하는 상황을 도시하는 도면이다.
1 is a flowchart showing a robot motion planning method according to the present invention.
2 is a diagram showing step s100 in the robot motion path planning method of the present invention.
3 is a diagram showing step s200 in the robot motion path planning method of the present invention.
4 is a diagram showing step s300 in the robot motion path planning method of the present invention.
5 is a view showing step s400 in the robot motion path planning method of the present invention.
6 is a diagram showing step s500 in the robot motion path planning method of the present invention.
7 is a diagram showing step s700 in the robot motion path planning method of the present invention.
8 is a diagram showing step s800 in the robot motion path planning method of the present invention.
9 is a diagram showing a state in which a hand of a robot moves while avoiding an obstacle.
10 is a diagram showing a situation in the prior art in which a robot motion plan is performed in a shape space (CS).

이하, 도면을 참조하여 본 발명의 실시예에 대해 설명한다. 도 1 은 본 발명의 로봇모션계획방법을 도시하는 플로우차트이다.Hereinafter, embodiments of the present invention will be described with reference to the drawings. 1 is a flowchart showing a robot motion planning method according to the present invention.

본 발명의 로봇 모션 경로 계획방법은 다음과 같은 단계를 포함하여 이루어진다. The robot motion path planning method of the present invention includes the following steps.

도 2 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s100)을 도시하는 도면이다.2 is a diagram showing step s100 in the robot motion path planning method of the present invention.

단계(s100)에서는 도 2 에 도시된 바와 같이, 형상공간(CS)에서 복수의 노드(qi)를 배치하고 상기 복수의 노드(qi)의 각각의 둘레에 일정한 간격으로 검지노드(△qj)를 형성한다.In step s100, as shown in Fig. 2, a plurality of nodes qi are arranged in the shape space CS and detection nodes? Qj are arranged at regular intervals around each of the plurality of nodes qi .

노드(qi)를 배치하는 단계(s100)에서는 장애물(COi)이 존재하지 않는 공간에 노드(qi)를 배치하는 것이 바람직 하나, 장애물(COi)이 존재하는 공간에 배치된 경우에도 후술하는 단계에 의해 자동적으로 노드(qi)가 장애물(COi)이 존재하지 않는 공간으로 이동하게 된다.In step s100 of arranging the node qi, it is preferable to arrange the node qi in a space in which the obstacle COi does not exist. However, even if the node qi is disposed in a space in which the obstacle COi exists, The node (qi) is automatically moved to a space in which the obstacle (COi) does not exist.

한편, 노드(qi)의 주변에는 원주방향으로도 일정한 반경(rs)을 가지도록 복수 개의 검지노드(△qj)를 배치한다.On the other hand, a plurality of detection nodes? Qj are arranged around the node qi so as to have a constant radius rs also in the circumferential direction.

도 2 에서는 본 실시예의 설명을 위해 2차원에서 원주방향에 형성된 경우에 대해서만 도시하고 있으나, n 차원을 가지는 초구(hypersphere)로 형성될 수 있다.Although FIG. 2 shows only the case of being formed in the circumferential direction in two dimensions for the explanation of this embodiment, it may be formed as a hypersphere having n dimensions.

도 3 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s200)을 도시하는 도면이다.3 is a diagram showing step s200 in the robot motion path planning method of the present invention.

다음으로, 이웃하는 노드(qi)를 검색하여 확장 반발 계수를 연산하는 단계(s200)를 수행한다Next, the step s200 of searching for the neighboring node qi and calculating the expansion / repulsion coefficient is performed

도 3 에 도시된 바와 같이 단계(s300)에서는 하나의 노드(qi)와 이웃하는 노드(qj)의 사이의 반경(r)을 미리 정해진 값을 가지는 이웃 반경(rn)과 비교하여 반발포텐셜함수(f)를 하기와 같이 결정한다.As shown in FIG. 3, in step s300, the radius r between one node qi and the neighboring node qj is compared with a neighboring radius r n having a predetermined value, (f) is determined as follows.

f = 1/2(1/r-1/rn)2 [0 < r ≤rn 만족] f = 1/2 (1 / r-1 / r n ) 2 [0 < r r n satisfies]

= 0 [0 < r ≤rn 불만족]= 0 [0 < r &lt; rn unsatisfied]

즉, 반경(r)이 0 < r ≤rn 을 만족하는 경우에 반발 포텐셜 함수(f)는 1/2(1/r-1/rn)2 에 의해 결정된다.In other words, the radius (r) is 0 <r ≤r n repulsion potential function (f) in case of satisfying is determined by the 1/2 (1 / r-1 / r n) 2.

반발 포텐셜 함수(f)는 노드(qi) 사이의 반경(r)이 미리 정해진 이웃 반경(rn)보다 작은 경우에 노드(qi) 사이의 반경(r)을 이웃 반경(rn) 이상으로 멀게 형성되게 하기 위해 노드(qi)를 이동시키기 위한 이동량을 결정하기 위한 것이다.The rebound potential function f is formed such that the radius r between the nodes qi is distanced beyond the neighboring radius r n when the radius r between the nodes qi is smaller than the predetermined neighboring radius rn And to determine the amount of movement for moving the node qi in order to make it move.

즉, 본 발명에서 반발 That is, in the present invention, 포텐셜Potential 함수(f)는 노드( The function (f) qiqi ) 사이의 반경(r)이 가까운 경우에 반경을 멀게 하는 작용을 위한 것인 바, 본 ) Is close to the radius r, the radius 실시예에서의In the embodiment 1/2(1/r-1/r1/2 (1 / r-1 / r nn )) 2 2 in 한정되는 것이 아니라 거리에 반비례하는 함수라면 다른 식을 사용하는 것도 가능하다. It is also possible to use other expressions as long as they are functions that are inversely proportional to the distance, rather than being limited.

예를 들어, E.g, 반발포텐셜함수Repulsive potential function (f) 는 f = a/r (f) is f = a / r 또는 fOr f = -ar 또는 f = -ar+b 또는 f = - = -ar or f = -ar + b or f = - arar 22 + b (여기서, a, b 는 상수임)등  + b (where a and b are constants), etc. 반발포텐셜함수(f)가 거리(r)에If the rebound potential function (f) is at the distance (r) 반비례하는 여러 공지된 다른 함수를 사용하는 것도 가능하다. It is also possible to use several other well-known functions that are inversely proportional.

한편, 반경(r)이 0 < r ≤rn 을 만족하지 못하는 경우에 반발 포텐셜 함수(f)는 0 으로 결정된다.On the other hand, when the radius r does not satisfy 0 < r &lt; r n , the rebound potential function f is determined to be zero.

그 이유는 노드(qi) 사이 반경(r)가 미리 정해진 이웃 반경(rn)보다 큰 경우에 해당되므로 노드(qi) 사이의 반경(r)을 멀게 할 필요가 없기 때문이다.This is because it is not necessary to disturb the radius r between the nodes qi since the radius r between the nodes qi is larger than the predetermined neighboring radius r n .

노드(qi)는 여러 방향으로의 방향성을 가지는 벡터이므로 이러한 방향성을 고려하면 확장 반발계수(Fi 확장)가 하기 수학식 1 과 같이 표현된다.Since the node qi is a vector having directionality in various directions, considering the directionality, the expansion coefficient of restitution (F i extension ) is expressed by the following equation (1).

Figure pat00007
Figure pat00007

여기서, 노드(qi), 이웃 노드(qj), 확장 반발계수(Fi 확장)는 방향성을 가지는 벡터임.Here, the node qi, the neighboring node qj, and the expansion / contraction coefficient (F i extension ) are directional vectors.

rij 는 노드(qi)와 노드(qj) 사이의 거리r ij Is the distance between the node (qi) and the node (qj)

ηi 는 이웃하는 노드(qj)의 셋트를 의미함.η i Means a set of neighboring nodes (qj).

상기 식에서 반발포텐셜함수(f)는 반발로 인해 노드(qi)간의 거리를 멀어지게 하는 이동량의 크기를 의미하며 (qi-qj)/r 은 반발되어 이동하는 방향을 의미한다.In the above equation, the repulsive potential function (f) means the magnitude of the movement amount that causes the distance between the nodes (qi) to increase due to the repulsion, and (qi-qj) / r means the repulsive moving direction.

도 4 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s300)을 도시하는 도면이다.4 is a diagram showing step s300 in the robot motion path planning method of the present invention.

다음으로, 검지반발계수를 연산하는 단계(s300)를 수행한다.Next, a step (S300) of calculating the detection restitution coefficient is performed.

단계(s400)은 검지반발계수(Fi 검지)를 연산하기 위해 먼저 검지반발함수(s)를 결정하게 되는데, 각 노드(qi)에서의 검지노드(△qj)의 위치가 형상공간(CS)에서 장애물(COi)의 범위 내에 존재하는 경우에는 검지반발함수(s)를 1 로 결정하고, 장애물(COi)의 범위 내에 존재하지 않는 경우 검지반발함수(s)를 0 으로 결정하게 된다.In step S400, the detection repulsive function s is first determined to calculate the detection repulsion coefficient (F i detection ). The position of the detection node Qj in each node qi is determined by the shape space CS, The detection repulsive function s is determined to be 1 when it is within the range of the obstacle COi and the detection repulsion function s is determined to be 0 when it is not within the range of the obstacle COi.

즉, s(q) = 1 (형상공간(CS) 내 검지노드(△qj)와 장애물 충돌 발생 경우)That is, when s (q) = 1 (occurrence of an obstacle collision with the detection node? Qj in the shape space CS)

= 0 (형상공간(CS) 내 검지노드(△qj)와 장애물 충돌 발생하지 않은 경우)        = 0 (when an obstacle collision does not occur with the detection node? Qj in the shape space CS)

노드(qi)는 여러 방향으로의 방향성을 가지는 벡터이므로 이러한 방향성을 고려하여 검지반발계수(Fi 검지)를 표현하면 하기 수학식 2 와 같이 된다.Since the node qi is a vector having directionality in various directions, the detection repulsion coefficient (F i detection ) can be expressed by the following equation (2) in consideration of such a directionality.

Figure pat00008
Figure pat00008

검지반발계수(Fi 검지)는 마이너스값을 가지게 되는데 검지노드(△qj)는 노드(qi)에 대해 반대방향으로 검지반발계수(Fi 검지)를 형성하기 때문이다.(F i detection ) has a negative value because the detection node (Qj) forms the detection repulsion coefficient (F i detection ) in the opposite direction to the node (qi).

검지반발계수(Fi 검지)는 모든 검지노드(△qj)에 대해 연산되어야 하므로 j=1...ns 값을 가진다.The detection restitution coefficient (F i detection ) has a value of j = 1 ... ns since it must be calculated for all the detection nodes (Δ qj).

여기서, 노드(qi), 노드(qj), 검지 반발계수(Fi 검지)는 방향성을 가지는 벡터임.Here, the node qi, the node qj, and the detection repulsive coefficient (F i detection ) are directional vectors.

S 는 검지노드(△qj)의 셋트를 의미함.S denotes a set of detection nodes (? Qj).

ns 는 검지노드(△qj)의 개수를 의미함.n s means the number of detection nodes (Δ qj).

상기 식의 의미를 살펴보면 충돌검지함수(s)는 장애물과 충돌이 검지된 경우 노드(qi)를 장애물로부터 이동시키는 이동량의 크기를 의미하며, △qj 는 충돌이 검지된 경우 이동하는 방향을 의미하는 것이다.The collision detection function s means the amount of movement of the node qi from the obstacle when the collision with the obstacle is detected, and Δqj denotes the direction of movement when the collision is detected. will be.

다음으로, 각 노드(qi)에서 위치를 업데이트 하는 단계(s400)를 수행하게 된다. 도 5 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s400)을 도시하는 도면이다.Next, a step (S400) of updating the position at each node qi is performed. 5 is a view showing step s400 in the robot motion path planning method of the present invention.

노드(qi)의 위치는 하기 수학식 3 에 의해 새로운 위치로 업데이트된다.The position of the node qi is updated to a new position by the following equation (3).

Figure pat00009
Figure pat00009

G1, G2 는 각각 확장반발계수 Fi 확장(k) 및 검지반발계수 Fi 검지(k) 에 대한 게인(gain)값임G 1, G 2 are each expansion coefficient of restitution F i extension gain (gain) ¹ for the (k) and detecting the restitution coefficient F i index (k)

상기 식의 의미를 설명하면 원래의 k 번째 위치 연산된 노드 qi(k) 위치에 확장반발계수 Fi 확장(k) 에 의한 노드 위치 변동량 및 검지반발계수 Fi 검지(k) 에 의해 노드 위치 변동량이 연산되어 새로운 위치인 k+1 번째 노드 위치 qi(k+1) 가 연산되는 것을 표현하는 것이다.Turning to the meaning of the expression node position by the original k-th position calculation nodes qi (k) expansion coefficient of restitution at a position F i extension (k) node position change amount, and detecting the restitution coefficient F i index (k) by amount of variation Is calculated to express that the (k + 1) -th node position qi (k + 1) as a new position is calculated.

단계(s400)의 노드 위치 업데이트 작용에 대해 도 5을 참조하여 자세히 설명하면 다음과 같다.The node location update operation in step S400 will be described in detail with reference to FIG.

먼저, 확장반발계수 연산과 관련하여 도 5a 를 살펴보면 하나의 노드(qi)의 이웃 반경(rn)의 내부에 이웃 노드(qj)가 배치되어 확장반발작용이 발생하는 것을 알 수 있다.Referring to FIG. 5A, it can be seen that the neighboring node qj is disposed inside the neighboring radius r n of one node qi, so that an expansion repelling action occurs.

또한, 검지반발계수와 관련하여 도 5b 를 살펴보면 검지노드(△qj) 중에서 3개의 검지노드(△q1, △q2, △q3)가 장애물(COi)에 위치되어 충돌하므로 검지반발작용이 발생하는 것을 알 수 있다.Referring to FIG. 5B regarding the detection repulsion coefficient, three detection nodes Δq1, Δq2, and Δq3 among the detection nodes Δqj are located at the obstacle COi and collide with each other. Able to know.

도 5c 에는 확장반발작용 및 검지반발작용이 동시에 작용하는 내용이 도시되어 있다.FIG. 5C shows the contents in which the expansion repelling action and the detection repelling action act simultaneously.

이러한 2가지 작용의 발생으로 인해 도 5d 에 도시된 바와 같이 전술한 수학식 3 에 의해 새로운 노드 위치인 k+1 번째 노드 위치 qi(k+1) 가 연산되어 노드의 위치가 새로 업데이트 된다.Due to the occurrence of these two actions, the (k + 1) -th node position qi (k + 1) as a new node position is computed by the above-described Equation 3 as shown in FIG.

한편, 단계(s500)에서 노드(qi)는 각각의 노드 위치가 모두 한 번씩 위치 업데이트되도록 동기화방식으로 진행된다.On the other hand, in step s500, the node qi proceeds in a synchronous manner such that the position of each node is all positionally updated once.

즉, 각각의 노드(qi)의 위치가 모두 업데이트될 때까지 이미 위치가 업데이트된 노드(qi)에서는 더 이상 위치 업데이트 작업을 하지 않고 대기하는 방식으로 이루어진다.That is, in the node qi where the position has already been updated until all the positions of the respective nodes qi are updated, the process is performed in such a manner that no more position update operations are performed.

다음으로는 이웃 반경(rn)의 크기를 업데이트하는 단계(s500)를 수행하게 된다. 도 6 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s500)을 도시하는 도면이다.Next, the size of the neighboring radius rn is updated (S500). 6 is a diagram showing step s500 in the robot motion path planning method of the present invention.

먼저, 이웃반경(rn)을 업데이트할 필요성에 대해 설명하기로 한다.First, the necessity to update the neighboring radius r n will be described.

단계(s500)에서 확장반발계수를 연산하는 경우 이웃 노드와의 반경(r)을 미리 정해진 이웃반경(rn)과 비교하여 연산하게 된다.If the expansion coefficient is calculated in step s500, the radius r of the neighboring node is compared with the predetermined neighbor radius r n .

그런데 동적 환경에서는 작업공간(WS)으로 장애물(WOi)이 진입하고 퇴출하게 되는 바, 형상공간(CS)에서도 장애물(COi)의 크기 내지 부피도 수시로 변동하여 형상공간(CS)의 크기 내지 부피도 변동하게 된다.In the dynamic environment, the obstacle (WOi) enters and leaves the work space (WS), and the size and volume of the obstacle (COi) also fluctuate in the shape space (CS) .

따라서, 형상공간(CS)의 크기 내지 부피에 따라 이웃반경(rn)의 크기를 적절하게 변경하지 않으면 로봇 모션 경로 계획 방법을 수행하는 경우에 노드의 균등한 분포가 달성되지 못하는 문제점이 발생하게 된다.Therefore, if the size of the neighboring radius r n is not appropriately changed according to the size and the volume of the shape space CS, there is a problem that the uniform distribution of the nodes is not achieved in the case of performing the robot motion path planning method do.

예를 들어, 도 6 은 로봇 모션 경로 계획 방법을 100회 반복실시한 후의 상태를 도시하는 도면으로서 6a 는 이웃 반경(rn) 이 10 인 경우로서 아무런 반발작용이 발생하지 않는 상태임을 알 수 있다. For example, FIG. 6 shows a state after the robot motion path planning method is repeated 100 times, where 6a is a state in which the neighboring radius r n is 10, and no repelling action occurs.

도 6b 의 경우 이웃반경(rn)이 30 인 경우로서 노드간의 반발작용이 발생하기는 하나 형상공간(CS)에 빈 공간이 발생하는 등 충분한 노드 균일 분포가 달성되지 않음을 도시하고 있다.6B shows that when the neighboring radius r n is 30, repulsive action occurs between the nodes, but a sufficient node uniformity distribution is not achieved, such that voids are generated in the shape space CS.

도 6c 는 이웃 반경(rn) 이 47 인 경우로서 아주 이상적으로 형상공간(CS) 전체에 걸쳐 노드가 균일하게 분포되고 있음을 알 수 있다. FIG. 6C shows that nodes are uniformly distributed throughout the shape space CS ideally when the neighboring radius r n is 47.

도 6d 는 이웃 반경(rn)이 60 인 경우로서 로봇 모션 경로 계획방법을 수행하는 경우에 연산이 수렴되지 않아 균일한 노드 분포가 달성되지 않음을 알 수 있다.FIG. 6D shows that when the neighboring radius r n is 60, the computation is not converged when performing the robot motion path planning method, so that a uniform node distribution is not achieved.

따라서, 적정한 이웃반경(rn)의 값을 설정하는 것은 특히 동적환경으로 인해 형상공간(CS)의 부피가 급변하는 경우에 더욱 절실하게 필요하게 된다.Therefore, setting the value of the proper neighborhood radius r n is more and more necessary when the volume of the shape space CS is suddenly changed due to the dynamic environment.

적절한 이웃 반경의 크기는 하기 수학식 4 에 의해 결정된다.The size of the appropriate neighborhood radius is determined by the following equation (4).

Figure pat00010
Figure pat00010

G 는 게인(gain)값. G is the gain value.

Pd 는 희망하는 반발력의 합의 값으로 미리 정해진 값.Pd is a predetermined value of the sum of desired repulsive forces.

P 는 각 노드에서의 반발력의 합.P is the sum of the repulsive forces at each node.

Figure pat00011
Figure pat00011

△t = tk+1 -tk 로서 k번째 반복과 k+1 번째 반복사이의 시간차이.The time difference between kth iteration and k + 1th iteration as Δt = t k + 1 -t k .

rn(tk)는 k 번째 반복에서의 이웃 반경.r n (t k ) is the neighborhood radius in the kth iteration.

N 은 노드의 총개수N is the total number of nodes

다음으로 단계(s500)에서 업데이트 후 노드 위치 qi(k+1) 와 위치 업데이트 전 노드 위치 qi(k) 를 비교하여 미리 정해진 허용치(ε) 이하인지 여부를 판단하는 단계(s600)를 수행하게 된다.Next, in step s500, the node position qi (k + 1) after update is compared with the pre-position update node position qi (k) to perform step s600 of determining whether or not it is less than a predetermined allowable value? .

Figure pat00012
Figure pat00012

본 발명의 방법을 반복수행하면 노드(qi)간의 확장반발계수 및 충돌검지계수가 지속적으로 연산되어 노드(qi) 위치가 지속적으로 업데이트되어 변경되며, 최종적으로 노드(qi)간의 반경이 충분히 확보되고 장애물과도 충돌되지 않는 노드(qi)위치도 확보된다.If the method of the present invention is repeatedly performed, the expansion restitution coefficient and the collision detection coefficient between the nodes qi are continuously calculated, the position of the node qi is constantly updated and changed, and finally the radius between the nodes qi is sufficiently secured A node (qi) position that does not collide with an obstacle is also secured.

이러한 상태가 되면 노드(qi)의 위치가 더 이상 크게 변동되지 않으므로 노드(qi) 위치 변화가 미리 정해진 허용치(ε)보다 작게 되는 지 여부를 수학식 5 와 같이 판단하게 된다.In this state, since the position of the node qi does not change much any more, whether the change of the position of the node qi is smaller than the predetermined allowable value? Is determined as shown in Equation (5).

도 7 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s700)을 도시하는 도면이다.7 is a diagram showing step s700 in the robot motion path planning method of the present invention.

단계(s700)에서 업데이트 전후의 노드 위치의 차이가 미리 정해진 허용치(ε)보다 크게 되면 다시 단계(s200)으로 복귀하여 단계(s200) 내지 단계(s500)을 반복하는 단계(s700)를 수행하게 된다.In step s700, when the difference between the node positions before and after the update becomes larger than the predetermined allowable value?, The process returns to step s200 to repeat step s200 to step s500 .

단계(s700)를 지속적으로 수행하게 되면 형상공간(CS) 내부에서의 노드의 분포 균일도가 점점 더 향상되는 작용을 하게 된다.If the step S700 is continuously performed, the distribution uniformity of the nodes in the shape space CS gradually increases.

예를 들어, 단계(s100)만을 초기에 수행한 경우에는 도 7a 에 도시된 바와 같이 형상공간(CS)의 내부에 노드가 불균일하게 분포된다.For example, when only the step s100 is initially performed, the nodes are unevenly distributed in the shape space CS as shown in Fig. 7A.

단계(s700)을 5회 정도 반복하게 되면 도 7b 에 도시된 바와 같이 노드간의 균일 분포가 서서히 확보되며 10회 정도 반복하게 되면 도 7c 에서와 같이 노드의 분포 균일도가 더욱 향상되고 100회 정도 반복하게 되면 도 7d 에서와 같이 형상공간(CS)의 내부에서 노드의 거의 완전한 분포 균일성이 확보되게 된다.If the step (s700) is repeated five times, as shown in FIG. 7B, the uniform distribution between the nodes is gradually secured. If the distribution is repeated ten times, the distribution uniformity of the node is further improved as shown in FIG. The almost complete distribution uniformity of the node is secured in the shape space CS as shown in FIG. 7D.

이와 같이 지속적으로 단계(s700)를 수행하게 되면 노드의 위치가 균일하게 분포되므로 일정 반복회수 이후에는 업데이트 전후의 노드 위치의 차이가 미리 정해진 허용치(ε)보다 작게 되어 단계(s600)을 만족하게 되므로 단계(s800)를 수행하게 된다.Since the positions of the nodes are uniformly distributed when the step S700 is continuously performed, the difference between the node positions before and after the update is smaller than the predetermined allowable value? After a predetermined number of iterations, so that the step s600 is satisfied Step s800 is performed.

도 8 는 본 발명의 로봇 모션 경로 계획방법에서 단계(s800)을 도시하는 도면이다.8 is a diagram showing step s800 in the robot motion path planning method of the present invention.

단계(s700)의 지속적인 반복으로 충분한 노드 분포의 균일성이 확보된 후에는 전술한 바와 같이 노드 위치가 더 이상 크게 변경되지 않게 된다.After the uniformity of the sufficient node distribution is ensured by the continuous repetition of the step s700, the node position is no longer largely changed as described above.

이와 같은 최종적으로 확정된 형상공간(CS)에서의 노드 분포를 기준으로 하여 공지된 최적 경로 방법 등을 통해 노드의 위치를 연결하여 로봇의 매니퓰레이터의 최적 경로를 형성하는 단계(s800)를 수행하게 된다. In step S800, the nodes are connected through the well-known optimal path method based on the node distribution in the finally determined shape space CS to form the optimal path of the manipulator of the robot .

도 9a 에 도시된 바와 같이 형상공간(CS)의 내부에서 균일도가 확보된 노드를 연결하여 최적경로를 형성하게 되면, 궁극적으로 도 9b 에 도시된 바와 같이 작업공간(WS)에서 로봇의 매니퓰레이터(M)가 장애물(WOi)과 간섭되거나 충돌되지 않으면서 이동할 수 있는 경로를 계획하는 것이 가능하게 된다.As shown in FIG. 9A, when an optimal path is formed by connecting nodes having uniformity within a shape space CS, ultimately, as shown in FIG. 9B, a robot manipulator M ) Can travel without interfering with or colliding with the obstacle (WOi).

이와 같이 본 발명에서는 단계(s200) 내지 단계(s400)을 수행함으로써 확장반발계수 및 검지반발계수라는 개념을 도입하여 노드의 균일한 위치를 빠르게 확보하는 작용을 확보하는 바, 동적환경에서의 로봇 모션 경로 계획을 빠른 시간 내에 달성할 수 있는 효과를 가지게 된다.As described above, the present invention introduces the concept of the expansion restitution coefficient and the detection / repulsion coefficient by performing the steps (s200) to (s400) to secure the action of securing the uniform position of the node quickly, The path planning can be achieved in a short time.

특히, 본 발명의 로봇 모션 경로 계획방법을 수행하는 경우 각 노드(qi)마다 하나의 쓰레드(thread)가 할당되어 분산적으로 수행하게 된다. 이와 같이 각 노드마다 각각의 쓰레드로 연산하는 경우 노드(qi)의 수가 많아지더라도 계산이 분산되어 더욱 빠르게 연산을 수행하게 된다.될 수 있게 된다.In particular, when performing the robot motion path planning method according to the present invention, one thread is allocated to each node qi and distributedly performed. In this way, when the number of nodes (qi) increases with each thread in each node, the calculation is distributed and the operation is performed more quickly.

또한, 이웃반경(rn)을 연산시마다 업데이트하는 단계(s500)를 수행함으로써 동적환경의 변화로 인해 형상공간(CS)의 부피가 장애물의 진입 및 퇴출로 인해 급변하는 경우에도 연산 자체가 수행되지 않거나 연산이 되더라도 수렴되지 않는 문제점을 방지하는 효과적인 작용을 하게 된다.In addition, the neighborhood radius (r n) for, by performing the step (s500) for updating at each operation, even if the volume of the shaped space due to a change in a dynamic environment (CS) rapidly changing due to the entry of an obstacle and the exit operation itself is not performed It does not converge even if it is calculated or operated.

전술한 실시예는 본 발명의 기술적 사상을 예시적으로 설명하기 위한 것으로서 본 발명의 기술적 범위를 제한하는 것으로 해석될 수 없다.The above-described embodiments are intended to illustrate the technical concept of the present invention and can not be construed as limiting the technical scope of the present invention.

Claims (6)

동적환경하에서 로봇의 이동경로를 계획하는 방법으로서,
상기 형상공간(CS)의 내부에 복수의 노드(qi)를 배치하고 상기 복수의 노드(qi)의 각각의 둘레에 일정한 간격으로 검지노드(△qj)를 형성하는 단계(s100);
상기 하나의 노드(qi)와 이웃하는 노드(qi)의 사이의 반경(r)와 미리 정해진 이웃 반경(rn)를 비교하여 확장반발계수를 하기 식에 의해 연산하는 단계(s200);
Figure pat00013

여기서, 노드(qi), 이웃 노드(qj), 확장 반발계수(Fi 확장)는 방향성을 가지는 벡터임.
rij 는 노드(qi)와 노드(qj) 사이의 거리
ηi 는 이웃하는 노드(qj)의 셋트를 의미함.
반발포텐셜함수(f)는 0 < r ≤rn 만족시에는 거리(r)에 반비례하는 임의의 함수로 결정되며, 0 < r ≤rn 불만족시에는 O 으로 결정됨.
상기 각 노드 둘레의 검지노드가 장애물에 위치하는 지 여부를 판단하여 검지반발계수를 하기 식에 의해 연산하는 단계(s300);
Figure pat00014

충돌검지함수(s)는 하기와 같이 결정됨
s(q) = 1 (형상공간(CS)내 검지노드와 장애물 충돌 발생 경우)
= 0 (형상공간(CS)내 검지노드와 장애물 충돌 발생하지 않은 경우)
각 노드(qi)에서 하기 식을 이용하여 노드(qi)의 위치를 업데이트 하는 단계(s400);
Figure pat00015

여기서, G1, G2 는 각각 확장반발계수 Fi 확장(k) 및 검지반발계수 Fi 검지(k) 에 대한 게인(gain)값임.
상기 단계(s400)에서 업데이트된 노드(qi) 위치 qi(k+1)와 업데이트 전 노드(qi) 위치 qi(k)와의 반경 차이가 미리 정해진 허용치(ε) 이하인지 여부를 판단하는 단계(s600);
Figure pat00016

상기 단계(s600)을 만족하지 못하는 경우 상기 단계(s200)으로 복귀하는 단계(s700);
상기 단계(s700)을 만족하는 경우 로봇 모션 경로 계획 방법을 종료하는 것을 특징으로 로봇 모션 경로 계획 방법.
A method for planning a movement path of a robot under a dynamic environment,
A step (s100) of arranging a plurality of nodes qi in the shape space CS and forming a detection node? Qj at regular intervals around each of the plurality of nodes qi;
A step (s200) of comparing the radius r between the one node qi and the adjacent node qi to a predetermined neighboring radius rn to calculate an expansion / repulsion coefficient according to the following equation: s200;
Figure pat00013

Here, the node qi, the neighboring node qj, and the expansion / contraction coefficient (F i extension ) are directional vectors.
r ij Is the distance between the node (qi) and the node (qj)
η i Means a set of neighboring nodes (qj).
The repulsive potential function (f) When 0 <r ≤ rn, it is determined as an arbitrary function that is inversely proportional to the distance (r), and when 0 <r ≤rn is unsatisfied, it is determined as O.
Determining whether or not the detection node around each node is located at an obstacle, and calculating the detection counterpart coefficient by the following equation (s300);
Figure pat00014

The collision detection function (s) is determined as follows
s (q) = 1 (when an obstacle collision occurs with the detection node in the shape space (CS))
= 0 (no obstacle collision occurred with the detection node in the shape space (CS))
Updating (S400) the position of the node (qi) using the following equation at each node (qi);
Figure pat00015

Here, G 1, G 2 are each expansion coefficient of restitution F i extension (k) and the restitution coefficient F i index detection gain (gain) ¹ for (k).
Determining whether the radius difference between the updated node qi (k + 1) and the updated node qi (qi) position qi (k) is equal to or smaller than a predetermined allowable value? );
Figure pat00016

Returning to step s200 if the step (s600) is not satisfied (s700);
And if the step (s700) is satisfied, terminating the robot motion path planning method.
청구항 1 에서,
상기 단계(s400)와 단계(s600) 사이에 이웃반경(rn)을 하기 식에 의해 업데이트하는 단계(s600)를 더 포함하는 것을 특징으로 하는 로봇 모션 경로 계획 방법.
Figure pat00017

G 는 게인(gain)값.
Pd 는 희망하는 반발력의 합의 값으로 미리 정해진 값.
P 는 각 노드에서의 반발력의 합.
Figure pat00018

△t = tk+1 -tk 로서 k번째 반복과 k+1 번째 반복사이의 시간차이.
rn(tk)는 k 번째 반복에서의 이웃 반경.
In claim 1,
Further comprising a step (s600) of updating the neighboring radius (rn) between the steps (s400) and (s600) by the following equation (s600).
Figure pat00017

G is the gain value.
Pd is a predetermined value of the sum of desired repulsive forces.
P is the sum of the repulsive forces at each node.
Figure pat00018

The time difference between kth iteration and k + 1th iteration as Δt = t k + 1 -t k .
r n (t k ) is the neighborhood radius in the kth iteration.
청구항 1 에 있어서,
상기 반발포텐셜함수(f)는 하기 식에 의해 결정되는 것을 특징으로 하는 로봇 모션 경로 계획 방법.
f = 1/2(1/r-1/rn)2 [0 < r ≤rn 만족]
= 0 [0 < r ≤rn 만족]
The method according to claim 1,
Wherein the repulsive potential function (f) is determined by the following equation.
f = 1/2 (1 / r-1 / rn) 2 [0 < r &
= 0 [0 &lt; r &lt; rn satisfaction]
청구항 2 에서,
상기 단계(s200) 내지 단계(s400)는 각 노드에 대해 분산 쓰레드 방식으로 연산되는 것을 특징으로 하는 로봇 모션 계획 방법.
In claim 2,
Wherein the steps (s200) to (s400) are performed in a distributed thread manner for each node.
청구항 1 또는 청구항 2 에 있어서,
상기 단계(s400)은 즉, 노드(qi) 위치를 업데이트 하는 단계는 각각의 노드(qi)의 위치가 모두 업데이트될 때까지 이미 위치가 업데이트된 노드(qi)에서는 더 이상 위치 업데이트 작업을 하지 않고 대기하는 동기화방식으로 이루어지는 것을 특징으로 하는 로봇 모션 경로 계획 방법.
The method according to claim 1 or 2,
That is, the step (S400) of updating the position of the node (qi) does not perform the position update operation any more at the node (qi) whose position has already been updated until the position of each node (qi) And a synchronization method in which the robot moves in a waiting direction.
청구항 1 또는 청구항 2 에 있어서,
상기 단계(s600) 이후에 노드를 연결하여 최적 경로를 형성하는 단계(s800)를 더 포함하는 것을 특징으로 하는 로봇 모션 경로 계획 방법.
The method according to claim 1 or 2,
Further comprising a step (s800) of connecting the nodes after the step (s600) to form an optimal path (s800).
KR1020170059735A 2017-05-15 2017-05-15 Planning method for robot motion KR101937269B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020170059735A KR101937269B1 (en) 2017-05-15 2017-05-15 Planning method for robot motion

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020170059735A KR101937269B1 (en) 2017-05-15 2017-05-15 Planning method for robot motion

Publications (2)

Publication Number Publication Date
KR20180125646A true KR20180125646A (en) 2018-11-26
KR101937269B1 KR101937269B1 (en) 2019-01-14

Family

ID=64603155

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020170059735A KR101937269B1 (en) 2017-05-15 2017-05-15 Planning method for robot motion

Country Status (1)

Country Link
KR (1) KR101937269B1 (en)

Cited By (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2021211420A1 (en) * 2020-04-14 2021-10-21 Realtime Robotics, Inc. Configuration of robot operational environment including layout of sensors
CN114003047A (en) * 2021-12-31 2022-02-01 山东科技大学 Path planning method for small unmanned ship
US11429105B2 (en) 2016-06-10 2022-08-30 Duke University Motion planning for autonomous vehicles and reconfigurable motion planning processors
US11623346B2 (en) 2020-01-22 2023-04-11 Realtime Robotics, Inc. Configuration of robots in multi-robot operational environment
US11634126B2 (en) 2019-06-03 2023-04-25 Realtime Robotics, Inc. Apparatus, methods and articles to facilitate motion planning in environments having dynamic obstacles
US11673265B2 (en) 2019-08-23 2023-06-13 Realtime Robotics, Inc. Motion planning for robots to optimize velocity while maintaining limits on acceleration and jerk
US11738457B2 (en) 2018-03-21 2023-08-29 Realtime Robotics, Inc. Motion planning of a robot for various environments and tasks and improved operation of same
US11745346B2 (en) 2018-02-06 2023-09-05 Realtime Robotics, Inc. Motion planning of a robot storing a discretized environment on one or more processors and improved operation of same
US11970161B2 (en) 2018-01-12 2024-04-30 Duke University Apparatus, method and article to facilitate motion planning of an autonomous vehicle in an environment having dynamic objects
US12017364B2 (en) 2019-04-17 2024-06-25 Realtime Robotics, Inc. Motion planning graph generation user interface, systems, methods and articles
CN118372256A (en) * 2024-06-21 2024-07-23 贵州大学 Real-time obstacle avoidance and terminal pose adjustment method for redundant mechanical arm

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101667032B1 (en) 2009-10-30 2016-10-17 삼성전자 주식회사 Path planning apparatus of robot and method thereof
KR101145243B1 (en) 2010-03-31 2012-05-24 한국과학기술연구원 Restriction space calculation method using position sensors of multi degrees-of-freedom manipulator
KR101641022B1 (en) 2015-06-29 2016-07-20 중앙대학교 산학협력단 Mobile robot and control method thereof under unknown slippage effects

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11429105B2 (en) 2016-06-10 2022-08-30 Duke University Motion planning for autonomous vehicles and reconfigurable motion planning processors
US11970161B2 (en) 2018-01-12 2024-04-30 Duke University Apparatus, method and article to facilitate motion planning of an autonomous vehicle in an environment having dynamic objects
US11745346B2 (en) 2018-02-06 2023-09-05 Realtime Robotics, Inc. Motion planning of a robot storing a discretized environment on one or more processors and improved operation of same
US12090668B2 (en) 2018-02-06 2024-09-17 Realtime Robotics, Inc. Motion planning of a robot storing a discretized environment on one or more processors and improved operation of same
US11738457B2 (en) 2018-03-21 2023-08-29 Realtime Robotics, Inc. Motion planning of a robot for various environments and tasks and improved operation of same
US11964393B2 (en) 2018-03-21 2024-04-23 Realtime Robotics, Inc. Motion planning of a robot for various environments and tasks and improved operation of same
US12083682B2 (en) 2018-03-21 2024-09-10 Realtime Robotics, Inc. Motion planning of a robot for various environments and tasks and improved operation of same
US12017364B2 (en) 2019-04-17 2024-06-25 Realtime Robotics, Inc. Motion planning graph generation user interface, systems, methods and articles
US11634126B2 (en) 2019-06-03 2023-04-25 Realtime Robotics, Inc. Apparatus, methods and articles to facilitate motion planning in environments having dynamic obstacles
US11673265B2 (en) 2019-08-23 2023-06-13 Realtime Robotics, Inc. Motion planning for robots to optimize velocity while maintaining limits on acceleration and jerk
US11623346B2 (en) 2020-01-22 2023-04-11 Realtime Robotics, Inc. Configuration of robots in multi-robot operational environment
WO2021211420A1 (en) * 2020-04-14 2021-10-21 Realtime Robotics, Inc. Configuration of robot operational environment including layout of sensors
CN114003047A (en) * 2021-12-31 2022-02-01 山东科技大学 Path planning method for small unmanned ship
CN118372256A (en) * 2024-06-21 2024-07-23 贵州大学 Real-time obstacle avoidance and terminal pose adjustment method for redundant mechanical arm

Also Published As

Publication number Publication date
KR101937269B1 (en) 2019-01-14

Similar Documents

Publication Publication Date Title
KR101937269B1 (en) Planning method for robot motion
US20210252707A1 (en) Collision avoidance motion planning method for industrial robot
Petrič et al. Smooth continuous transition between tasks on a kinematic control level: Obstacle avoidance as a control problem
Jin et al. Distributed task allocation of multiple robots: A control perspective
WO2018107851A1 (en) Method and device for controlling redundant robot arm
CN109491389B (en) Robot trajectory tracking method with speed constraint
JP5156836B2 (en) Real-time self-collision and obstacle avoidance
KR20120073616A (en) Path planning apparatus of robot and method thereof
JP2003039353A (en) Control method for manipulator
Gao et al. Optimal trajectory planning for robotic manipulators using improved teaching-learning-based optimization algorithm
Li et al. A hybrid model and model-free position control for a reconfigurable manipulator
JP5173958B2 (en) Moving body posture generation method and moving body posture generation apparatus
CN114939872B (en) MIRRT-Connect algorithm-based intelligent storage redundant mechanical arm dynamic obstacle avoidance motion planning method
El Haiek et al. Optimal trajectory planning for spherical robot using evolutionary algorithms
Rout et al. Kinematic and dynamic optimal trajectory planning of industrial robot using improved multi-objective ant lion optimizer
Kaden et al. Maximizing robot manipulability along paths in collision-free motion planning
Zhao et al. Collision-free kinematics for redundant manipulators in dynamic scenes using optimal reciprocal velocity obstacles
WO2018084164A1 (en) Action transfer device, action transfer method, and non-temporary computer readable medium having action transfer program stored thereon
Rout et al. Kinematic and dynamic optimal trajectory planning of industrial robot using multi-objective ant lion optimizer
Huptych et al. Online path planning in dynamic environments using the curve shortening flow method
Moll et al. Distributed control of the center of mass of a modular robot
Abainia et al. Bio-inspired approach for inverse kinematics of 6-dof robot manipulator with obstacle avoidance
Chembuly et al. An efficient approach for inverse kinematics and redundancy resolution scheme of hyper-redundant manipulators
Stoian et al. Using artificial potential field methods and fuzzy logic for mobile robot control
Rybak et al. Optimization of the trajectory of movement of a parallel robot based on a modified AСO algorithm

Legal Events

Date Code Title Description
E701 Decision to grant or registration of patent right