1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346
|
============
Introduction
============
.. contents:: Table of Contents
:depth: 1
:local:
:backlinks: none
Welcome
=======
Robot Raconteur is a powerful communication framework for robotics and automation systems. While intended for
use with robotics, it is flexible enough to be used for other applications, including building control,
infrastructure, and Internet-of-Things applications, among many others. The Robot Raconteur ecosystem consists of
several major segments:
* The `Robot Raconteur Framework Standards <https://github.com/robotraconteur/robotraconteur_standards>`_,
which define the overall architecture, behavior, protocols, and data formats.
* The official implementations of the Robot Raconteur framework, including
`Robot Raconteur Core <https://github.com/robotraconteur/robotraconteur>`_,
`Robot Raconteur Web <https://github.com/robotraconteur/RobotRaconteurWeb>`_,
and `Robot Raconteur Lite <https://github.com/robotraconteur/robotraconteurlite>`_.
* `Standard Service Definitions <https://github.com/robotraconteur/robotraconteur_standard_robdef>`_ and
`Companion Libraries <https://github.com/robotraconteur/robotraconteur_companion>`_ that support these standards.
* `Device Drivers, Utilities, User Interfaces, and Support Libraries <https://github.com/robotraconteur/robotraconteur-directory>`_.
* Many of these components will utilize Standard Types and the Companion Libraries.
* Related projects such as the `PyRI Open-Source Teach Pendant <https://github.com/pyri-project/pyri-core>`_.
The overall Robot Raconteur ecosystem is vast and can be somewhat overwhelming to a new user. This guide will help ease
a new user into understanding and taking full advantage of the ecosystem.
.. note::
To help locate available components, refer to the
`Robot Raconteur Directory <https://github.com/robotraconteur/robotraconteur-directory>`_.
.. note::
This guide is intended to be an introduction and tutorial. See
`Robot Raconteur Documentation <https://github.com/robotraconteur/robotraconteur/wiki/Documentation>`_ for a full list
of available reference documentation.
Robot Raconteur has been used on numerous projects and received funding from the United States DoD Advanced
Robotics in Manufacturing (ARM) Institute and New York State.
Presentations
-------------
* Robot Raconteur an Interoperable Middleware: https://www.youtube.com/watch?v=3jhDXIRUiQY
* ROS-Industrial 2022 presentation: https://www.youtube.com/watch?v=nxIUeRPE16k
* ROS Hardware Interfaces Presentation: https://www.youtube.com/watch?v=NqwgbjatKJE
Papers
------
`J. Wason and J. T. Wen, "Robot Raconteur® Updates on an Open Source Interoperable Middleware for Robotics", in Proc. IEEE Conference on Automation Science and Engineering, 2023, pp. 1-8. <https://files2.wasontech.com/RobotRaconteur_CASE2023.pdf>`_
`H. He, B. Aksoy, G. Saunders, J. Wason, and J. T. Wen, "Plug-and-play software architecture for coordinating multiple industrial robots and sensors from multiple vendors", in Proc. IEEE Conference on Automation Science and Engineering, 2023, pp. 1-8. <https://files2.wasontech.com/RobotRaconteur_CASE2023_plugandplay.pdf>`_
`J. Wason, "Robot Raconteur® version 0.8: An Updated Communication System for Robotics, Automation, Building Control, and the Internet of Things", in Proc. IEEE Conference on Automation Science and Engineering, 2016, pp. 595-602. <https://files2.wasontech.com/RobotRaconteur_CASE2016.pdf>`_
`J. Wason and J. T. Wen, "Robot Raconteur: A Communication Architecture and Library for Robotic and Automation Systems", in Proc. IEEE Conference on Automation Science and Engineering, 2011, pp. 761-766. <https://files2.wasontech.com/RobotRaconteur_CASE2011.pdf>`_
Examples
--------
* Microassembly: https://www.youtube.com/watch?v=2KrOI6GOogE
* Human Guided Dual-Arm Manipulation: https://www.youtube.com/watch?v=OfFp_3kPHCk
* Cooperative Robotics: https://www.youtube.com/watch?v=FQqaPFqu0Gk
* Smart Conference Room: https://sites.ecse.rpi.edu/~rjradke/papers/afshari-buildsys15.pdf
* Assistive Robotics: https://www.youtube.com/watch?v=5JM8bgZvMg0
* PyRI Open-Source Teach Pendant: https://www.youtube.com/watch?v=9KSYgGpG8mk
Features
========
The Robot Raconteur framework is an advanced form of "Remote Procedure Call" (RPC) middleware specially designed
for robotics and automation systems. This specialization is designed to improve interactions with robots in terms of
organization and semantics of interacting with devices, discovery/connection management, data types, data communication
latency, and reliability. Robot Raconteur is an "augmented-object oriented" RPC system. The "augmented" means
that the objects have extra "member types" which support communication semantics required for robotics applications.
This unique design allows for true plug-and-play operation of Robot Raconteur, and significantly greater ease-of-use
compared to competing frameworks.
.. note::
Robot Raconteur has a unique "augmented object-oriented" design and is very different from
ROS Middleware, which is a pub-sub system. Robot Raconteur can provide similar functionality to pub-sub
systems using "Subscriptions", but the focus is on the client-service model.
Robot Raconteur currently supports the following platforms:
* Windows (>WinXP)
* Linux
* MacOS (>10)
* Android
* iOS
* FreeBSD
* WebAssembly (Robot Raconteur Core with Emscripten)
* Web Browser (Robot Raconteur Web)
* ASP.NET Server (Robot Raconteur Web)
* Arduino (specialized demo)
Support is planned for VxWorks and QNX.
The following computer languages are supported:
* C++
* Python
* MATLAB
* C#
* Java
* LabView
* ANSI C (under development)
* JavaScript (under development)
Support is planned for `Rust <https://github.com/robotraconteur/robotraconteur/issues/86>`_,
`Go <https://github.com/robotraconteur/robotraconteur/issues/87>`_, and
`Lua <https://github.com/robotraconteur/robotraconteur/issues/88>`_.
.. Note::
Most applications will use the Robot Raconteur Core implementation. Supported languages for the core library are
C++, Python, MATLAB, C#, Java, and LabView. The LabView implementation is a commercial add-on available from
Wason Technology, LLC. See the
`Installation <https://github.com/robotraconteur/robotraconteur/blob/master/docs/common/installation.md>`_ page for
instructions of how to obtain the LabView add-on.
Robot Raconteur has these additional differentiating features:
* Compatibility: 22 platforms/architectures, 7 languages, 6 transport technologies
* Client-service model
* “Augmented Object-Oriented” model
* Forward and backwards compatibility using polymorphism
* Plug and play capability
* Request-Response, streaming, and “most recent”
* TLS, certificates, and password security
* Two central certificate authority chains, by Digicert and private HSM
* Certificates available at nominal cost
* Compatible with Web and Cloud using WebSockets
* Node and service discovery
* Long-Term compatibility
* Open Source, Apache 2.0 License, first open source release Fall 2018
* Open Standards: https://github.com/robotraconteur/robotraconteur_standards
* Core library package “robotraconteur” available in ROS Noetic and ROS Humble
* Robot Raconteur ↔ ROS 2 Bridge: https://github.com/robotraconteur-contrib/robotraconteur_ros2_bridge
.. _client-service-model:
Client-Service Object-Oriented Model
====================================
Robot Raconteur uses an object-oriented client-service model. "Nodes" communicate with each other by passing
"messages" using "transports". All communication between nodes is "packed" into messages, and an
"augmented object-oriented" protocol is built on top of this message passing layer.
The figure below shows the basic architecture of a Robot Raconteur client and service. Services contain some resource
that clients need to access. This resource may be something physical like a robot, or something virtual like a software
application. The service consists of one or more "objects". The objective of Robot Raconteur is to reflect these objects
to the client, creating "object references", sometimes referred to as "proxies". Robot Raconteur is designed to make it
appear to the user as if the object exists locally in the client as much as possible. Essentially, Robot Raconteur
encapsulates the complex communication from the client user, so the user, for the most part, does not need to be concerned
with the details of the communication.
.. image:: ../../python/source/tutorial/figures/client-service.svg
:alt: Configuration of Client-Service communication
:name: ClientServiceConfiguration
:width: 400
Clients "connect" to the service using a known URL or use "discovery" to find the service on the network. Once
connected, the user can communicate with the service using the object "members". In a typical object-oriented
language, these members would include "properties", "functions", and "events". Robot Raconteur uses eight member
types to better handle the types of communication required for robotics:
* ``property``
* ``function``
* ``event``
* ``objref``
* ``pipe``
* ``callback``
* ``wire``
* ``memory``
The use of these members will be discussed throughout the examples.
Request/response members support transparent try/catch exception handling, meaning that exceptions are transported
automatically to the caller. This reduces the amount of boilerplate error-handling code required.
With Robot Raconteur, objects are always passed by "reference," while data is passed by "value." This means that
the service always owns the objects, while data is copied and passed between nodes. The following data types are
supported:
* Numeric primitives including integers, floating points, and complex numbers
* Arrays and multi-dim arrays
* Strings
* Structures
* Pods
* Named arrays
* Containers (map, list)
See the `Framework` documentation for more information.
Plug-and-Play Interoperability
==============================
Robot Raconteur supports plug-and-play operation using two methods:
* Dynamic type and proxy handling
* Clients connecting to a service receive a “Service Definition” and can dynamically handle objects and value types.
* Used for scripting languages like MATLAB and Python.
* Interoperability through common or standardized “Service Definitions”
* Clients are designed to connect to specific defined types. If the service implements the expected types, the client can interact with the service.
* Standardized types are available for many common devices and systems.
* Deployed systems will require standardized types for interoperability.
* Dynamic typing for scripting is intended for laboratory and prototyping use.
Discovery and Subscriptions
===========================
Robot Raconteur uses "discovery" to find nodes. Nodes can be running on the same computer, within the same process
(intraprocess), connected over a network, or connected using a peripheral connection such as USB. Discovery uses
transport-specific communication protocols to detect and enumerate available services. For a normal Ethernet local
area network, IPv6 multicast packets are used to detect nodes.
.. note::
IPv6 uses automatic 128-bit "link-local" addresses that do not require configuration. Robot Raconteur by default
uses IPv6 addresses.
Discovery can be used to detect nodes and then create connections, or it can be combined with automatic connection
management using "Subscriptions". Subscriptions build on discovery and create robust connections to services based
on connection criteria or based on a URL.
Standard Service Types
======================
Standard service types are used to allow for interoperability between services. For example, robots will often
implement the standard ``com.robotraconteur.robotics.robot.Robot`` object type, defined in the
``com.robotraconteur.robotics.robot`` service definition. Clients that are designed to understand the ``Robot``
standard type will be able to interact with any service that implements this type.
.. note::
A separate repository is used to store the
`Standard Service Types <https://github.com/robotraconteur/robotraconteur_standard_robdef>`_,
often referred to as "standard robdef".
The companion libraries `Robot Raconteur Companion <https://github.com/robotraconteur/robotraconteur_companion>`_,
`Robot Raconteur Companion Python <https://github.com/robotraconteur/robotraconteur_companion_python>`_, and
`Robot Raconteur Companion .NET <https://github.com/robotraconteur/RobotRaconteurNET.Companion>`_
provide support code. They also contain the "thunk" code so no generation is needed.
Standard Drivers
================
Drivers for various devices such as robots and sensors are constantly under development. Most of these drivers
take advantage of standard types to allow for interoperability. See the
`Directory <https://github.com/robotraconteur/robotraconteur-directory>`_ for a full list of available drivers.
Industrial robots use a base class called "Abstract Robot" to implement drivers. This base class makes implementing
robot drivers relatively easy. The diagram below shows the Robot Raconteur driver running on an embedded computer,
connecting to the robot using a private network. The driver communicates with the robot using proprietary protocols
and provides a standard interface to the system network.
.. image:: images/standard_robot_x15.svg
:alt: Standard Robot Driver Configuration
:name: StandardRobotDriver
:width: 400
Reynard the Robot
=================
Reynard the Robot is a simple cartoon robot used to demonstrate the capabilities of Robot Raconteur. See
the `Meet Reynard the Robot <MeetReynardTheRobot>`_ page for more information.
Training Simulator
==================
A `Training Simulator <https://github.com/robotraconteur-contrib/robotraconteur_training_sim>`_ based on the Gazebo
robot simulator has been developed to help learn Robot Raconteur and test
new ideas in a safe environment. The simulator runs on Windows, Linux, and MacOS.
Three scenes are included in the simulator:
* Universal Robot UR5e Scene
* Two Universal Robots UR5e Robots
* Two simulated vacuum grippers
* An overhead simulated camera
* Payloads
* Calibration target
* Multi Robot Scene
* Universal Robots UR5e Robot
* ABB IRB 1200-5/0.9 Robot
* Rethink Robotics Sawyer Robot
* Three simulated vacuum grippers
* An overhead simulated camera
* Payloads
* Calibration target
* iRobot Create 1 Scene
* iRobot Create
* Stereo camera mounted on robot
* "Cafe" scene from the Gazebo model library
.. image:: images/training_sim_ur5e.png
:alt: Training Simulator UR5e Scene
:name: TrainingSimUR
:width: 400
.. image:: images/training_sim_multi.png
:alt: Training Simulator Multi Robot Scene
:name: TrainingSimMulti
:width: 400
.. image:: images/training_sim_create.png
:alt: Training Simulator iRobot Create Scene
:name: TrainingSimCreate
:width: 400
The simulator uses the
`Robot Raconteur Gazebo Plugin <https://github.com/robotraconteur-contrib/RobotRaconteur_Gazebo_Server_Plugin>`_, which
allows for most of the API of Gazebo to be accessed using
Robot Raconteur. Simulated device drivers interact with the plugin to simulate device behavior.
Examples
========
The rest of this Getting Started manual contains examples of using Robot Raconteur. This guide covers Python,
MATLAB, and LabView examples. Select the appropriate tab for the language you are using by clicking on the tab
name.
Refer to the documentation for
each specific library and computer language for detailed reference beyond what is offered in the examples, including
the other supported computer languages.
.. note::
Leave a message on the `Discussion <https://github.com/robotraconteur/robotraconteur/discussions>`_
board if you have a question!
|