ROBOT WITH HOT-SWAPPED END EFFECTORS
20170190050 ยท 2017-07-06
Inventors
Cpc classification
B25J9/1612
PERFORMING OPERATIONS; TRANSPORTING
B25J15/0066
PERFORMING OPERATIONS; TRANSPORTING
B25J19/0025
PERFORMING OPERATIONS; TRANSPORTING
B25J9/1646
PERFORMING OPERATIONS; TRANSPORTING
B25J15/0483
PERFORMING OPERATIONS; TRANSPORTING
B25J9/08
PERFORMING OPERATIONS; TRANSPORTING
G05B2219/31095
PHYSICS
G05B19/128
PHYSICS
B25J15/0491
PERFORMING OPERATIONS; TRANSPORTING
International classification
B25J15/00
PERFORMING OPERATIONS; TRANSPORTING
Abstract
Robots capable of accommodating dynamic replacement of end effectors load and run software that allows the end effector to be operated without change to the main control program. The driver may be dynamically linked and run during program execution when the corresponding end effector is detected. Typically, the robot controller will store a library of drivers, and load the appropriate driver when a new end effector is detected.
Claims
1.-8. (canceled)
9. A tool plate for use with a robot system, the robot system comprising (i) a robot body, (ii) a robot arm connected to the robot body, the robot arm having a distal end including a first connector, and (iii) a robot controller for controlling the robot arm and an end effector connected thereto via the first connector, the tool plate comprising: nonvolatile memory storing data comprising at least one of identification information or configuration information; a communication interface; a processor; and a second connector matable with the first connector for establishing bidirectional communication between the processor and the robot controller via the communication interface, the processor being configured to cause transmission of the data to the robot controller upon mating of the first and second connectors, wherein the tool plate is removably connectable to the robot arm.
10. The tool plate of claim 9, wherein the robot controller is adapted to self-configure based on the data and to control movements of the connected end effector based on the self-configuration.
11. The tool plate of claim 9, wherein the data includes both identification information and configuration information.
12. The tool plate of claim 9, wherein the data does not include configuration information, the robot system further comprising a database including records relating end-effector identification information to configuration information for the end effector, the controller being further adapted to query the database using the identification information to obtain the corresponding configuration information and to self-configure based thereon.
13. The tool plate of claim 9, further comprising a third connector matable with a fourth connector of a second end effector of a type different from that of the end effector.
14. The tool plate of claim 9, wherein the data includes configuration information.
15. The tool plate of claim 14, wherein the configuration information specifies a driver for controlling the end effector.
16. The tool plate of claim 15, wherein the configuration information comprises the driver.
17. The tool plate of claim 15, wherein the configuration information comprises one or more parameters usable to tailor a generic driver to the end effector.
18. The tool plate of claim 15, wherein the configuration information comprises an identifier specifying a type of the driver.
19. The tool plate of claim 9, further comprising circuitry for supporting bidirectional communication between the robot controller and the end effector.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0014] The foregoing will be more readily understood from the following detailed description of the invention, in particular, when taken in conjunction with the drawings, in which:
[0015]
[0016]
[0017]
[0018]
[0019]
DETAILED DESCRIPTION
[0020] Refer first to
[0021] The robot 100 includes one or more cameras 115. In
[0022] The robot 100 described above is, of course, only one of many possible robot embodiments in accordance with the invention, and the various features described above are representative rather than limiting. Various components and features can be modified in manners that will be readily apparent to persons of skill in the art. For example, the robot may, generally, have any number of arms (or, more generally, appendages), and each arm may have any number of degrees of freedom. The links of the arms need not be joined by rotational joints with one degree of freedom (such as, e.g., hinge joints), but may, for example, include ball-and-socket joints that provide two rotational degrees of freedom, or rail systems that facilitate translational motion.
[0023] Robot operation is governed by a robot controller 125, which monitors and alters robot positions, kinematics, dynamics, and forces; controls joint-level actuators to move the robot and/or its moving parts as directed by the robot controller; and high-level computational functionality that facilitates image-processing, user interaction, etc. The robot controller 125 may generally be implemented in hardware, software, or a combination of both on a general-purpose or special-purpose computer, which includes a bidirectional system bus 128 over which the central processing unit (CPU) 130, memory 133, and storage devices 136 communicate with each other as well as with internal or external input/output devices such as the screen 112, the camera 115, navigators 118, wrist cuffs, and any other input devices and/or external sensors. A conventional communication interface 138 facilitates communications over a network, such as the Internet and/or any other land-based or wireless telecommunications network or system. The storage devices 136 store an end-effector database 140 which, as explained in greater detail below, maintains information relevant to the various types of end effectors 110 that may be associated with the robot 100. The various modules may be programmed in any suitable programming language, including, without limitation, high-level languages such as C, C++, C#, Ada, Basic, Cobra, Fortran, Java, Lisp, Perl, Python, Ruby, or Object Pascal, or low-level assembly languages. The robot controller 125 may be implemented in software, hardware, or a combination.
[0024] The end effector 110 is connected to the robot arm 105 via a tool plate 150, which may accommodate more than one type of end effector 110 and, in some implementations, more than one end effector at a time. In this way, the tool plate 150 acts as a universal connector that is mechanically and electrically connected to the robot 100 via the robot arm 105, and which receives mechanical and electrical connectors from the end effector 110. In addition, the tool plate 150 assists the robot controller 125 in locating and installing the appropriate driver for a particular end effector 110. In various embodiments, the tool plate 150 may alert the robot controller when an end effector has been removed and replaced with a different (but compatible) end effector, providing information that allows the controller 125 to locate, load, and run the appropriate new driver in real time. The tool plate 150 may be one of several differently configured tool plates, each having identical mechanical and electrical connectors for mating with the robot arm 105 but different receptacles for receiving different end effectors. In this way, it is possible to accommodate more end effectors than the number of receptacles a single tool plate could physically support, and also facilitates system extensibility: as new end effectors with different connector configurations are developed, it is not necessary to replace the entire robot 100 or even the robot arm 105; rather, the ability to swap tool plates 150 means it is only necessary to design a new tool plate. Features of the tool plate 150 described below provide flexibility in this regard.
[0025]
[0026] With reference to
[0027] The operation and key internal components of the tool plate 150 are illustrated in
[0028] When mated mechanically and electrically with the robot arm 105, the tool plate 150 receives power and establishes communication with the robot controller 125 (see
[0029] When an end effector 420 is mated with the tool plate 150, various communications take place whose end result is to provide power to and enable communication between the robot controller 125 and the end effector 420, but also to enable the robot controller to self-configure in order to operate the end effector. In one representative implementation, the end effector is a dumb device with no onboard information to offer the robot controller. The tool plate 150 recognizes the end effector because of the receptacle configuration (e.g., it is designed to accept a single type of end effector), or from its mechanical and/or electrical characteristics, or because the tool plate accommodates only one type of end effector. In the illustrated embodiment, the memory 405 stores an identifier for each of the two possible end effectors 420.sub.1, 420.sub.2. When the control element 415 detects attachment of a particular end effector, it communicates the corresponding identifier to the robot controller 125 via the robot arm 105. The robot controller uses the communicated identifier to locate, in the database 140 (see
[0030] Detecting attachment of an end effector, either by the tool plate 150 or by the robot controller 125 (if, for example, the end effector is attached directly to a robot arm 105), can occur in an active or passive fashion. For example, the end effector or tool plate can initiate communication with the robot controller or the tool plate. Alternatively, the end effector or tool plate can, upon attachment, emit a characteristic signal that is detected by the robot controller polling for that signal. In either case, the robot controller 125 (or, in some implementations, the robot arm 105) sends commands to the end effector or the tool plate, which responds with data (I/O or status data, or stored configuration/identification data, depending on the command).
[0031] In some embodiments, the configuration information is stored in the memory 405 of the tool plate 150, and upon detecting attachment of an end effector, the control element 415 locates the corresponding configuration information in the memory 405 and transmits this to the robot controller 125. Once again, the configuration information may be the driver itself or a pointer thereto, enabling the robot controller 125 to download the latest version of the driver before self-configuring, or information that enables the robot controller 125 to parameterize a generic driver for the particular end effector. The memory 405 can also store end-effector-specific metrics such as cycle counts and hours of operation, allowing for preventive maintenance such as replacing suction cups when they are near their rated cycle limit.
[0032] In various implementations, any of the receptacles 420 can accommodate more than one type of end effector. In such cases, the end effector may store an identifier that is provided to (or retrieved by) the tool plate 150 upon establishing communication with a newly installed end effector. In this case, the tool plate 150 communicates the identifier to the robot controller 125 or, in some embodiments, uses the identifier to retrieve configuration information from the memory 405 and sends this information to the robot controller 125. The optimal distribution of informationi.e., whether to store configuration information on the tool plate 150 or in nonvolatile memory on the robot itselfrepresents a design choice. The more information that is stored on the tool plate 150, the more generic the robot can be, but the more memory the tool plate 150 will require. Another consideration is the need to update information or programming. For example, if the configuration data is subject to change over time, it may be desirable to store only unchanging information, such as an end-effector identifier, in the memory 405; the robot controller 125 can verify, at power-up or when installation of a new robot arm is detected, that it has the most current driver. It is possible, of course, to include functionality on the tool plate 150 enabling it to check for updates to stored configuration information before providing it to the robot, but such capability requires either on-board connectivity or the ability to access the network resources (e.g., via the Internet) through the robot.
[0033] In cases where the end effector is smart, i.e., contains its own configuration information, this can be retrieved by the tool plate 150 and provided to the robot controller 125. It is even possible for the tool plate 150 to communicate wirelessly with end effectors and/or the robot controller 125 using a suitable on-board wireless interface. If, on the other hand, the robot controller 125 is unable to locate a suitable driver, it may search for a driver in a remote (e.g., hosted) repository of drivers or may autonomously conduct an Internet search for the proper driver, installing and testing proper operation and functionality via the tool plate 150 before actually allowing the robot to operate normally.
[0034] As previously noted, the control element 415 of the tool plate 150 may be any suitable microprocessor or microcontroller, depending on the functions that the tool plate is to perform. For example, the control element 415 may be a programmable microcontroller designed expressly for embedded operation, or one or more conventional processors such as the Pentium or Celeron family of processors manufactured by Intel Corporation of Santa Clara, Calif. The memory 405 may store programs and/or data relating to the operations described above. The memory 405 may include random access memory (RAM), read only memory (ROM), and/or FLASH memory residing on commonly available hardware such as one or more application specific integrated circuits (ASIC), field programmable gate arrays (FPGA), electrically erasable programmable read-only memories (EEPROM), programmable read-only memories (PROM), or programmable logic devices (PLD).
[0035] The terms and expressions employed herein are used as terms and expressions of description and not of limitation, and there is no intention, in the use of such terms and expressions, of excluding any equivalents of the features shown and described or portions thereof. In addition, having described certain embodiments of the invention, it will be apparent to those of ordinary skill in the art that other embodiments incorporating the concepts disclosed herein may be used without departing from the spirit and scope of the invention. In particular, embodiments of the invention need not include all of the features or have all of the advantages described herein. Rather, they may possess any subset or combination of features and advantages. Accordingly, the described embodiments are to be considered in all respects as only illustrative and not restrictive.