A ROS2 package for interfacting with a Ferrobotics Active Contact Flange (ACF) over TCP/IP Ethernet.
mkdir -p ros2_ws/src
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.
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
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)
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.
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.
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]
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 thejoint_name
parameter is set.
The acf
node subscribes to the following topic:
~/force
(Float32
) -> Used to set the current output force of the ACF in Newtons.