1. Field of the Invention
The present invention relates to a robotics apparatus including a control unit for controlling a first driving source for driving a first link, a second driving source for driving a second link, and a third driving source for driving both the first link and the second link, and to a robot control method, a program, and a recording medium.
2. Description of the Related Art
In a method for controlling a manipulator, it becomes more and more important for a hand tip to be able to flexibly come into contact with an object. If the flexible contact of the hand tip with the object is applied to industrial robots, collaborative work between a human and a robot is realized, or component fitting work is facilitated by controlling a direction of flexibility of the hand tip.
If the flexible contact described above is applied to leg-walking type mobile robots, legs can softly come into contact with a ground surface to reduce a shock applied on a trunk, or the robot can stably walk on an irregular terrain by absorbing a level difference.
In order to realize the control of flexibility of the hand tip, impedance control using a force sensor mounted on the hand tip, or control using an artificial muscle actuator is performed. It is known that a human muscle is an actuator as well as a control mechanism having a variable viscoelasticity. Among the artificial muscle actuators, in particular, a pneumatic rubber artificial muscle actuator as represented by a McKibben artificial muscle actuator has viscoelastic properties similar to those of the muscles. Therefore, by controlling softness of the artificial muscle actuator provided to the manipulator, the hand tip can come into contact with the object with arbitrary flexibility.
In the document, “Mechanical Properties of Robot Arm Operated with Muscle Coordinate System Consisted of Bi-articular Muscles and Mono-articular Muscles, by Toru Oshima, Tomohiro Fujikawa, and Minayori Kumamoto, Journal of the Japan Society of Precision Engineering, Vol. 66, No. 1, pp. 141 to 146”, it is proposed, that a 3-pair 6-muscle manipulator including a bi-articular simultaneous driving actuator for simultaneously driving a first link and a second link in addition to artificial muscle actuators for respectively driving the first link and the second link. Oshima et. al teaches features in the following stiffness properties. Specifically, when elasticities of the artificial muscle actuators are set equal to each other, a direction of an external force applied onto the hand tip and a direction of movement become the same in the case where the external force is applied to the hand tip on a line connecting a first joint and the hand tip. It is difficult to use the McKibben actuator for motion control because the McKibben actuator has nonlinearity in viscoelastic properties and control is required to be performed with antagonistic arrangement.
On the other hand, Japanese Patent Application Laid-Open No. 2012-86354 teaches that a simple feedback control system using saturation of a control input is derived to control a joint angle in addition of stiffness control for the hand tip in a simultaneous manner. However, the 3-pair 6-muscle manipulator requires six driving sources to be provided. Therefore, for example, when the McKibben artificial muscle actuator is used, a mechanical configuration including a control valve becomes complex.
On the other hand, in “Motor Development of an Pneumatic Musculoskeletal Infant Robot, by Kenichi Narioka and Koh Hosoda, 2011, IEEE International Conference on Robotics and Automation, pp. 963 to 968, 2011”, artificial muscle actuators are used for lower limbs of an infant robot. By acquiring a contractile-force command value by learning, a crawling motion is realized. In Narioka et. al, one actuator is provided to each joint in a direction of folding the first link and the second link with respect to the manipulator, whereas a single bi-articular simultaneous driving actuator is provided to unfold the two links.
In Narioka et. al, a learning control system is configured based on neural oscillators to acquire the contractile-force command value for realizing the crawling motion by linking motions of upper limbs and motions of the lower limbs.
In Narioka et. al, the realization of the crawling motion by a fullbody motion of the infant robot is considered, but positioning control or compliance control by the manipulator alone is not considered. Moreover, the learning control requires time to generate the control input. Therefore, it is difficult to apply the learning control to purposes of use in which a target trajectory frequently changes.
The present invention provides a robotics apparatus capable of controlling a distal end of a second link to track a target trajectory and performing stiffness control at the distal end of the second link with a smaller number of driving sources than that of a conventional 3-pair 6-muscle manipulator, a robot control method, a program, and a recording medium.
A purpose of the invention is to provide a robotics apparatus, including a first link pivotably connected at a first joint with regard to a base portion, a second link pivotably connected at a second joint with regard to the first link, a first driving source for driving the first link about the first joint, a second driving source for driving the second link about the second joint, a third driving source for simultaneously driving the first link about the first joint and the second link about the second joint, and a control unit for respectively controlling driving forces of the first driving source, a driving force of the second driving source and a driving force of the third driving source, based on a first driving-force command value for the first driving source, a second driving-force command value for the second driving source, and a third driving-force command value for the third driving source.
Another purpose of the invention is to provide, a robot control method of controlling a robotics apparatus including generating, by the control unit, a first target joint angle for the first joint and a second target joint angle for the second joint based on a target trajectory of a distal end of the second link, setting, by the control unit, the third driving-force command value to a predetermined setting value, calculating, by the control unit, the first driving-force command value based on the third driving-force command value and the first target joint angle, and calculating, by the control unit, the second driving-force command value based on the third driving-force command value and the second target joint angle.
A further purpose of the invention is to provide a computer program executes steps of generating, by the control unit, a first target joint angle for the first joint and a second target joint angle for the second joint based on a target trajectory of a distal end of the second link, setting, by the control unit, the third driving-force command value to a predetermined setting value, calculating, by the control unit, the first driving-force command value based on the third driving-force command value and the first target joint angle; and calculating, by the control unit, the second driving-force command value based on the third driving-force command value and the second target joint angle.
A still further purpose of the invention is to provide a computer-readable recording medium including a computer program that executes steps of generating, by the control unit, a first target joint angle for the first joint and a second target joint angle for the second joint based on a target trajectory of a distal end of the second link, setting, by the control unit, the third driving-force command value to a predetermined setting value, calculating, by the control unit, the first driving-force command value based on the third driving-force command value and the first target joint angle; and calculating, by the control unit, the second driving-force command value based on the third driving-force command value and the second target joint angle.
A still further features of the present invention will become apparent from the following description of exemplary embodiments with reference to the attached drawings.
Now, embodiments for carrying out the present invention are described in detail referring to the drawings.
First Embodiment
(1) Modeling
In a first embodiment of the present invention, control of a manipulator using pneumatic artificial muscle actuators is performed. The artificial muscle actuator is an actuator having a property similar to a muscle property called “viscoelasticity”. A muscle is modeled by using a force-generating element, an elastic element, and a viscous element, as illustrated in
In
{dot over (x)}
Moreover, k is an elastic-force constant, b is a viscous-force constant, and F is a muscle contractile force. Then, the viscoelastic property of the muscle is modeled as expressed by:
F=u−kux−bu{dot over (x)} (1)
The elastic force and the viscous force of the muscle contractile force have a feature in having a non-linear element proportional to the contractile force u of the force-generating element.
Next, a robotics apparatus according to the first embodiment is illustrated in
A base end of the link 101 is pivotably connected at a joint J1 which is a first joint with regard to a base portion 103. A base end of the link 102 is pivotably connected at a joint J2 which is a second joint with regard to a distal end of the link 101.
The actuator f1 drives the link 101 about the joint J1, whereas the actuator f2 drives the link 102 about the joint J2. Specifically, each of the actuators f1 and f2 is a mono-articular driving actuator for driving a single link.
The actuator e3 simultaneously drives the links 101 and 102 respectively about the joints J1 and J2. The actuator e3 is a bi-articular simultaneous driving actuator for simultaneously driving the two links.
In this embodiment, each of the actuators f1, f2, and e3 is a pneumatic artificial muscle actuator, and generates only a contractile force (tensile force) as a driving force. Therefore, the actuator f1 drives the link 101 about the joint J1 in a pivot direction R1 which is a first pivot direction, whereas the actuator f2 drives the link 102 about the joint J2 in the pivot direction R1. The actuator e3 drives both the links 101 and 102 respectively about the joints J1 and J2 in a pivot direction R2 which is a second pivot direction opposite to the pivot direction R1.
It is known that bi-articular simultaneous driving actuators called “bi-articular muscles” exist in brachial regions and lower-limb thigh regions of a human. Muscular arrangements in human four limbs are complex. However, the concept of effective muscles is introduced, and Oshima et. al discloses a two-link model having 3-pair 6-muscles. Although the 3-pair 6-muscle arrangement realizes biologically-inspired control such as output-direction control, the number of actuators becomes three times as large as that of a serial-link robot which is widely put into practical use for industrial applications.
Therefore, in this embodiment, the manipulator 120 includes the two mono-articular driving actuators, that is, the actuators f1 and f2, and the single bi-articular driving actuator, that is, the actuator e3, to thereby drive the two links 101 and 102.
The arrangement of the actuators f1, f2, and e3 described above is referred to as “3-muscle antagonistic arrangement” in this embodiment. Here, uf1, uf2, and ue3 are contractile forces of the force-generating elements, kf1, kf2, and ke3 are elastic-force constants of the artificial muscle actuators, and bf1, bf2, and be3 are viscous constants of the artificial muscle actuators. A pivot angle of the link 101 with regard to the base portion 103, that is, a joint angle of the joint J1 (first joint angle) is regarded as θ1, and a pivot angle of the link 102 with regard to the link 101, that is, a joint angle of the joint J2 (second joint angle) is regarded as θ2.
Inertia moments of the links 101 and 101 are respectively regarded as I1 and I2, lengths of the links 101 and 102 in a longitudinal direction are respectively regarded as l1 and l2, masses of the links 101 and 102 are respectively regarded as m1 and m2, and a moment arm diameter for both the links 101 and 102 is regarded as r. In this embodiment, the elastic-force constant and the viscous-force constant are respectively regarded as k and b for each muscle. Then, motion equations are:
It is understood that a difference between the generated forces (driving forces, that is, contractile forces) uf1 and ue3 in the first term on the right-hand side of Formula (2) applies a rotation torque to the joint J1 and the sum of the generated forces uf1 and ue3 in the second and third terms on the right-hand side varies the stiffness and the viscosity with regard to the joint J1. Similarly, it is understood that a difference between the generated forces uf2 and ue3 in the first term on the right-hand side of Formula (3) applies a rotation torque to the joint J2 and the sum of the generated forces uf2 and ue3 in the second and third terms on the right-hand side varies the stiffness and the viscosity with regard to the joint J2.
(2) Control System
The robotics apparatus 100 includes a control device 200, and three drivers 301, 302, and 303. The three drivers 301, 302, and 303 respectively drive the actuators f1, f2, and e3 based on the driving-force command values (that is, contractile-force command values) uf1, uf2, and ue3 from the control device 200. The control device 200 generates the driving-force command values uf1, uf2, and ue3 (first driving-force command value uf1, second driving-force command value uf2, and third driving-force command value ue3) respectively corresponding to the actuators f1, f2, and e3. Then, the control device 200 outputs the driving-force command values uf1, uf2, and ue3 respectively to the drivers 301, 302, and 303 to control the driving forces of the respective actuators f1, f2, and e3.
For each of the drivers 301, 302, and 303, the driving source is a pneumatic artificial muscle actuator. Therefore, the drivers 301, 302, and 303 are configured to include a pipe constituting an air path for feeding air respectively to the actuators f1, f2, and e3 and a control valve under the driving-force command values uf1, uf2, and ue3 from the control device 200.
Now, prior to the description of an operation of the control device 200, a device configuration of the control device 200 is first described.
The control device 200 is configured with a computer, and includes a central processing unit (CPU) 201 as a control unit (calculation unit). The control device 200 also includes a read only memory (ROM) 202 and a random access memory (RAM) 203. The control device 200 further includes a hard disk drive (HDD) 204, a recording disk drive 205, and various interfaces 207 to 212.
The ROM 202, the RAM 203, the HDD 204, the recording disk drive 205, and the various interfaces 207 to 212 are connected to the CPU 201 through a bus 206. Basic programs such as a BIOS are stored in the ROM 202. The RAM 203 is a storage device for temporarily storing the result of calculation processing by the CPU 201.
The HDD 204 is a storage unit for storing various types of data which are the results of calculation processing performed by the CPU 201 as well as a recording medium for recording a program 221 for controlling the CPU 201 to execute various types of calculation processing described later. The CPU 201 executes the various types of calculation processing based on the program 221 recorded on the HDD 204.
The recording disk drive 205 can read out various types of data and programs recorded on the recording disk 222.
The drives 301, 302, and 303 described above are respectively connected to the interfaces 210, 211, and 212. The CPU 201 outputs the driving-force command values uf1, uf2, and ue3 respectively to the drivers 301, 302, and 303 through the bus 206 and the interfaces 210, 211, and 212. The drivers 301, 302, and 303 control the actuators fe, f2, and e3 to generate the driving forces corresponding to the driving-force command values uf1, uf2, and ue3.
In this embodiment, the robotics apparatus 100 includes a detection unit 401 which is a first detection unit, a detection unit 402 which is a second detection unit, and a touch sensor 403, which are not shown in
The detection unit 401 is connected to the interface 207. A signal indicating the detected joint angle θ1 is transmitted to the CPU 201 through the interface 207 and the bus 206. The detection unit 402 is connected to the interface 208. A signal indicating the detected joint angle θ2 is transmitted to the CPU 201 through the interface 208 and the bus 206. The touch sensor 403 is connected to the interface 209. A signal indicating whether or not an object has come into contact therewith is transmitted to the CPU 201 through the interface 209 and the bus 206.
Specifically, the CPU 201 functions as a target joint-angle generation processing unit 230, a setting processing unit 231, and a feedforward calculation processing unit 240. The CPU 201 also functions as a feedback calculation processing unit 241 which is a first feedback calculation processing unit and a feedback calculation processing unit 242 which is a second feedback calculation processing unit. The CPU 201 further functions as a torque command-value calculation processing unit 251 which is a first torque command-value calculation processing unit and a torque command-value calculation processing unit 252 which is a second torque command-value calculation processing unit. The CPU 201 further functions as a driving-force command value calculation processing unit 261 which is a first driving-force command value calculation processing unit and a driving-force command value calculation processing unit 262 which is a second driving-force command value calculation processing unit. The CPU 201 also functions as a constraint processing unit 271 which is a first constraint processing unit and a constraint processing unit 272 which is a second constraint processing unit.
In this embodiment, the CPU 201 functions as each of the units described above to control the three actuators f1, f2, and e3. In this manner, the rotation torque is applied to each of the joints J1 and J2 to perform the control so as to vary the stiffness of a distal end (that is, hand tip) E of the second link 102. In this embodiment, the CPU 201 functions as each of the units described above to set a target trajectory for the joint angle. By generating a joint torque so as to track the target trajectory, trajectory tracking control is performed.
Specifically, the target joint-angle generation processing unit 230 executes target joint-angle generation processing for generating a target joint angle (first target joint angle) ra1 for the joint J1 and a target joint angle (second target joint angle) ra2 for the joint J2 based on the target trajectory of the hand tip E (target joint-angle generation step). Data of the target trajectory of the hand tip E is stored in, for example, the HDD 204, and is read out from the HDD 204 by the CPU 201.
Now, control input torques (torque command values) to the joints J1 and J2 to allow the hand tip E to track the target trajectory are respectively regarded as T1 and T2.
(uf1−ue3)r=T1 (4)
(uf2−ue3)r=T2 (5)
The driving-force command values uf1, uf2, and ue3 only need to be determined so as to satisfy Formulas (4) and (5). However, unique solutions cannot be obtained thereby. Therefore, in this embodiment, the setting processing unit 231 executes setting processing for setting the driving-force command value ue3 for the actuator e3 to a predetermined (for example, constant) set value U3 (setting step).
The driving-force command value calculation processing unit 261 executes first driving-force command value calculation processing for calculating the driving-force command value uf1 based on the driving-force command value U3 and the target joint angle ra1 (first driving-force command value calculation step). The driving-force command value calculation processing unit 262 executes second driving-force command value calculation processing for calculating the driving-force command value uf2 based on the driving-force command value U3 and the target joint angle ra2 (second driving-force command value calculation step).
By the above-mentioned processing, the driving-force command values uf1 and uf2 for the mono-articular driving actuators f1 and f2 can be determined. If the driving-force command value U3 for the bi-articular driving actuator e3 is increased, the driving-force command values uf1 and uf2 for the mono-articular driving actuators f1 and f2 are required to be increased so that the manipulator 120 maintains a constant posture. According to Formula (1), the elastic coefficient k of the actuators f1, f2, and e3 is proportional to the driving-force command values uf1, uf2, and ue3. Therefore, the stiffness of the manipulator 120 (that is, the hand tip E) is increased.
As described above, by the 3-muscle antagonistic arrangement, the target trajectory tracking control and the stiffness control can be performed. In this embodiment, the tracking control to the target trajectory is performed by a two-degrees-of-freedom control system obtained by combining a feedforward control system and a feedback control system. Further, a technique for analyzing and controlling the stiffness properties of the hand tip E in the 3-muscle antagonistic arrangement is described.
(2.1) Two-Degrees-of-Freedom Control System
Feedback control systems for the respective links 101 and 102 are the feedback calculation processing units 241 and 242. The feedback calculation processing unit 241 obtains a feedback control torque (first correction-torque command value) TFB1 for the joint J1 by a feedback calculation based on a difference between the detected joint angle θe1 and the target joint angle ra1. Specifically, the feedback calculation processing unit 241 executes first feedback calculation processing for obtaining the feedback control torque TFB1 (first feedback calculation step). The feedback calculation processing unit 242 obtains a feedback control torque (second correction-torque command value) TFB2 for the joint J2 by a feedback calculation based on a difference between the detected joint angle θ2 and the target joint angle ra2. Specifically, the feedback calculation processing unit 242 executes second feedback calculation processing for obtaining the feedback control torque TFB2 (second feedback calculation step).
More specifically, the feedback calculation processing unit 241 includes a difference calculation processing unit 243, a gain adjusting unit 244, and a PID control unit 245. The difference calculation processing unit 243 calculates a difference (θ1−ra1) between the detected joint angle θ1 and the target joint angle ra1. The gain adjusting unit 244 sets the gain to 0 when the contact is detected by the touch sensor 403 and to 1 when the contact is not detected. The PID control unit 245 calculates the feedback control torque TFB1 for compensating for the difference (θ1−ra1) based on a transfer function KPID1.
Similarly, the feedback calculation processing unit 242 includes a difference calculation processing unit 246, a gain adjusting unit 247, and a PID control unit 248. The difference calculation processing unit 246 calculates a difference (θ1−ra2) between the detected joint angle θ2 and the target joint angle ra2. The gain adjusting unit 247 sets the gain to 0 when the contact is detected by the touch sensor 403 and to 1 when the contact is not detected. The PID control unit 248 calculates the feedback control torque TFB2 for compensating for the difference (θ2−ra2) based on a transfer function KPID2.
The feedforward control system is the feedforward calculation processing unit 240. The feedforward calculation processing unit 240 uses the driving-force command value U3 and the target joint angle ra1 to obtain a feedforward control torque (temporary first torque command value) TFFW1 for the join J1 by a feedforward calculation. Specifically, the feedforward calculation processing unit 240 executes first feedforward calculation processing for obtaining the feedforward control torque TFFW1 (first feedforward calculation step).
Similarly, the feedforward calculation processing unit 240 uses the driving-force command value U3 and the target joint angle ra2 to obtain a feedforward control torque (temporary second torque command value) TFFW2 for the join J2 by a feedforward calculation. Specifically, the feedforward calculation processing unit 240 executes second feedforward calculation processing for obtaining the feedforward control torque TFFW2 (second feedforward calculation step).
Here, by Formulas (4) and (5),
(uf1−ue3)r=TFFW1+TFB1=T1 (6)
(uf2−ue3)r=TFFW2+TFB2=T2 (7)
If the driving-force command values uf1, uf2, and ue3 are determined to satisfy Formulas (6) and (7), sums (first torque command value T1 and second torque command value T2) of the torques of the feedback control system and the feedforward control system can be given respectively to the joints J1 and J2. Accordingly, in order to obtain the driving-force command values uf1, uf2, and ue3 from the torque command values T1 and T2, Formulas (6) and (7) only need to be solved for the driving-force command values uf1 and uf2 to determine
uf1=T1/r+U3, uf2=T2/r+U3 (8)
Specifically, the driving-force command value calculation processing unit 261 only needs to calculate T1/r+U3 as the driving-force command value uf1, whereas the driving-force command value calculation processing unit 262 only needs to calculate T2/r+U3 as the driving-force command value uf2. More specifically, the driving-force command value calculation processing unit 261 includes a multiplication unit 263 for multiplying T1 by 1/r and an addition unit 264 for adding U3 to a calculation result T1/r of the multiplication unit 263. The driving-force command value calculation processing unit 262 includes a multiplication unit 265 for multiplying T2 by 1/r and an addition unit 266 for adding U3 to a calculation result T2/r of the multiplication unit 265.
Here, in the first embodiment, the actuators f1 and f2 generate the force only in the contraction direction,
the conditions:
uf1>0, uf2>0 (9)
are required to be satisfied simultaneously. By Formulas (8) and (9), when the torque command values T1 and T2 satisfy constraint conditions:
T1>−rU3, T2>−rU3 (10)
the manipulator 120 is positioned at the target joint angles ra1 and ra2 by the torque command values T1 and T2.
A detailed description is now given. First, T1>−r×U3 is set as a first constraint condition, and T2>−r×U3 is set as a second constraint condition. In this embodiment, the CPU 201 which is the control unit functions as a calculation processing unit 273 for calculating −r×U3 and a calculation processing unit 274 for calculating −r×U3.
When the torque command value T1 does not satisfy the first constraint condition based on the calculation result of the calculation processing unit 273, the constraint processing unit 271 corrects the torque command value T1 so as to satisfy the first constraint condition. Then, the constraint processing unit 271 executes first constraint processing to set the result of correction as the new torque command value T1 (first constraint step). Similarly, when the torque command value T2 does not satisfy the second constraint condition based on the calculation result of the calculation processing unit 274, the constraint processing unit 272 corrects the torque command value T2 so as to satisfy the second constraint condition. Then, the constraint processing unit 272 executes second constraint processing to set the result of correction as the new torque command value T2 (second constraint step). By the constraint operations described above, the manipulator 120 is positioned at the target joint angles ra1 and ra2 by the torque command values T1 and T2 for the respective joints J1 and J2.
(2.2) Feedback Control Systems
As described above, the stiffness of the manipulator 120 (that is, the hand tip E) can be varied by using the driving-force command value U3 for the bi-articular simultaneous driving actuator e3. However, when the gains of the feedback control systems are large, the stiffness of the joints based on the gains of the feedback control systems becomes disadvantageously dominant.
Therefore, as illustrated in
As a result, at arbitrary time, for example, time at which the contact of the hand tip E with a human or an object is detected, the stiffness of the manipulator 120 (hand tip E) can be quickly switched to the stiffness based on the elastic elements of the actuators f1, f2, and e3.
In this embodiment, the transfer functions of the PID control units 245 and 248 are set as expressed by:
(2.3) Feedforward Control Systems
First, Formulas (2) and (3) are rewritten as follows.
f1(θ1,{dot over (θ)}1,{umlaut over (θ)}1,θ2,{dot over (θ)}2,{umlaut over (θ)}2)=uf1r(1−krθ1−br{dot over (θ)}1)−ue3r(1+kr(θ1+θ2)+br({dot over (θ)}1+{dot over (θ)}2)) (13)
f2(θ1,{dot over (θ)}1,{umlaut over (θ)}1,θ2,{dot over (θ)}2,{umlaut over (θ)}2)=uf2r(1−krθ2−br{dot over (θ)}2)−ue3r(1+kr(θ1+θ2)+br({dot over (θ)}1+{dot over (θ)}2)) (14)
Based on the inverse dynamics, feedforward control inputs (temporary first driving-force command value and temporary second driving-force command value) uFf1 and uFf2 which are necessary for the detected joint angles θ1 and θ2 to track the target joint angles ra1 and ra2 are obtained as:
Specifically, the feedforward calculation processing unit 240 calculates the feedforward control inputs uFf1 and uFf2 based on the inverse dynamics.
For the two-degrees-of-freedom control illustrated in
TFFW1=(uFf1−U3)r (17)
TFFW2=(uFf2−U3)r (18)
only need to be satisfied. Specifically, the feedforward calculation processing unit 240 calculates the feedforward control torque TFFW1 by a calculation formula: TFFW1=(uFf1−U3)×r and the feedforward control torque TFFW2 by a calculation formula: TFFW2=(uFf2−U3)×r.
When at least one of the feedforward control inputs uFf1 and uFf2 becomes negative, a recalculation is required to be performed after the set value U3 is increased. Specifically, when at least one of the feedforward control inputs uFf1 and uFf2 becomes negative, the feedforward calculation processing unit 240 adds a positive value to the set value U3 of the driving-force command value ue3. Then, the feedforward calculation processing unit 240 recalculates the feedforward control torques TFFW1 and TFFW2. Alternatively, reaching time at the target trajectory may be changed to reduce an acceleration.
For the derivation described above, it is supposed that the elastic forces of the actuators f1, f2, and e3 are generated proportional to angles from θ1=0 and θ2=0 [deg]. In order to generate the feedforward control inputs with arbitrary angles as angles serving as references of generation of the elastic forces of the actuators f1, f2, and e3 (hereinafter referred to as “neutral posture angles”), when θc1 and θc2 are the neutral posture angles, the feedforward control inputs are obtained by satisfying instead of Formulas (15) and (16):
(2.4) Hand Tip Stiffness Control
In the case of the two-link manipulator 120, the hand tip E directly comes into contact with the external world. Therefore, it is important to control the stiffness of the hand tip E. The stiffness of the hand tip E is expressed by a stiffness ellipse as shown in
In the case of the two-link manipulator having the 3-pair 6-muscles described in Oshima et. al, the stiffness of the hand tip is obtained by controlling the sums of the contractile forces of the antagonistic pairs. For example, when the sums of the contractile forces of the respective antagonistic pairs are all set equal to each other, an axis of the stiffness ellipse is oriented in a direction which connects the first joint and the hand tip. However, the 3-muscle antagonistic arrangement used in this embodiment, the stiffness ellipse is determined by the neutral posture angles which correspond to an initial posture and a target posture. This is because, by setting the muscle command to the bi-articular simultaneous driving actuator to U3, the driving-force command values uf1 and uf2 for stabilization to the target posture are uniquely determined as:
In
First, focusing on a y axis, in the 3-muscle antagonistic arrangement and the 3-pair 6-muscle arrangement, axes of the stiffness ellipses are respectively parallel to the x axis and the y axis. It implies that, in a case where a disturbance is applied to the hand tip E in the x-axis direction and the y-axis direction, the hand tip E is displaced in the same direction as that of the disturbance.
In the 2-pair 4-muscle arrangement, however, the axes of the stiffness ellipses are inclined with respect to the x axis and the y axis. In response to the disturbance applied in the x-axis direction, the hand tip E displaces away from the x axis. By the above-mentioned fact, in a case where the hand tip E is located on the y axis, it is understood that compliance control based on the viscoelasticity of the muscles is achieved in the 3-muscle antagonistic arrangement and the 3-pair 6-muscle arrangement.
Next, focusing on positions other than on the y axis, in the 3-pair 6-muscle arrangement, the axes of the stiffness ellipses are always oriented toward the hand tip E and the point of origin. The 3-pair 6-muscle arrangement has a good compliance property that the hand tip E is displaced in the same direction as that of the disturbance in response to the disturbance in the direction described above.
In the case of the manipulator 120 having the 3-muscle antagonistic arrangement of this embodiment, the axes of the stiffness ellipses are oriented in approximately the same directions are those of the 3-pair 6-muscle arrangement, in particular, within the range of the hand tip±0.1 [m] from the initial posture.
In the case of the 2-pair 4-muscle arrangement, however, the stiffness ellipses greatly differ from each other. From the above-mentioned fact, the 3-muscles arrangement has a compliance property similar to that of the 3-pair 6-muscle arrangement owing to the effects of the bi-articular muscle.
Further, by changing the neutral posture angles with respect to the same target posture, the inclination of the stiffness ellipse at the hand tip position which is a target position can be controlled.
In
(2.5) Trajectory Design
In this embodiment, the target trajectory is set so that the hand tip E is driven on the y axis in a positive direction. Further, it is assumed that the target trajectory has an acceleration section, a constant-speed section, and a deceleration section. The target joint angles ra1 and ra2 for the joint angles θ1 and θ2 are obtained from the trajectory of the hand tip based on the inverse dynamics.
Next, the target stiffness is set so as to be high in the acceleration/deceleration sections and to be low in the constant-speed section. Specifically, the driving-force command value (contractile-force command value) ue3 for the bi-articular simultaneous driving actuator e3 in the acceleration/deceleration sections is regarded as U3max and the driving-force command value (contractile-force command value) ue3 for the bi-articular simultaneous driving actuator e3 in the constant-speed zone is regarded as U3min. In this embodiment, the trajectory having the acceleration section, the constant-speed section, and the deceleration section is used. However, a trajectory without the constant-speed section, for example, a minimum-jerk trajectory may be used. Moreover, if drive efficiency is not taken into consideration, the target stiffness may be set constant.
(3) Simulation
A simulation using the control system described in the preceding section is performed. It is assumed that physical parameters of the links 101 and 102 are the same. It is assumed that a length of each of the links 101 and 102 is 0.2 [m], inertia moments of the links 101 and 102 are I1=I2=1.3×10−3 [kgm2], a diameter of the moment arm is 0.05 [m], and the elasticity and the viscous constant are k=12 and b=0.003, respectively. For the target trajectory, start time ta of the constant-speed section=0.2747 [seconds], finish time tb of the constant-speed section=0.4746 [seconds], and positioning finish time tfin=0.75 [seconds]. Moreover, it is assumed that the neutral posture angles θc1 and θc2 by the elastic forces when the joint torques T1 and T2 do not act are joint angles at an intermediate point on the hand tip trajectory, and θc1=29.7 [deg] and θc2=120.7 [deg]. The driving-force command value (contractile-force command value) ue3 for the artificial muscle actuator e3 is expressed by:
U3max=3, U3min=1
Further, in this embodiment, in order to examine an identification error of a model of the two-degrees-of-freedom control system, it is assumed that the inertia moments are I1 and I2 in the generation of the feedforward inputs. In the simulation, however, the inertia moments of the links 101 and 102 are set as I1′=1.2I1 and I2′=1.2I2.
In
The detected joint angles θ1 and θ2 indicated by the solid lines overlap the target joint angles ral and ra2 indicated by the broken lines. Therefore, from
Further,
U3max=15, U3min=5
It is understood that the hand tip E tracks the target trajectory as in the case of
(Second Embodiment)
Next, a robotics apparatus according to a second embodiment of the present invention is described. In the first embodiment described above, the case where the actuators f1, f2, and e3 generate only the contractile forces (tensile forces) as the driving forces has been described. Specifically, in the first embodiment described above, the two-degrees-of-freedom control system taking the antagonistic drive into consideration is derived, and the trajectory tracking control is performed simultaneously with the hand tip stiffness control. The antagonistic drive has an advantage in that a backlash of the mechanism constituting the manipulator can be compensated for. For a McKibben artificial muscle which is one type of the artificial muscle actuators, however, a valve is required to be opened and closed to control an air pressure. Therefore, it is known that it is difficult to obtain a high responsiveness from the McKibben artificial muscle.
Therefore, the use of a variable stiffness actuator using an electromagnetic motor as a force-generating element and the combination of mechanical elements such as a spring and a damper to variably change a viscoelasticity as in the case of the artificial muscle actuator is actually studied. The variable stiffness actuator (VSA) has a feature in that an output direction of the force is not limited to the contraction direction.
In the second embodiments, the VSAs are used as the actuators f1, f2, and e3 which are a first driving source, a second driving source, and a third driving source. Then, a control system which performs non-antagonistic drive using pushing forces of the VSAs in a time zone in which a large output is required, for example, at time of acceleration/deceleration, and performs antagonistic drive in a time zone in which a backlash is required to be compensated for at the time of stabilization is designed. As a result, as compared with the first embodiment, stabilization time can be reduced. Specifically, in the second embodiment, the case where the actuators f1, f2, and e3 generate the contractile forces (tensile forces) and pushing forces as the driving forces is described. The arrangement of the actuators f1, f2, and e3 is the same as that of the first embodiment (
(1) Modeling
In the second embodiment, the realization of the viscoelastic property of the muscle is considered, which is expressed by Formula (1) by employing the parallel-type VSAs using the combination of the mechanism such as the electromagnetic motor and the spring as the artificial muscle actuators f1, f2, and e3. In the second embodiment, the electromagnetic motor is used as the force-generating element. In this case, each of the drivers 301, 302, and 303 (
The second embodiment using the VSAs differs from the first embodiment described above in that the pushing force can be generated without limiting the output direction of the force to the contraction direction. Motion equations of the two-link manipulator are Formulas (2) and (3) as in the case of the first embodiment.
(2) Control System Design
(2.1) Two-Degrees-of-Freedom Control System
In the first embodiment, the condition for allowing the artificial muscle actuators perform the antagonistic drive for generating the forces only in the contraction direction has been described. For performing the non-antagonistic drive for allowing the artificial muscle actuators to generate the pushing forces, Formula (10) needs to be dissatisfied. This is because the condition for allowing the artificial muscle actuators to generate the forces only in the contraction direction, which is expressed by Formula (9), is not satisfied as a result of the dissatisfaction of Formula (10). Therefore, in the second embodiment, the first coefficient h1 for adjusting an antagonistic degree to the link 101 and the second coefficient h2 for adjusting an antagonistic degree to the link 102 are introduced to modify Formula (10) as:
T1>−rh2U3, T2>−rh2U3 (23)
Specifically, T1>−r×h1×U3 is set as the first constraint condition, and T2>−r×h2×U3 is set as the second constraint condition. Here, by setting h1=1 and h2=1, Formula (23) becomes equal to Formula (10). Therefore, the antagonistic drive is performed. On the other hand, by setting h1>>1 and h2>>1, the non-antagonistic drive is performed.
Further, by smoothly changing the parameters h1 and h2, a transition from the antagonistic drive to the non-antagonistic drive can be achieved seamlessly. For the satisfaction of Formula (23), the sums of the feedback control inputs and the feedforward control inputs only need to be constrained, as illustrated in a block diagram of
The coefficient setting processing unit 281 sets the first coefficient h1 to 1 when a pivot direction of the link 101 by the actuator f1 and a pivot direction of the link 101 by the actuator e3 are opposite to each other. On the other hand, the coefficient setting processing unit 281 sets the first coefficient h1 to a value larger than 1 when the pivot direction of the link 101 by the actuator f1 and the pivot direction of the link 101 by the actuator e3 are the same.
Similarly, the coefficient setting processing unit 282 sets the second coefficient h2 to 1 when a pivot direction of the link 102 by the actuator f2 and a pivot direction of the link 102 by the actuator e3 are opposite to each other. On the other hand, the coefficient setting processing unit 282 sets the second coefficient h2 to a value larger than 1 when the pivot direction of the link 102 by the actuator f2 and the pivot direction of the link 102 by the actuator e3 are the same.
When the torque command value T1 does not satisfy the first constraint condition described above, the constraint processing unit 271 corrects the torque command value T1 so as to satisfy the first constraint condition and sets the result of correction as the new torque command value T1.
Similarly, when the torque command value T2 does not satisfy the second constraint condition described above, the constraint processing unit 272 corrects the torque command value T2 so as to satisfy the second constraint condition and sets the result of correction as the new torque command value T2.
(2.2) Feedforward Control Systems
In the first embodiment described above, when any one of the feedforward control inputs (temporary first driving-force command value and temporary second driving-force command value) uFf1 and uFf2 becomes negative, the antagonistic drive is not performed. Therefore, U3 is set again in such a case.
In the second embodiment, when any one of the feedforward control inputs uFf1 and uFf2 becomes negative, the force-generating elements of the VSAs generate the pushing forces. In this case, the viscoelastic coefficient becomes negative in the viscoelasticity model of the muscle based on Formula (1). However, the negative viscoelasticity is difficult to realize with a mechanical system. Therefore, in a section in which the generated force becomes negative, a viscoelastic coefficient of the parallel VSAs is set to 0. As a result, in a section in which uFf1<0, a recalculation is performed by replacing Formula (15) as:
In a section in which uFf2<0, a recalculation is performed by replacing Formula (16) as:
By substituting Formulas (15) and (16) into Formulas (6) and (7), the feedforward control torques TFFW1 and TFFW2 are obtained.
(2.3) Generation of Parameters for Adjusting Antagonistic Degree
In a section in which any one of the feedforward control inputs uFf1 and uFf2 becomes negative, the feedforward control with the non-antagonistic drive is performed. Thus, the condition of the antagonistic drive can be cancelled for the feedback control systems. Therefore, in the second embodiment, a parameter hn (n=1, 2) for adjusting the antagonistic degree is automatically generated by setting as hn=1 in a section in which the feedforward control input uFfn (n=1, 2) becomes positive and by setting as hn=10 in a section in which the feedforward control input uFfn becomes negative. In this case, if hn is discontinuously switched between hn=1 and hn=10, such discontinuous switching becomes a factor of chattering in the control inputs at the time of the transition between the antagonistic drive and the non-antagonistic drive. Therefore, the generated parameter hn is controlled to pass through a zero-phase lowpass filter in advance.
(3) Simulation
A simulation using the control system described in the preceding section is performed. Although the positioning finish time tfin=0.75 [seconds] is set in the first embodiment described above, the positioning finish time tfin=0.64 [seconds] is set in the second embodiment. The other conditions are the same as those of the simulation of the first embodiment described above.
In the second embodiment, because the positioning finish time is reduced, a large acceleration/deceleration force is required. Thus, the condition expressed by Formula (10) does not satisfied a condition in a section from about 0.45 [seconds] to 0.62 [seconds] for the link 101. Thus, the non-antagonistic drive is required for the link 101.
The parameter h for adjusting the antagonistic degree is shown in
The filtered parameter h is indicated by the solid line. As a result, the feedforward inputs for performing an efficient deceleration by the non-antagonistic drive in the deceleration section and allowing a seamless transition to the antagonistic drive in the stabilization section to compensate for the backlash of the mechanism are generated.
By the above-mentioned fact, it is understood that the driving-force command value uf1 generates the pushing force to perform the non-antagonistic drive. After 0.62 [seconds] at which the parameter h becomes 1, the non-antagonistic drive transitions to the antagonistic drive. As a result, all the actuators f1, f2, and e3 generate the contractile force. By the antagonistic drive, the backlash of the mechanism is compensated for. Therefore, the links 101 and 102 can be positioned at the target joint angles ra1 and ra2 with high accuracy.
The present invention is not limited to the embodiments described above. Various variations are possible by a person having ordinary skill in the art within the scope of the technical idea of the present invention.
Specifically, each of the processing operations of the embodiments described above is executed by the CPU 201 which is the control unit of the control device 200. Therefore, the recording medium on which the program for realizing the above-mentioned functions is recorded may be supplied to the control device 200 so that each of the processing operations is achieved by reading and executing the programs stored in the recording medium by the computer (CPU or MPU) of the control device 200. In this case, the program itself read out from the recording medium realizes the functions of the embodiments described above. Thus, the program itself and the recording medium on which the program is recorded constitute the present invention.
In the embodiments described above, the case where the computer-readable recording medium is the HDD 204 and the program 221 is stored in the HDD 204 has been described. However, the recording medium for storing the program is not limited thereto. The program 221 may be recorded on any recording medium as long as the recording medium is computer-readable. For example, as the recording medium for supplying the program, the ROM 202 and the recording disk 222, which are illustrated in
The program described in the embodiments described above may be downloaded through a network to be executed by a computer.
Further, the present invention is not limited to the realization of the functions in the embodiments described above by executing the program codes read out by the computer. The present invention encompasses the case where an operating system (OS) operating on the computer executes a part or all of the actual processing based on an instruction of the program code to realize the functions of the embodiments described above by the processing.
Further, the program code read out from the recording medium may be written on a memory included in an extension board inserted into the computer or an extension unit connected to the computer. The present invention encompasses the case where the CPU included in the extension board or the extension unit performs a part or all of the actual processing based on an instruction of the program code to realize the functions of the embodiments described above by the processing.
Further, although the case where the functions illustrated in
Other Embodiments
Embodiments of the present invention can also be realized by a computer of a system or apparatus that reads out and executes computer executable instructions recorded on a storage medium (e.g., non-transitory computer-readable storage medium) to perform the functions of one or more of the above-described embodiment(s) of the present invention, and by a method performed by the computer of the system or apparatus by, for example, reading out and executing the computer executable instructions from the storage medium to perform the functions of one or more of the above-described embodiment(s). The computer may comprise one or more of a central processing unit (CPU), micro processing unit (MPU), or other circuitry, and may include a network of separate computers or separate computer processors. The computer executable instructions may be provided to the computer, for example, from a network or the storage medium. The storage medium may include, for example, one or more of a hard disk, a random-access memory (RAM), a read only memory (ROM), a storage of distributed computing systems, an optical disk (such as a compact disc (CD), digital versatile disc (DVD), or Blu-ray Disc (BD)™), a flash memory device, a memory card, and the like.
While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application claims the benefit of Japanese Patent Application No. 2013-061607, filed Mar. 25, 2013, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2013-061607 | Mar 2013 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5648709 | Maeda | Jul 1997 | A |
7385686 | Shiba et al. | Jun 2008 | B2 |
20080041153 | Tokita | Feb 2008 | A1 |
20080288107 | Tokita | Nov 2008 | A1 |
20080312049 | Ido | Dec 2008 | A1 |
20100010639 | Ikeuchi | Jan 2010 | A1 |
20100050765 | Kadota | Mar 2010 | A1 |
20110218676 | Okazaki | Sep 2011 | A1 |
20120072025 | Takagi et al. | Mar 2012 | A1 |
20120072026 | Takagi | Mar 2012 | A1 |
20130211595 | Takagi | Aug 2013 | A1 |
20130211596 | Takagi | Aug 2013 | A1 |
20130345877 | Kose et al. | Dec 2013 | A1 |
Number | Date | Country |
---|---|---|
2012-86354 | May 2012 | JP |
Entry |
---|
Mechanical Properties of Robot Arm Operated with Muscle Coordinate System Consisted of Bi-articular Muscles and Mono-articular Muscles, by Toru Oshima, Tomohiro Fujikawa, and Minayori Kumamoto, Journal of the Japan Society of Precision Engineering, vol. 66, No. 1, pp. 141 to 146, Jan. 1, 2000. |
Motor Development of an Pneumatic Musculoskeletal Infant Robot, by Kenichi Narioka and Koh Hosoda, 2011, IEEE International Conference on Robotics and Automation, pp. 963 to 968, May 9, 2011. |
Number | Date | Country | |
---|---|---|---|
20140288703 A1 | Sep 2014 | US |