Listen to this article |
The Robot Operating System (ROS) is a powerful open-source platform for robotics research, but until recently it lacked industrial-quality hardware that is tightly integrated with the ROS software stack. Robot equipment manufacturers use proprietary, closed-source software and control systems for their manipulators, leaving researchers with a steep hill to climb in order to use ROS on industrial robots.
Addressing this need and advancing the capabilities of the ROS development community, Tormach has created a ROS-based industrial robotic manipulator and control system that avoids “black box” issues that plague modern robotics applications. Additionally, Tormach’s control system, PathPilot, uses Python as the robot programming language, creating an intuitive programming interface for robot motion and unleashing the potential of the Python package ecosystem.
This open-source, ROS-based robotics platform – which includes the control system, industrial robot hardware, and full access to all system parameters – creates a fast, accessible solution that brings industrial robotics to more researchers, developers, and students.
The problem with ROS and proprietary robot control systems
Robot control manufacturers are hesitant to allow ROS developers to access all the system parameters in their closed-source controls for the following reasons:
- They have invested significant resources into developing and testing their proprietary control systems and don’t want to expose the inner workings of their system to external researchers for fear of losing intellectual property.
- There are risks associated with exposing the system parameters to external researchers. Untested usage may
introduce bugs or other issues that could compromise the safety or reliability of the system. - Legal or contractual obligations often prevent manufacturers from sharing proprietary information with external parties.
- They may be concerned about potential liability issues if their closed-source control systems are modified by external parties.
- There is little financial incentive for most manufacturers, and in many cases, there is a strong disincentive: the need to invest in additional documentation, training, and support infrastructure to enable researchers to work with their control systems effectively.
For these reasons, integrations between ROS and commercially available robot hardware are limited. While drivers exist to connect ROS to other industrial robots, their low (10 – 100Hz) bandwidth implementations simply drip-feed waypoints to a proprietary, closed-source controller.
As a result, the user may not have access to whether or not the robot adheres to timing, velocity, and path accuracy intents. Data like motor torque, current, following error is usually unavailable, and the slow control loop severely limits what researchers can accomplish.
Motor and drive feedback to ROS
The ROS/HAL hardware and software stack offers feedback that can provide valuable control opportunities.
The ZA6 provides the following:
- Feedback from each joint, standard configuration: position, velocity feedback, torque feedback in SI units, following error, diagnostics-like error code, with configuration, drives can also report additional diagnostics like motor/encoder temperatures and error code history.
- 10 digital inputs + 12 digital outputs (one digital input usable as probe input)
- HAL can report RT latency
- Feedback from ROS and MoveIt, especially Cartesian pose
Most of these feedback elements focus on only the lower-level control layers. Higher-level control layers can provide other opportunities, depending on research needs.
Meet HAL: The open-source Hardware Abstraction Layer
The connection between ROS and a robot’s hardware relies on a hardware abstraction layer (HAL). HAL evolved out of the open-source Enhanced Machine Controller (EMC) project that had its origin 25 years ago at the National Institute of Standards and Testing (NIST).
Active development of HAL continues today via the LinuxCNC and Machinekit projects because HAL is flexible, 100% open-source, and is used in thousands of machines around the world.
HAL consists of modular components (loadable binary modules) that communicate with each other by updating, reading, and writing named pins that connect via named signals. In some ways, HAL is like ROS, but there are important differences:
- Using PREEMPT-RT Linux extensions, HAL components written in C execute in a 1kHz real-time thread with minimum jitter.
- HAL has many pre-written components designed for low-level hardware control (PWM generators, stepper driver step generators, BLDC and three-phase motor controls, and more. A full list can be found here.
The Tormach robot bridges the gap between ROS with the open-source hal_ros_control component. The combination of HAL and ROS allows a wealth of robot data to be exposed to the user. All process data is accessible via shell commands, data logger utilities, and a graphical scope. All information on the EtherCAT bus, including torque, current, following error, position, velocity, and more are available at 1 kHz and exposed via HAL to ROS.
Since HAL is modular and flexible, users can alter their robot’s HAL configuration using pre-built HAL components or by writing new components in C or Python, allowing easy integration with almost any external device or process.
Preconfigured for ROS
Previously, using a commercially available robot with ROS requires finding and downloading the appropriate driver for the control, a URDF file to describe kinematics; creating a moveit configuration, choosing one or more planners, IK solvers, and perhaps finding and bringing solid models into Rviz. Configuring a new robot for use with ROS is challenging even for experienced ROS developers.
An optimized default ROS configuration for the manipulator, like that provided by Tormach as part of the control, helps alleviate many of these issues. The URDF model (unified robot description format) is defined, motion pipelines are configured, and trajectory planners and kinematics solvers are selected and optimized so that the robot is ready to work out of the box.
The robot hardware, user interface, and robot programming language are fully documented and supported by Tormach. Go here for documentation.
The robot’s default ROS configuration will be ideal for most applications, saving months of configuration time, and it’s also open-ended to allow users to develop their own unique configurations at will.
Python: the robot’s programming language
The lack of an industry-standard robot programming language led Tormach to choose Python for its ZA6 robot. The Tormach Robot Programming Language (TRPL) uses the Python 3 interpreter and works similarly to other common robot programming languages, with commands for different move types, commands to read and set inputs and outputs, and commands to set and change tool and user frames. The language is documented here.
It is important to note that any Python 3 program is a valid robot program. The robot’s ability to interpret any Python program means that almost any Python package can be imported to help with more challenging robot tasks. Examples include:
- Using the csv and http requests libraries to upload data files recorded by the robot to a web server.
- Using opencv to recognize ArUco markers for visual servoing and localization.
- Using numpy and kdl to calculate forces in cartesian space from the joint torque feedback and robot Jacobian.
- Using Twilio to send text messages from the robot.
- Using ChatGPT and the Python OpenAI API to conversationally create robot programs – example here.
While the TRPL interpreter simplifies a lot of programming tasks like move commands and offsets, power users who are familiar with ROS are able to access the underlying ROS API directly. Find more information here.
Suitable for research and education
The PathPilot user interface makes it easy to write simple teach-mode programs to help students learn the concepts they need to be successful in industrial robotics. Unlike other robots designed for the classroom, the ZA6 teaches industrial robot concepts like user frames, tool frames, waypoint programming, and Cartesian-versus-joint angle waypoint types. Another reason to use the robot as a teaching tool is its easy-to-learn user interface.
The PathPilot user interface makes it easy to write simple teach-mode programs to help students learn the concepts they need to be successful in industrial robotics. Unlike other robots designed for the classroom, the ZA6 teaches industrial robot concepts like user frames, tool frames, waypoint programming, and Cartesian-versus-joint angle waypoint types. Another reason to use the robot as a teaching tool is its easy-to-learn user interface.
Dr. John Wen at Rensselaer Polytechnic Institute is developing Robot Raconteur, which is a royalty-free project intended to provide a solution to distributed control and component interfaces. The system is designed precisely for the scenario of an engineer wanting to control a component from a high-level language in distributed or non-distributed conditions.
See how researchers at RPI have integrated the Tormach robot into its Robot Raconteur program for force-torque control.
Credit: Source link
Comments are closed.