The present application claims priority to Korean Patent Application No. 10-2015-0095864, filed Jul. 6, 2015, the entire contents of which is incorporated herein by this reference.
Field of the Invention
The present disclosure relates to methods and systems for controlling walking of a wearable robot. More particularly, the present disclosure relates to methods and systems for controlling walking of a wearable robot, which may make a robot wearer's walking comfortable by providing force of a virtual spring as walking assistive power.
Description of the Related Art
Generally, a wearable robot is a device for helping a patient who has difficulty in walking or cannot walk unassisted to walk with the assistance of the robot while wearing the robot.
Algorithms developed thus far for assisting walking of a wearable robot may be largely categorized into a method in which previously input walking patterns are realized according to modes for patients who cannot move by themselves, and a method in which the force of the joint to move is measured and augmented for patients who can move by themselves but have weak muscular strength.
In the case of a wearable robot for assisting walking, research has been progressing in order that the wearer of the robot may walk in a way very similar to human walking and not feel resistance when wearing the robot.
Particularly, technology for reducing loads attributable to the weight of the robot to enable the wearer of a robot to comfortably walk has become a very important issue in related art.
The foregoing is intended merely to aid in the understanding of the background of the present invention, and is not intended to mean that the present invention falls within the purview of the related art that is already known to those skilled in the art.
Accordingly, the present disclosure is intended to provide systems and methods for controlling walking of a wearable robot, which applies the force of a virtual spring to provide walking assistive power that is applied as if something were pulling the wearer from the front or pushing the wearer from the back in the walking direction, whereby the wearer of the robot may comfortably walk.
According to one aspect of the present disclosure, there is provided a system for controlling walking of a robot, which includes: a walking mode determination unit configured to determine whether the robot is walking; a virtual spring force calculation unit configured to calculate force of a virtual spring of which one end is connected to the robot and the other end is connected to a target point located in front of the robot based on a walking direction of the robot, when it is determined by the walking mode determination unit that the robot is walking; and a joint driving unit configured to drive joints of the robot using torque that is calculated based on the force of the virtual spring, which is calculated by the virtual spring force calculation unit.
In some implementations, the walking mode determination unit is configured to determine that the robot is walking when the robot is converted from a two foot support state to a one foot support state, and when speed of the robot is equal to or greater than predetermined reference speed.
In some implementations, the virtual spring force calculation unit is configured to calculate the target point based on walking speed of the robot, and predetermined target acceleration or predetermined target speed.
In some implementations, the virtual spring force calculation unit is configured to calculate the target point using previously programmed fuzzy logic, based on walking speed of the robot and predetermined target acceleration or predetermined target speed.
In some implementations, the virtual spring force calculation unit is configured to calculate the target point by the following Equation:
where xd denotes the target point, {dot over (x)}robot denotes walking speed of the robot, and Ki and Ti are optimal control gains, set according to target speed and target acceleration.
In some implementations, the virtual spring force calculation unit is configured to calculate the target point by the following Equation:
xd=asgn({dot over (x)}robot)e−k||
where xd denotes the target point, {dot over (x)}robot denotes walking speed of the robot, sgn denotes a sign function, and a, b, k, and δ are constants adjusted by target speed or target acceleration.
In some implementations, the virtual spring force calculation unit is configured to calculate the force of the virtual spring by the following Equation:
Fvspring=−kvspringΔx−cvspring
where Δx=xd−xc, Fvspring denotes the force of the virtual spring, xd denotes the target point, xc denote a current location of the robot, and kvspring and cvspring are predetermined control constants.
According to another aspect of the present disclosure, there is provided a method for controlling walking of a robot, which includes: a walking mode determination operation for determining whether the robot is walking; a target point calculation operation for calculating a target point located in front of the robot based on a walking direction of the robot, depending on walking speed of the robot and predetermined target acceleration or predetermined target speed, when it is determined in the walking mode determination operation that the robot is walking; a virtual spring force calculation operation for calculating force by a virtual spring of which one end is connected to the robot and the other end is connected to the target point; and a joint driving operation for driving joints of the robot using torque calculated based on the force of the virtual spring calculated in the virtual spring force calculation operation.
In implementations of the systems and methods for controlling walking of a wearable robot, described above, the force of a virtual spring connected between the robot and a target point, which is set in the walking direction of the robot, may be applied to the walking of the robot. As a result, the wearer of the robot may feel assistive power applied as if something were pulling or pushing him or her in the walking direction, thus the wearer may comfortably walk.
The above and other objects, features and other advantages of the present invention will be more clearly understood from the following detailed description when taken in conjunction with the accompanying drawings, in which:
Hereinafter, systems and methods for controlling walking of a wearable robot will be described in detail with reference to the accompanying drawings.
As illustrated in
Referring to
Through the above-described configuration, the systems and methods for controlling walking of a wearable robot may apply the force by a virtual spring connected between the robot and a target point, which is set in the walking direction of the robot, to the walking of the robot. Accordingly, the wearer of the robot may feel assistive power as if something were pulling or pushing him or her in the walking direction, whereby the wearer may comfortably walk.
At the walking mode determination step (S10, S30), the walking mode determination unit 10 may determine whether a robot is walking, using various sensors (not illustrated in the drawings) installed in the robot 100. The walking mode determination unit 10 may determine at step S10 whether the robot supports itself on one foot or on both feet using a ground reaction force sensor (not illustrated), which is installed on the soles of the robot 100. The ground reaction force sensor, installed on the soles of the robot, may determine the supporting state by generating different signals respectively for the case in which the sole of the robot is contacted with the ground and for the case in which the sole of the robot is not contacted with the ground.
At the step for determining the supporting state of the robot (S10), when it is determined that the state in which the robot supports itself on both feet is converted into the state in which the robot supports itself on one foot, the walking mode determination unit 10 may determine at step S30 whether the robot has certain speed toward a fixed direction using an acceleration sensor and the like installed in the robot. For example, when the walking mode determination unit 10 determines that the speed in the x-direction at the waist of the robot is greater than predetermined threshold speed after the robot is converted into the one foot support state, it may be determined that the robot has started walking or is walking.
When the walking mode determination unit 10 determines that the robot 100 is converted into the one foot support state and is currently walking, the virtual spring force calculation unit 30 sets a target point P in the walking direction of the robot and calculates the force by a virtual spring of which one end is connected to the robot and the other end is connected to the target point P at step S70.
The target point P may be a certain point located in front of the robot 100 based on the walking direction of the robot. Assuming that there is a virtual spring between the robot (for example, from the waist of the robot) and the target point, when the force by the virtual spring that pulls the robot 100 to the direction of the target point P is applied to the walking of the robot, the wearer of the robot may feel the force as if something were pulling him or her from the front or pushing him or her from the back, whereby the wearer may comfortably walk.
At the target point calculation step (S50), the virtual spring force calculation unit 30 may calculate the target point by applying various methods based on the walking speed of the robot and predetermined target acceleration or predetermined target speed.
For example, at the target point calculation step (S50), the virtual spring force calculation unit 30 may obtain the target point by applying previously programmed fuzzy logic. The current walking speed of the robot and the predetermined target acceleration or target speed become the inputs of the fuzzy logic. In order to determine the location of the target point, which corresponds to the output of the fuzzy logic, the fuzzy logic may apply previously specified rules and preset conditions to the inputs.
As another example, the virtual spring force calculation unit 30 may determine the target point by applying conditional statements and equations.
An example for applying the conditional statements and the equations is shown as the following Equation (1):
where xd denotes the target point, {dot over (x)}robot denotes the current walking speed of the robot 100, and Ki and Ti are optimal control gains, which are set according to the predetermined target speed and target acceleration of the robot.
As shown in Equation (1), the virtual spring force calculation unit 30 may obtain the target point by applying the optimal control method.
Another example for applying the conditional statements and equations is shown as the following Equation (2):
xd=asgn({dot over (x)}robot)e−k||
where xd denotes the target point, {dot over (x)}robot denotes the current walking speed of the robot 100, sgn denotes a sign function, and a, b, k, and δ are constants adjusted by the target speed or target acceleration.
Besides, the virtual spring force calculation unit 30 may obtain the target point using a reference table, which previously sets the relation among the location of the target point, the walking speed of the robot, and the predetermined target acceleration or target speed, at the target point calculation step (S50).
After the location of the target point is calculated at the target point calculation step (S50), the virtual spring force calculation unit 30 may perform the virtual spring force calculation step (S70). At step S70, the force of the virtual spring may be calculated as the following Equation (3):
Fvspring=−kvspringΔx−cvspring (3)
where Δx=xd−xc, Fvspring denotes the force of the virtual spring, kvspring and cvspring are predetermined control constants, xd denotes the target point, and xc denote the current location of the robot 100.
Subsequently, at the joint driving step (S90), the joint driving unit 50 may convert the force of the virtual spring, which was calculated at the virtual spring calculation step (S70), into target torque to be applied to the respective joints 110, 130, and 150 of the robot. The conversion into the target torque, performed at the joint driving step (S90) may be calculated by the following Equation (4):
where JT denotes Jacobian transpose, and SSP means the walking when the robot supports itself on one foot. In other words, the torque to which the force of the virtual spring is applied may be applied when the robot is walking by being converted from the two foot support state to the one foot support state.
At the joint driving step (S90), the joint driving unit 50 drives the joints 110, 130, and 150 of the robot 100 using the torque calculated by Equation (4), whereby the force by the virtual spring may be applied to the driving of the joints.
As described above, the systems and methods for controlling walking of an wearable robot applies the force of a virtual spring to driving of the joints of a robot to help stability and gait in the walking direction (pitch direction) when the walking by the robot is converted from a two foot support state to a one foot support state, whereby the load felt by the wearer of the robot may be reduced and the robot may help the wearer to comfortably walk.
Although a preferred forms of the present invention has been described for illustrative purposes, those skilled in the art will appreciate that various modifications, additions and substitutions are possible, without departing from the scope and spirit of the invention as disclosed in the accompanying claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2015-0095864 | Jul 2015 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
6484068 | Yamamoto | Nov 2002 | B1 |
6845830 | Tojo | Jan 2005 | B2 |
8287473 | Yasuhara | Oct 2012 | B2 |
9043029 | Seo | May 2015 | B2 |
20070010913 | Miyamoto | Jan 2007 | A1 |
20080147281 | Ishii | Jun 2008 | A1 |
20090227424 | Hirata | Sep 2009 | A1 |
20100243344 | Wyrobek | Sep 2010 | A1 |
20110040216 | Herr et al. | Feb 2011 | A1 |
20120310412 | Seo | Dec 2012 | A1 |
Number | Date | Country |
---|---|---|
09-131679 | May 1997 | JP |
2008-73830 | Apr 2008 | JP |
2012-143449 | Aug 2012 | JP |
10-1179159 | Sep 2012 | KR |
10-1321791 | Jul 2013 | KR |
10-1315199 | Oct 2013 | KR |
101438970 | Sep 2014 | KR |
Entry |
---|
A virtual force approach for cooperative standoff target tracking using multiple robots; Xun Wang; Daibing Zhang; Lincheng Shen; Jianwei Zhang; 2016 Chinese Control and Decision Conference (CCDC); Year: 2016; pp. 1348-1353, DOI: 10.1109/CCDC.2016.7531194. |
ScarIETH: Design and control of a planar running robot ; Marco Hutter; C. David Remy; Mark A. Hoepflinger; Roland Siegwart; 2011 IEEE/RSJ International Conference on Intelligent Robots and Systems ; Year: 2011; pp. 562-567, DOI: 10.1109/IROS.2011.6094504. |
Online nonlinear reference shaping with end-point position feedback for human-like smooth reaching motion; Fumi Seto; Tomomichi Sugihara; 2009 9th IEEE-RAS International Conference on Humanoid Robots; Year: 2009; pp. 297-302, DOI: 10.1109/ICHR.2009.5379562. |
Number | Date | Country | |
---|---|---|---|
20170007426 A1 | Jan 2017 | US |