The purpose of this package is to provide standard interface for robot hardwares. Controllers using those standard interfaces do not need to assume any particular robot hardware. For example, our force_control package can be used with either an ABB robot or a UR robot. Currently supporting the following interfaces:
- Position-controlled robot arm
- 6-dof force torque sensor
Current implementations includes (see robots/
):
- UR robot rtde communication
- ARX robot arm via CAN bus
- ATI force torque sensor via netft;
- Robotiq FT series force torque sensor via modbus
- Realsense cameras via USB.
Author: Yifan Hou [email protected]
This package depends on cpplibrary and yaml-cpp.
Additionally, each hardware interface has there own dependencies. You can disable the hardware that you don't need by comment out the corresponding "add_subdirectory" lines in the base CMakeLists.txt.
- The ur_rtde module is dependent on UR rtde c++ library
- The arx_can module is dependent on the arx c++ sdk.
- The realsense module is dependent on the official lib realsense package
- The GoPro module is dependent on opencv.
- The ati_netft and robotiq_ft_modbus module contains a copy of the respective drivers and thus do not have additional dependencies.
Example installation procedure with CMake:
cd workspace
# install yaml-cpp
git clone [email protected]:jbeder/yaml-cpp.git
cd yaml-cpp
mkdir build && cd build
cmake -DCMAKE_CXX_STANDARD=17 .. # need to build with c++ 17
make -j
make install
# install cpplibrary
cd ../..
git clone [email protected]:yifan-hou/cpplibrary.git
cd cpplibrary
mkdir build && cd build
cmake ..
make -j
make install
# install ur-rtde
cd ../..
git clone https://gitlab.com/sdurobotics/ur_rtde.git
cd ur_rtde
mkdir build && cd build
cmake ..
make -j
make install
# build hardware_interface
git clone [email protected]:yifan-hou/hardware_interfaces.git
cd hardware_interfaces
mkdir build && cd build
cmake ..
make -j
make install
The above instruction will install the libraries to /usr, which affects all users on your system. It is recommended to install to a local folder instead.
In your $HOME, create the following file structure:
$HOME/
.local/
bin/
include/
lib/
In .bashrc or .zshrc, add the following:
# For home installations
export PATH=$HOME/.local/bin:$PATH
export C_INCLUDE_PATH=$HOME/.local/include/:$C_INCLUDE_PATH
export CPLUS_INCLUDE_PATH=$HOME/.local/include/:$CPLUS_INCLUDE_PATH
export LD_LIBRARY_PATH=$HOME/.local/lib/:$LD_LIBRARY_PATH
Note that all install targets in hardware_interfaces are written with CMAKE_INSTALL_PREFIX
like this:
install(TARGETS Utilities
DESTINATION ${CMAKE_INSTALL_PREFIX}/lib/${PROJECT_NAME}
)
To install to the local path we specified before, just change the line
cmake ..
to
cmake -DCMAKE_INSTALL_PREFIX=$HOME/.local ..
in the instructions above, then make
, make install
as usual.