The present application claims priority of Korean Patent Applications No. 10-2007-0124162 and 10-2008-0054685, filed on Dec. 3, 2007 and Jun. 11, 2008, which are incorporated herein by reference.
The present invention relates to a network-based robot system, and more specifically, to a network-based robot system and method for action execution of a robot in the network-based robot system to enable hierarchical/concurrent/sequential action execution of the robot.
This work was supported by the IT R&D program of MIC/IITA [2005-S-033-03, Action execution sequence model, method and devices for hierarchical, concurrent action execution].
In general, robot actions that are executed in a robot follow a certain order, and a description on the order of action execution is called an action execution procedure. That is, an action execution procedure of a robot is basically constituted by a condition decision step for processing information on an external condition, an action decision step for deciding an action to be carried out by the robot based on the external condition, and an action execution step for carrying out the decided action. These steps are implemented in software and used in a robot control algorithm.
As conventional techniques related to the above action execution procedure, there are two ways: one is associated with the kind of languages to describe the action decision process and the other is associated with a model used as a basis of the action decision process.
The former way is to implement the action decision process directly in a compiler source code such as C language or C++ language. The action decision process implemented in the source code is combined with the condition decision process and the action execution process, followed by being compiled to create an execution program. The execution program so created is then loaded in a robot and used to control the robot. The major advantage of this way is that action decision process is executed quickly because the action decision process is mapped to an execution code.
Meanwhile, the latter way makes use of a sequential/planar model to sequentially describe a series of actions in temporal order.
However, the former way has a difficulty in revising the action decision process, a difficulty in immediate revision and debugging, and a difficulty in learning.
The latter way has a shortcoming in poor modulation of the action selection process, poor reusability, and increasing complexity and a difficulty in modulation of an excessively enlarged planar model as the action selection process gets more complex.
In addition, these conventional approaches are convenient to describe a decision that is made for sequential actions, but are not suitable for describing actions that are executed in parallel.
It is, therefore, an object of the present invention to provide a network-based robot system and method for action execution of a robot in the network-based robot system to enable hierarchical/concurrent/sequential action execution of the robot by creating an activity to define hierarchical/parallel/sequential action execution procedures of the robot and distributing the created action execution procedures to the robot.
In accordance with an aspect of the present invention, there is provided a network-based robot system comprising:
an activity creating device creating activities in hierarchical structure, each activity describing action execution procedures to be carried out and being arranged in an activity tree;
a robot downloading the activity tree over a communication network and executing an activity selected in the activity tree.
In accordance with another aspect of the present invention, there is provided a method for action execution of a robot in a network-based robot system, comprising:
creating activities in hierarchical structure, each activity describing action execution procedures to be run by the robot and being arranged in an activity tree;
downloading the activity tree via communication network to storing the activity tree in the robot;
searching for, in response an execution instruction of the robot, the activity tree including a target activity corresponding to the execution instruction;
interpreting the searched activity tree; and
executing the target activity in the interpreted activity tree.
The above and other objects and features of the present invention will become apparent from the following description of embodiments, given in conjunction with the accompanying drawings, in which:
Hereinafter, various embodiments of the present invention will be described in detail with reference to the accompanying drawings. In the following description, well-known constitutions or functions will not be described in detail if they would obscure the invention in unnecessary detail.
A network-based robot system of the present invention includes a robot 100 and an activity creating device 120 which are connected over a communication network 110.
The activity creating device 120 creates activities to be executed in the robot 100 in hierarchical structure. An activity is a basic unit in script format defining the action execution procedures of the robot 100 to be run within a certain period of time, more details of which will be given with reference to
The activity creating device 120 has a function of structural/hierarchical edition to efficiently express the activities that have structural/hierarchical/sequential attributes. The activity creating device 120 provides an interface for describing a basic action execution procedure of the robot 100, and an interface for describing a complex action execution procedure higher level of the basic action execution procedure, thereby enabling a robot programmer to achieve an activity with a hierarchical tree structure. The activities created by the activity creating device 120 are downloaded in the robot 100 through the communication network 110, which may include wired/wireless communication networks.
The robot 100 manages the downloaded activities and performs actions corresponding to the activities.
The activity storage 210 stores activities in a tree structure that are provided from the activity creating device 120.
The instruction interpreter 200 interprets a user-input execution instruction for the robot 100 to know which activity needs to be executed.
The activity manager 202 allows the activities to be downloaded over the communication network 110, and them to be stored in a form of activity trees in the activity storage 210. Further, the activity manager 202 searches the activity storage 210 for an activity tree having an activity that is associated with the execution instruction interpreted from the instruction interpreter 200. The searched activity tree is then provided to the activity interpreter 204.
The activity interpreter 204 interprets the activity tree in script format, and changes it in a format readable by the activity executor 206 and loads the same onto a memory device (not shown).
The activity executor 206 is responsible for actual execution of an activity, and when the activity is executed, it changes an internal mode of the activity through a mode transition decision routine of the activity. At this time, the mode transition decision routine checks surrounding conditions of the robot 100 that is recorded in the world model 208 to determine whether to transit the mode.
The world model 208 is a collection of data that represents surrounding conditions of the robot 100. Information on the surrounding conditions sensed by all kinds of built-in sensors (not shown) mounted in the robot 100 is processed in a format required for the activity, and is recorded on the world model 208. Since the surrounding conditions of the robot 100 continuously change, the surrounding conditions are acquired by the built-in sensors on regular cycle and recorded on the world model 208 after processing thereof.
An activity, as shown in
Goal mode is composed of one or more modes among plural modes of the activity. The goal mode is reached when the activity has finished a certain goal it has pursued. When the execution of the activity reaches a relevant goal mode, the activity is regarded as having achieved its expected goal. Such goal mode can be used for a higher activity to examine whether an activity that is called out from the higher activity has successfully finished a goal.
The activity history retains an execution record of an activity while the activity is being executed. Such an execution record contains information about activated time of the activity in a previous execution cycle (0 is set if not activated) and information about the mode that is finally activated in the previous execution cycle.
Each mode has a structure containing a name indicative of the mode, mode execution time, entry action to be performed when newly entering a mode, exit action to be performed when exiting a mode, mode action to be performed while in a mode, and a mode transition decision routine for deciding whether a mode needs to transit to the other mode (or this current mode).
With reference to
Referring to
On the other hand, when a robot executes one single action, an activity or primitive action becomes the action of the robot. Such an activity can be expressed in script format as illustrated in TABLE 1 that is an illustrative diagram showing an activity written in script language.
Referring to TABLE 1, if an activity a1 is defined, the activity a1 has two internal modes M1 and M2. Here, M1 indicates a start mode of the activity a1, and M2 indicates a goal mode of the activity a1. The mode M1 specifies an entry action entry_action, mode transition decision routine transition_rule, mode action do{ . . . }, and exit action exit_action. The mode M2 does not specify the entry action and the exit action, but specifies only the mode transition decision routine and the mode action.
First, as shown in
In step S502, if the execution instruction interpreted in step S500 is to shut down the robot 100, the robot shuts down. If not, in step S504, the robot 100 reads an activity that is relevant to the execution instruction from the activity storage 210 by the activity manager 202. In this connection, the activity manager 202 reads, out of the activity storage 210, not only the relevant activity to the execution instruction, but also an activity tree, as shown in
Next, in step S506, the activity interpreter 204 interprets the activity tree in a format readable by the activity executor 206, and provides the interpreted activity tree to the activity executor 206. The activity executor 206 then loads the interpreted activity tree by the activity interpreter 204 on the memory device.
Thereafter, in order for the activity executor 206 to execute the interpreted activity, in step S508, the robot 100 updates the world model 208 to reflect any changes in the surrounding conditions. That is, the changes in the surrounding conditions are derived from all kinds of built-in sensors mounted on the robot 100, adapted in a form required for the activity, and then stored in the world model 208.
After updating the world model 208, the activity executor 206 sets a root activity of the activity tree as an execution activity P in step S510, and carries out the execution activity P in step S512. Execution of the activity eventually calls out the other child activity, namely, a lower activity, or calls out primitive actions that are basically loaded on the robot 100. In step S514, if a child activity is called out by the activity executor 206, the child activity is assigned as the execution activity P in step S516, followed by returning to step S512 for execution of next steps. In other words, the child activity, which is a lower activity and is called out, calls out the other child activity thereof, or calls out any of primitive actions of the robot 100. Whether to call out a child activity or a primitive action depends on the modes of the activity. Because every mode in its activated status has mode actions to be executed, either a child activity or a primitive action may be called out based on what is described in the mode actions of an activated activity.
Meanwhile, if a lower activity is not called out to be executed, the activity executor 206 calls out and executes a primitive action in step S518, and decides whether the activity has finished in step 520.
If the decision result in step S520 shows that the activity has finished, the control process returns to the step S500 to receive a new user instruction, but if not, the control process returns to the step S508 to carry out subsequent steps. That is to say, from the step S508 for updating the world model 208 till all the execution of all primitive action constitutes a basic cycle of the execution of the activity tree. Such cycle repeatedly occurs until the execution of the activity tree is terminated.
When a robot enters the currently activated mode, a mode transition decision routine of this mode is first called out and executed in step S600. Then, in step S602, the mode transition decision routine decides whether the current mode should be kept or whether the mode should transit to the other mode of the activity to which the current mode belongs, based on the surrounding conditions recorded on the world model 208.
In result of the decision made in step S602, if the current mode is to be kept, mode execution time of the current mode is checked in step S604. In result of the checking in step S604, if the mode execution time is “0” (representing that the current mode is a non-activated mode), it means that the current mode was not activated in a previous execution cycle but is newly activated in this cycle. Therefore, an entry action is executed while entering a new mode in step S606, and a mode action is executed in step S608. The mode action in step S708 refers to an action, which is to be run while the current mode is being activated, such as, calling out an activity or primitive action.
However, if the checking result in step S604 shows that the mode execution time is not “0” (representing that the current mode is an activated mode), which means that the mode execution time has set, the control process proceeds directly to step S608 to execute the current mode action.
Meanwhile, if the decision result in step S602 indicates that the current mode needs to transit to another mode according to the mode transition decision routine, in step S610 the control process executes an exit action of the current mode and, in step S612, initializes the mode execution time to 0. Thereafter, the current mode shifts to a new mode in step S614.
Since the entry action is executed when a robot enters the new mode, namely, when the current mode has not been activated in a previous execution cycle, a rule is established that, in the entry action, the robot should execute an action to meet a condition that has to be satisfied when the robot enters this mode. At this time, the action to be executed is an activity or primitive action.
Meanwhile, the exit action is performed once when the current mode activated transits to the other mode. Therefore, the exit action describes actions about how the robot 100 can perform a cleaning work such as cancellation of secured resources in this mode. Similar to the entry action, an activity or basic action can be the exit action.
In
As noted earlier, in the activity tree, activities are continuously connected and called out till terminal nodes at which primitive actions of a robot are positioned. Only primitive actions of the robot 100 can be the terminal nodes, while only activity nodes can be intermediate nodes. Therefore, a user can select a desired activity out of such an activity tree and instruct the robot to execute the selected activity.
In accordance with the present invention, by creating not only a simple, execution procedure of primitive action but also a complex action execution procedure, it becomes possible to easily create planar/sequential simple action execution programs for a robot as well as hierarchical/parallel complex action execution programs for a robot.
In addition, unlike the conventional approaches, the present invention also covers hierarchical/parallel action selection procedures, so that it can give a more natural expression upon decision of robot action.
While the invention has been shown and described with respect to the preferred embodiments, it will be understood by those skilled in the art that various changes and modification may be made without departing from the scope of the invention as defined in the following claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2007-0124162 | Dec 2007 | KR | national |
10-2008-0054685 | Jun 2008 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
5327541 | Reinecke et al. | Jul 1994 | A |
5442784 | Powers et al. | Aug 1995 | A |
5598545 | Childers et al. | Jan 1997 | A |
5659727 | Velissaropoulos et al. | Aug 1997 | A |
5664181 | Velissaropoulos et al. | Sep 1997 | A |
5749080 | Matsumoto et al. | May 1998 | A |
5864858 | Matsumoto et al. | Jan 1999 | A |
5924094 | Sutter | Jul 1999 | A |
6321231 | Jebens et al. | Nov 2001 | B1 |
6378627 | Tubel et al. | Apr 2002 | B1 |
6450104 | Grant et al. | Sep 2002 | B1 |
6535793 | Allard | Mar 2003 | B2 |
6622137 | Ravid et al. | Sep 2003 | B1 |
6845297 | Allard | Jan 2005 | B2 |
6879862 | Brown et al. | Apr 2005 | B2 |
6879878 | Glenn et al. | Apr 2005 | B2 |
7031802 | Bash et al. | Apr 2006 | B2 |
7069111 | Glenn et al. | Jun 2006 | B2 |
7197502 | Feinsmith | Mar 2007 | B2 |
7211980 | Bruemmer e | May 2007 | B1 |
7272818 | Ishimitsu et al. | Sep 2007 | B2 |
7296023 | Geyer et al. | Nov 2007 | B2 |
7332890 | Cohen et al. | Feb 2008 | B2 |
7487160 | Whyte | Feb 2009 | B2 |
7650205 | Calcagno | Jan 2010 | B2 |
7792886 | Hadari et al. | Sep 2010 | B2 |
7813816 | Fulton et al. | Oct 2010 | B2 |
7853357 | Sawada et al. | Dec 2010 | B2 |
7926438 | Guerrero et al. | Apr 2011 | B2 |
20050033822 | Grayson et al. | Feb 2005 | A1 |
20050165859 | Geyer et al. | Jul 2005 | A1 |
20060271351 | Mirkovic et al. | Nov 2006 | A1 |
20080162551 | Geyer et al. | Jul 2008 | A1 |
20090143909 | Lee et al. | Jun 2009 | A1 |
Number | Date | Country |
---|---|---|
2004-114242 | Apr 2004 | JP |
2005-246591 | Sep 2005 | JP |
10-2004-00984 98 | Nov 2004 | KR |
10-2007-0004268 | Jan 2007 | KR |
Number | Date | Country | |
---|---|---|---|
20090143909 A1 | Jun 2009 | US |