Skip to content

A ROS package for interfacing with the Ferrobotics ACF using the TCP/IP Ethernet interface

License

Notifications You must be signed in to change notification settings

sam-xl/ferrobotics_acf

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

31 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Ferrobotics ACF

Overview

A ROS2 package for interfacting with a Ferrobotics Active Contact Flange (ACF) over TCP/IP Ethernet.

Installation

Create a workspace

mkdir -p ros2_ws/src

Clone this repo

Clone the correct version for Humble from this repository inside your workspace src:

cd ros2_ws/src
git clone https://github.com/sam-xl/ferrobotics_acf.git -b humble
cd ..

Finally, build all packages in the workspace:

colcon build --symlink-install

It may be necessary to make the python scripts executable:

chmod +x src/ferrobotics_acf/src/*.py

This command is only required if the --symlink-install flag is used.

Usage

To run the acf interface:

ros2 run ferrobotics_acf acf.py

If there is an executable not found error, refer to the chmod command above.

To run the acf interface with an ACF with a non-default ip address:

ros2 run ferrobotics_acf acf.py --ros-args -p ip:=192.168.123.132

Parameters

The acf.py executable exposes the following parameters:

  • ip -> the acf ip address (string)
  • f_max -> the maximum allowed force [N] (integer)
  • initial_force -> the force generated when no contact is detected [N] (double)
  • ramp_duration -> the ramp time of the force once contact is detected [s] (double)
  • payload -> the mass attached to the acf [kg] (double)
  • frequency -> the polling frequency [Hz] (integer)
  • joint_name -> the ACF joint name (string)

Polling mode

If the frequency parameter is set, commands will be set to the ACF at that rate. Received force commands will not immediately trigger sending of commands to the ACF in this mode. ACF telemetry will be received at the same rate.

If the parameter is set to zero, commands will only be sent to the ACF when a force command is received. Telemetry is only sent after each force command.

Joint State Publisher

This node will also act as a joint state publisher when the joint_name parameter is set. This may be useful in conjunction with a robot state publisher.

Services

The acf node creates the following services:

  • ~/set_payload (SetFloat) -> used to set the current payload [kg]
  • ~/set_f_zero (SetFloat) -> used to set force generated when no contact is detected [N]
  • ~/set_t_ramp (SetDuration) -> used to set the ramp time of the force once contact is detected [s]

Publishers

The acf node publishes on the following topic:

  • ~/telem (ACFTelem) -> Contains return information from the ACF. Only published (shortly) after receiving a message on /ACF/force or when polling is active.
  • joint_state (JointState) -> Publishes the current position of the ACF as a joint state. Only published if the joint_name parameter is set.

Subscribers

The acf node subscribes to the following topic:

  • ~/force (Float32) -> Used to set the current output force of the ACF in Newtons.

About

A ROS package for interfacing with the Ferrobotics ACF using the TCP/IP Ethernet interface

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 92.6%
  • CMake 7.4%