The present disclosure generally relates to systems and methods for controlling a robot such as a prosthetic and in particular to systems and methods for simultaneous position and impedance control for myoelectric interfaces.
Compliant human-robot interaction is an essential component for integrating robots into everyday life. Many daily activities require variable impedance, and humans desire the same functionality when interacting with robots. Impedance control allows safe interaction with uncertain environments, enhancing both utility and viability. Surface electromyography (sEMG) has been identified as a candidate for naturally controlling variable impedance. During co-contraction, surface signals detected by sEMG correlate with the stiffness of corresponding joints. This correlation may be used in myoelectric impedance controllers. A neural network was trained to map the intensity of flexor and extensor forearm sEMG to the stiffness value of a prosthetic hand as it opened and closed, which in turn may be used to grip uncertain objects with the appropriate force. A similar impedance control, tele-impedance, may be applied to control a prosthetic hand aimed at generalizing grasping capabilities using kinematic synergies. The sEMG of quadriceps and hamstring muscles may be mapped to control stiffness and set-point angle for joint impedance of a prosthetic knee. There is thus a natural connection between sEMG and compliant controllers, with the controller designed to vary uniform stiffness of a prosthetic device based on sEMG.
Studies in neurophysiology indicate that humans not only control the intensity of their joint stiffness, but also the direction. While interacting in unstable environments, humans adapt their muscle activity to stabilize motion relative to the direction of instability. This suggests that multi-directional impedance control would provide a more natural extension to, and enhance capabilities of, human-robot interfaces. However, due to transient changes in sEMG, conventional myoelectric interfaces have struggled to provide reliable simultaneous control of motion, thereby deterring EMG-based impedance controllers from extending beyond a single degree-of-freedom (DOF).
The patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawings will be provided by the Office upon request and payment of the necessary fee.
Corresponding reference characters indicate corresponding elements among the view of the drawings. The headings used in the figures do not limit the scope of the claims.
This disclosure presents a novel control scheme for the first time offering multi-directional impedance and position control in myoelectric interfaces. Recent works have shown that motor skill learning properties equally apply to myoelectric controls. Properties such as control refinement, retention, generalization, and transfer allow users to learn simultaneous and proportional motion simply by interacting with a myoelectric interface, regardless of its initial intuitiveness. The proposed scheme expands on these motor learning approaches by implementing a multidirectional impedance controller in this framework. Two definitions of stiffness are defined herein:
1) anisotropic: directional (non-uniform) stiffness, such that external forces produce a displacement magnitude dependent on the direction of the force.
2) isotropic: non-directional (uniform) stiffness, such that external forces produce a displacement magnitude independent of the direction of the force.
This technique demonstrates motor skill learning without requiring retraining between sessions. Using sEMG inputs from upper limb muscles, users simultaneously control both the stiffness and set-point of 3-DOFs. Users stabilize control in the presence of external forces in an analogous way to natural limb movements. Despite having no haptic feedback, subjects learn to tune the stiffness of the object being controlled to stabilize movement along desired paths.
A five-session experiment was designed for subjects to learn the multi-directional impedance control with a 3-DOF virtual myoelectric interface. Throughout each session, performance metrics verified the subjects were demonstrating characteristics of standard motor skill-type learning. Each subject learned the general controls while performing tasks without any external forces for three sessions on distinct days. Subjects returned for two additional sessions in which additional tasks were introduced requiring either anisotropic or isotropic impedance control. Finally, the method was demonstrated on a KUKA Light Weight Robot 4 (LWR 4) with a Touch Bionics iLIMB Ultra prosthetic hand while grasping objects and interacting with external forces.
The multi-directional impedance control algorithm is an extension of the velocity control method. i incoming sEMG signals, e, are linearly mapped to c output controls, u, after accounting for a muscle activity threshold a and output gain g:
u=gW[(e−o′)ou(e−o′)] (1)
where o is an element-wise matrix multiplication, u(*) is the unit step function, and W is a (c×i) mapping function designed to map the entire output space using equal contributions from all inputs (
Subjects have consistently shown a capacity to learn such a mapping function regardless of its intuitiveness. When c<i, the mapping is subjective, introducing control redundancies. That is, the magnitude of the output, |u|, is independent of the magnitude of the input, |e|, because some muscle contributions may cancel out the contributions of others with respect to the resulting motion.
The proposed multi-directional impedance control uses this redundancy to generate c directional stiffness outputs k with magnitudes proportional to |e|. Thus,
k=gS|e−o′)ou(e−o′)] (2)
where S=abs(W) is the element-wise absolute value of matrix W (
With both a motion and stiffness component, the impedance controller is adapted with
a=ko[x−x
d
]−bI
c
v+f
ext (3)
where x and v are the current position and velocity of the object, a is the resulting acceleration, Ic is the c×c identity matrix, b is a scalar (isotropic damping term, fext is external force, and xd is the commanded set point:
x
d
=x+uΔt (4)
where Δt is the sampling rate. Inertia tensors are ignored in the virtual interface.
In this experiment, EMG inputs from four muscles (i=4)—Biceps Brachii (BB), Triceps Brachii (TB), Flexor Carpi Ulnaris (FCU), and Extensor Carpi Ulnaris (ECU)—are mapped to three control outputs (c=3)—x, y, and z (virtual)/hand motion (robot)—and W is arbitrarily chosen following the three criteria specified in (
The corresponding S is then (see
1) EMG Processing: The raw sEMG signals of four upper arm muscles are collected, rectified, low-pass filtered (fourth-order zero-lag Butterworth, cut-off 3 Hz), and normalized with respect to the subject's maximal voluntary contraction (MVC) to generate e. These signals are then subsampled to
for input to (4). To simulate continuous control, (3) is computed at f=2000 Hz. For stability, b=2f, and all elements of k were scaled between
based on MVC values. This ensures the system is both stable and critically damped at its highest stiffness.
Before each session, subjects perform their MVC for each muscle to scale sEMG and set external force magnitudes during isotropic and anisotropic tasks.
2) Robot Control: LWR 4 operates in Cartesian impedance control, effectively replacing (3) with its internal system and actual external forces. During this session, (2) and (4) were updated at 200 Hz according to the specifications of the robot. In contrast, only velocity commands can be sent to the iLIMB, so all compliance interaction was reserved for LWR 4. Velocity commands were sent via a wired connection and/or a wireless connection (e.g., Bluetooth) to the iLIMB for the purpose of opening and closing all fingers, in correspondence with Control Axis 3, also at 200 Hz.
Four wireless sEMG electrodes (Delsys Trigno Wireless) were acquired from the BB, TB, FCU, and ECU with a gain of 500, digitized with 16-bit depth at a frequency of 1926 Hz and broadcast via TCP. Both the virtual reality (VR) and robot interfaces receive commands at 200 Hz from a custom program using C++ and OpenGL API. The setup for interacting with both the VR and robot are shown in
Subjects, unaware how to control the interface, attended five sessions across a span of two weeks.
Throughout the experiment three different task variations were introduced (
External forces are applied with a magnitude proportional to 75% MVC, such that subjects must use different control strategies for anisotropic and isotropic tasks. With 75% MVC required to prevent external forces from displacing the helicopter, it would be difficult and exhausting for subjects to use isotropic stiffness to complete anisotropic tasks.
Subjects returned on separate days for each of sessions two and three, completing an additional 50 control tasks without the initial exploration time. With only control tasks, subjects focused on learning directional movements with both speed and precision for the first 150 tasks.
Session four introduced external forces, and subjects were asked to complete 75 trials. The tasks were distributed as 50% control tasks, 25% anisotropic tasks, and 25% isotropic tasks.
indicates data missing or illegible when filed
Subjects were able to detect anisotropic tasks before the task started, but were unaware whether the other 75% of trials were control tasks or isotropic tasks until arriving at the helipad. This encouraged subjects to land with high isotropic stiffness in every trial. Session five provided the same task distribution for 75 additional trials, a total of 300 trials over the entire experiment.
Trials were analyzed based on performance metrics from all subjects. No quantifiable data was collected for the robot demonstration, as its intent is a proof of concept for intuitive transfer to physical systems.
CT is the task completion time. TP is the throughput, a measure of speed and accuracy 1221. TS is the task score, a measure of speed and precision following the indicated path. n is the overall trial number, k is initial performance, and β shows the learning rate indicative of better performance over time.
Paths are randomly generated using cubic Bezier curves:
B(z)=(1−z)2Po+3(1−z)2P1+3(1−z)2P2+z3P3 (7)
where Po and P3 are the origin and helipad position, respectively, and P1,2 are random points on the screen. Particles are distributed at random offsets
through uniform samples of t ∈ [0,1], with r the radius of the helicopter. Particles begin to disappear sequentially along the path three seconds after the start of the trial, until the last particle disappears eight seconds after the start of the trial. This encourages the subject to balance speed and precision while reaching the target, and TS is the number of particles collected over the total number of particles.
Task difficulty is given via the Shannon Formulation:
where WD is the constant helipad diameter and D=∫ B(z)dt is the path distance. Then,
2) External Force Impact: The specific impact of external forces is observed through changes in percentage of multiple muscle control PM. Although subjects could theoretically complete all tasks using only single muscle activations, optimal performance, both with and without external forces, requires a more direct path involving simultaneous activity from multiple muscles. PM measures the percentage of time that subjects activate two or more muscles for a given trial.
Five healthy subjects (all male, age 20-28) participated in the experiment. All subjects gave informed consent as approved by the ASU IRB (Protocol: #1201007252). Subjects reported no fatigue throughout the first three sessions, but slight fatigue during sessions four and five due to the high muscle activity required to overcome external forces.
CT, TP and TS from all control trials were fit to Table I, with parameter values presented in Table II. Each metric shows a significant learning rate (β>0,p<0.05) despite time off between sessions. Performance metric progression for each task is shown in
During control tasks, subjects can use single muscle contractions to coarsely follow the path (
One subject returned after one month to apply controls to the robot. The subject reported the controls easy to remember, and intuitive to transfer. Example anisotropic and isotropic stiffness tasks are shown in
Referring to
The computer system 500 may be a general computing system is capable of executing a computer program product to execute a computer process. Data and program files may be input to the computer system 500, which reads the files and executes the programs therein. Some of the elements of a general purpose computer system 500 are shown in
The I/O section 504 is connected to one or more user-interface devices (e.g., a keyboard 516 and a display unit 518), a disc storage unit 512, and a disc drive unit 520. In the case of a tablet device, the input may be through a touch screen, voice commands, and/or Bluetooth connected keyboard, among other input mechanisms. Generally, the disc drive unit 520 is a DVD/CD-ROM drive unit capable of reading the DVD/CD-ROM medium 510, which typically contains programs and data 522. Computer program products containing mechanisms to effectuate the systems and methods in accordance with the presently described technology may reside in the memory section 504, on a disc storage unit 512, on the DVD/CD-ROM medium 510 of the computer system 500, or on external storage devices made available via a cloud computing architecture with such computer program products, including one or more database management products, web server products, application server products, and/or other additional software components. Alternatively, a disc drive unit 520 may be replaced or supplemented by an optical drive unit, a flash drive unit, magnetic drive unit, or other storage medium drive unit. Similarly, the disc drive unit 520 may be replaced or supplemented with random access memory (RAM), magnetic memory, optical memory, and/or various other possible forms of semiconductor based memories commonly found in smart phones and tablets.
The network adapter 524 is capable of connecting the computer system 500 to a network via the network link 514, through which the computer system can receive instructions and data. Examples of such systems include personal computers, Intel or PowerPC-based computing systems, AMD-based computing systems and other systems running a Windows-based, a UNIX-based, or other operating system. It should be understood that computing systems may also embody devices such as terminals, workstations, mobile phones, tablets, laptops, personal computers, multimedia consoles, gaming consoles, set top boxes, and the like.
When used in a LAN-networking environment, the computer system 500 is connected (by wired connection or wirelessly) to a local network through the network interface or adapter 524, which is one type of communications device. When used in a WAN-networking environment, the computer system 500 typically includes a modem, a network adapter, or any other type of communications device for establishing communications over the wide area network. In a networked environment, program modules depicted relative to the computer system 500 or portions thereof, may be stored in a remote memory storage device. It is appreciated that the network connections shown are examples of communications devices for and other means of establishing a communications link between the computers may be used.
In an example implementation, robot interfaces, VR interfaces, myoelectric interfaces, multidirectional impedance control software and other modules and services may be embodied by instructions stored on such storage systems and executed by the processor 502. Some or all of the operations described herein may be performed by the processor 502. Further, local computing systems, remote data sources and/or services, and other associated logic represent firmware, hardware, and/or software configured to control operations of the robot, the various interfaces, the electrodes, and/or other computing units or components of the systems and devices described herein. Such services may be implemented using a general purpose computer and specialized software (such as a server executing service software), a special purpose computing system and specialized software (such as a mobile device or network appliance executing service software), or other computing configurations. In addition, one or more functionalities of the systems and methods disclosed herein may be generated by the processor 502 and a user may interact with a Graphical User Interface (GUI) using one or more user-interface devices (e.g., the keyboard 516, the display unit 518, and other user devices) with some of the data in use directly coming from online sources and data stores.
The system set forth in
In the present disclosure, the methods disclosed may be implemented as sets of instructions or software readable by a device. Further, it is understood that the specific order or hierarchy of steps in the methods disclosed are instances of example approaches. Based upon design preferences, it is understood that the specific order or hierarchy of steps in the method can be rearranged while remaining within the disclosed subject matter. The accompanying method claims present elements of the various steps in a sample order, and are not necessarily meant to be limited to the specific order or hierarchy presented.
The described disclosure may be provided as a computer program product, or software, that may include a non-transitory machine-readable medium having stored thereon instructions, which may be used to program a computer system (or other electronic devices) to perform a process according to the present disclosure. A machine-readable medium includes any mechanism for storing information in a form (e.g., software, processing application) readable by a machine (e.g., a computer). The machine-readable medium may include, but is not limited to, magnetic storage medium, optical storage medium; magneto-optical storage medium, read only memory (ROM); random access memory (RAM); erasable programmable memory (e.g., EPROM and EEPROM); flash memory; or other types of medium suitable for storing electronic instructions.
The description above includes example systems, methods, techniques, instruction sequences, and/or computer program products that embody techniques of the present disclosure. However, it is understood that the described disclosure may be practiced without these specific details.
It should be understood from the foregoing that, while particular implementations have been illustrated and described, various modifications can be made thereto without departing from the spirit and scope of the invention as will be apparent to those skilled in the art. Such changes and modifications are within the scope and teachings of this invention as defined in the claims appended hereto.
This is a non-provisional application that claims benefit to U.S. provisional application Ser. No. 62/346,644, filed on Jun. 7, 2016, which is herein incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
62346644 | Jun 2016 | US |