This invention relates to robotic operator control units and their design and communications protocols, and specifically to an architecture and methods for automatically configuring operator control units based on configuration schema and protocol definitions provided from a robot or payload.
Many robots such as, for example, tactical robots used for battlefield surveillance or bomb detection and handling, employ an operator control unit (OCU) allowing remote control of the robot and viewing of sensor and telemetry and other data from the robot. A preferred robot OCU typically has a graphical user interface (GUI) including, for example, instrument panels with instrument models displaying data from the robot, and a video display showing a video feed from one or more robot cameras. The GUI may also include menus and multiple screens, windows, or panels. Buttons, soft buttons, joysticks, touchscreens, and other user input devices present on the OCU receive operator control input, which is processed, formatted, and transmitted to the robot according to one or more communications protocols between the robot and the OCU.
Typically, a robot OCU is designed specifically for the robot type it is intended to control. Such a scenario results in an design OCU for every design or product line of robots, each OCU with a unique user interface, hard coded communication protocols, and specialized functionality for common tasks. Often little or no code may be shared among different OCU and protocol designs, and other elements such as, for example, but in mapping virtual instrument mapping. Further, with the robot end-user, this may create a difficult learning curve to drive the robot and limited ability to augment the user interface.
What is needed, therefore, is a unified framework for building common functionality into diverse operator control units. What is further needed is a system to support rapid control-unit prototyping and cross platform development for robotic controllers.
A unified framework is provided for building common functionality into diverse operator control units. A set of tools is provided for creating controller configurations for varied robot types. Preferred controllers do one or more the following: allow uploading of configuration files from a target robot, adhere to common user interface styles and standards, share common functionality, allow extendibility for unique functionality, provide flexibility for rapid prototype design, and allow dynamic communication protocol switching.
One embodiment provides a method of configuring a robot operator control unit including generating a configuration file for a robot; transmitting the configuration file from the robot to the operator control unit; adjusting control configurations on the operator control unit based on the configuration file; and adjusting display topology on the operator control unit based on the configuration file. Variations of this method may include adjusting menu options on the operator control unit based on the configuration file, or including a menu tree description including menu structure indicators and command identity indicators. A tagged markup language such as XML may be employed. The configuration file may include an indicator of one or more instrument scene graphics. Also, the configuration file may include one or more controller mapping indicators. To describe the robot visual control structure, the configuration file may use one of the one or more scene graph descriptors such as an OSG scene graph.
In further variations, the methods herein employ a configuration file including one or more protocol definitions. The protocol definitions may be formatted in a tagged markup language such as XML.
Another embodiment provides a method of configuring a robot operator control unit including storing, on a robot, a definition of a robot data communications protocol; communicating a request from a robot operator control unit to the robot for the definition of the robot data communications protocol; communicating, from the robot to the robot operator control unit, the definition of the robot data communications protocol; and configuring the robot operator control unit to receive telemetry data from the robot formatted according to the definition of the robot data communications protocol.
Variations may include one or more of the following: storing, on the robot, a definition of a robot control protocol; communicating a request from the robot operator control unit to the robot for the definition of the robot control protocol; communicating, from the robot to robot operator control unit, the definition of the robot control protocol; and configuring the robot operator control unit to send robot command and control data to the robot formatted according to the definition of the robot control protocol. In other variations, the communication of any protocol definitions from the robot to the operator control unit is accomplished by transmitting one or more configuration files from the robot to the operator control unit. The protocol definitions stored on the robot may be formatted with a tagged markup language, such as XML.
In still further variations, the method includes storing, on the robot, a definition of a robot function menu structure; communicating a request from the robot operator control unit to the robot for the definition of the robot function menu structure; communicating, from the robot to robot operator control unit, the definition of the robot function menu structure; and configuring the robot operator control unit to present a robot operating menu to a user formatted according to the definition of the robot function menu structure.
Another implementation provides a method of configuring a robot operator control unit including: storing, on a robot, a definition of a robot controller input mapping; communicating, in response to a request from a robot operator control unit, the definition of the robot controller input mapping from the robot to the robot operator control unit; and configuring the robot operator control unit to map input signals from at least one user input device, associated the robot operator control unit, according to the definition of the robot controller input mappings. The robot controller input mapping may be formatted with a tagged markup language such as XML.
Another implementation provides a method of configuring a robot operator control unit comprising: storing, on a robot, a definition of a robot instrument scene graphic; communicating, in response to a request from a robot operator control unit, the definition of the robot instrument scene graphic from the robot to the robot operator control unit; and configuring the robot operator control unit to display at least one robot control panel according to the definition of the robot instrument scene graphic.
Variations may include one or more of the following: the definition of the robot instrument scene graphic may be formatted as a scene graph such as an OSG scene graph. The scene graph may include a record of one or more sub scene graphs, which may correspond to respective robot control panels displayed on the robot operator control unit. The definition of the robot controller input mapping may formatted with a tagged markup language such as XML.
In another variation, the method may further include: storing, on the robot, a definition of a robot control protocol; communicating a request from the robot operator control unit to the robot for the definition of the robot control protocol; communicating, from the robot to robot operator control unit, the definition of the robot control protocol; and configuring the robot operator control unit to send robot command and control data to the robot formatted according to the definition of the robot control protocol.
In yet another variation, the method may further include: storing, on the robot, a definition of a robot controller input mapping; communicating, in response to a request from a robot operator control unit, the definition of the robot controller input mapping from the robot to the robot operator control unit; and configuring the robot operator control unit to map input signals from at least one user input device, associated the robot operator control unit, according to the definition of the robot controller input mappings.
In yet another variation, the method may further include: storing, on the robot, a definition of a robot controller input mapping; communicating, in response to a request from a robot operator control unit, the definition of the robot controller input mapping from the robot to the robot operator control unit; and configuring the robot operator control unit to map input signals from at least one user input device, associated the robot operator control unit, according to the definition of the robot controller input mappings.
And, in still another variation, the method may include: storing, on the robot, a definition of a robot function menu structure; communicating, in response to a request from a robot operator control unit, the definition of the robot function menu structure; and configuring the robot operator control unit to present a robot operating menu to a user formatted according to the definition of the robot function menu structure. The communication of the robot function menu structure from the robot to the operator control unit may be accomplished by transmitting one or more configuration files from the robot to the operator control unit.
In these several variations, the communication of all of the definitions from the robot to the operator control unit may be accomplished by transmitting a configuration file.
In another embodiment, a robot control system is provided including: a robot comprising a controller, a data memory operably coupled to the controller and holding a robot configuration file; an operator control unit comprising a scene graph display module, a protocol adapter module, a controller I/O module, and a connection marshaller module operative to request configuration data from the robot and configure the scene graph display module, the protocol adapter module, and the controller I/O module according to the configuration data.
In another embodiment, a robot operator control unit is provided including: a scene graph display module; a protocol adapter module; a controller I/O module; and a connection marshaller module operative to request configuration data from a robot and configure the scene graph display module, the protocol adapter module, and the controller I/O module according to the configuration file. The robot operator control unit may further include a publication/subscription database in which robot telemetry data is associated with nodes in a scene graph displayed by the scene graph display module.
The details of one or more embodiments of the invention are set forth in the accompanying drawings and the description below. Other features, objects, and advantages of the invention is apparent from the description and drawings, and from the claims.
Like reference symbols in the various drawings indicate like elements.
With regard to the high level system diagram depicted in
In further detail, OCU Builder 102 is preferably a stand-alone application allowing the user to visually plan the layout of the graphical instruments (i.e., 120) used on the OCU device 104. In this implementation, OCU Builder 102 allows importing three types of data; instrument models 108 in graphical formats (preferably one supported by the preferred scene graph API, OpenSceneGraph (OSG)), controller mapping definitions 112, and communication protocol definitions 110. In a preferred implementation, the controller mappings 112 and communication protocol definitions 110 will be in an XML format. A protocol definition 110 preferably includes a list of communication data, data types and Aware Pub/Sub (publication/subscription) database topic names used for each piece of data.
From the set of instrument models 108, the user will choose which instruments will be displayed in each panel on the screen of the OCU device 104. The user will also arrange the instrument layout in each panel. The user will then be able to select a robot communication protocol definition 110 and bind the robot telemetry data topics to the various instruments 120 in each panel. Likewise, the user is able to identify which controller input devices present on OCU 104 (keyboards, joysticks, gamepads, touchscreens, etc.) will be used, and bind the controller input mapping to the robot control data topics.
Referring still to
In use, in one scenario, default controller mappings for devices supported by a particular manufacturer will be loaded onto OCU devices prior to robot communication. Likewise, legacy robot protocols may be installed directly on OCU devices to support legacy protocols in use before the adoption of common architecture 100. To support control of legacy robots, default instrument-graphics data files will also require prior loading onto OCU devices.
Preferably, for generations of robots employing the common architecture 100, the protocol definitions 110 and instrument-graphics data files 108 will be loaded on the individual robots 106. Controller mapping definitions may or may not be loaded on the individual robots 106. Upon first contact with an OCU device 104, the robot 106 will upload its configuration data files 114 to the OCU 104. Future contact between such a matched OCU/robot pair may only require a quick checksum of configuration files on both robot 106 and OCU 104 to determine if an upload is necessary.
The depicted startup component 200 runs at startup of the OCU to bring the system up to an operating state. Startup component 200 instantiates objects and creates connections between those objects. Use of inter-object connections and interfaces will be further described below. In a preferred embodiment, startup component 200 is built with configuration scripts in the Python programming language. Of course, other suitable programming languages may be used. The remaining components are preferably programmed in C++, Python, or a suitable database query language.
After startup, startup component 200 and control to the OCU Framework, which is largely event driven. In this implementation, the OCU GUI initialization is data driven by the configuration files uploaded from the individual robots upon first contact. The OCU GUI software includes components 204, 206, 208, and 210 in
At the heart of the OCU Framework is an Publication/Subscription database 202 that drives communication between the robot network packets and the OCU graphical user interface (GUI). In use, when a new robot 106 is contacted by OCU 104, its GUI (a scene graph branch uploaded in a configuration file) will be added to the OCU for rendering. Instrument nodes within the scene graph will have been tagged with a subscription topic name defined by the OCU Builder 102. The data subscription module 204 associates the scene graph instrument nodes with their data streams by registering them with Pub/Sub registration module 202. During rendering frame updates, each instrument will retrieve its specific telemetry data via the subscribed topic in the Pub/Sub database. When communication packets arrive from each robot, the data within the packet will extracted and published to the same Pub/Sub database under topic names defined by the OCU Builder.
For implementations that support legacy robots, in order for legacy robots to not require software upgrades, default protocol definitions, controller-map definitions, and GUI scene graphs will preferably be stored directly on the OCU prior to contact with robots. During the robot/OCU connection handshaking, the OCU will determine which stored default GUI to load from memory and use with that particular robot.
Also included in OCU 104 is new robot discovery module 214, which manages the discovery and installation of configurations for robots employing configuration files 114 (
Legacy robot discovery module 216 includes several protocol modules that are employed selectively to discover and interact with legacy robots. In one implementation, module 216 includes a TMR (tactical mobile robot) protocol module, a EOD/PCC Protocol Module, a JAUS (Joint Architecture for Unmanned Systems) Protocol Module, and other suitable legacy protocol modules that may be needed for communication with whatever legacy robots OCU 104 is intended to control.
Referring still to
I/O transmitter component 222, in this implementation, includes a robot command module which performs I/O control to command conversion. The robot command module also contains command marshaller for grouping, ordering, and prioritizing commands to be sent. I/O transmitter component 222 also includes drivers for the transceiver that interacts with the robot controlled. In preferred implementations, the transceiver is a radio transceiver, but wireline communication channels such as, for example, a spooled fiber-optic cable, are also used.
Referring still to
OCU 104 further includes I/O controller component 212, which manages the status of various input/output components installed on OCU 104. Preferably, component 212 includes a keyboard/mouse driver, joystick driver, game controller (Yoke) driver, and puck driver. Other suitable I/O devices may also be interfaced. Control input flow will be further described below.
In the depicted implementation, but they joystick and keyboard input, the I/O controller component maps the joystick from signal values to key names. A “dead zone” conversion may be specified depending on the type of joystick and application. For example, a left joystick movement made on an attached Xbox controller joystick may be converted to a key name as shown in the XML piece in Table 1.
The I/O controller component also maps keyboard keys and joystick buttons to generic control functions, depending on the OCU mode or robot mode. Such mapping preferably accomplished in another XML file from the input keyname mapping shown in Table 1, however this is not limiting and the XML to map controller input to protocol output may be accomplished in various ways. Further while XML is preferred, of course other suitable conversion schemes may be used. As an example of keyname conversion to generic functions, the Table 1 keyname result is converted to generic functions by the XML code shown in Table 2.
The generic function mapping shown in Table 2 happens, in this implementation, in step 308 in
The protocol employed to transmit the resulting network packet may be customized in another file from that containing the code shown in Table 3.
The network packet is communicated to the robot from protocol adapter 314. From this point, the robot implements or handles the command. A single robot may have multiple activated protocol adapters for communication with different modules or payloads, for example.
Also depicted in
Future telemetry packets received from the robot at telemetry receiver 402 will be recognized, and sent via a connection to that robots protocol handler (or “protocol adapter”) 414. In this implementation, each protocol adapter has a packet dictionary describing the packet contents. When a packet comes in to a protocol adapter it looks up the structure of the packet in the protocol packet dictionary and demarshals or disassembles the packet into place in the robot Pub/Sub database by publishing the telemetry data received from the robot to the appropriate Pub/Sub notices in the OCU Pub/Sub database.
In one implementation, protocols are defined with a tagged markup language such as, for example, XML. A protocol is preferably defined as a protocol class containing protocol definitions for multiple packet types. An example XML code snippet defining a protocol class is shown in Table 4.
Typically, a packet protocol is defined by the datatype and data position within the packet. Table 5 shows an example protocol packet definition or Packbot robot telemetry data packet.
In this implementation, metadata associated with packet variable data may define screen position and the type of instrument viewed on the OCU. Table 6 shows an example metadata set associated with certain data in the Packbot telemetry data packet.
After a payload config file is generated in step 610, the config file is loaded onto the payload and step 612. The payload may then be installed on the robot in step 614. In this implementation, the robot next queries the payload to request the payload's config file in step 616. In step 618, the robot examines the payload config file to determine the appropriate manner to merge payload config file with the robot's own config file. This may be done, for example, but a set of rules that determine where, in the robots scene graph, a payload control interface with a certain functionality will be presented. For example, a manipulator arm may require a video view and joystick and button control configuration to be accessible on the OCU screen at or near the top level of the robot scene graph. Such a scenario provides the operator quick access to the functionality of the manipulator arm payload. As another example, a radiation detector payload may present in the robots scene graph in the top level instrument panel, a readily visible readout to indicate dangerous radiation levels. The config file merging functionality described in step 618 is preferably accomplished by the robots controller or computer. Next in step 620, robot provides emerged configuration file to the OCU upon request. The OCU been configured to itself as described herein to provide a control interface to both the robot and the payload according to the format of instructions contained in emerged configuration. More than one payload may be so configured on a single robot. The merging functionality performed by the robots controller in the program, for example, to give priority and position in the robot's scene graph and menu tree to a certain type of payload designated as a higher priority payload, over another type of payload designated as a lower priority payload.
While this payload configuration scheme is shown for this implementation, of course other schemes may be employed to configure payloads in the context of the OCU configuration systems described herein. For example, robots that are not provided the software to merge payload configuration files with their own robot configuration file may be provided with a combined configuration file (robot+payload) authored using the OCU builder. In another example scheme, payload config file may be sent separately to the OCU and associated with their host robot, and the operator may choose where to display the payload control panel.
This application claims priority under 35 U.S.C. §119(c) to U.S. provisional patent application Ser. No. 60/908,932, filed on Mar. 29, 2007, the entire contents of which are hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
60908932 | Mar 2007 | US |