No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.

Package Summary

Tags No category tags.
Version 0.0.0
License BSD-3-Clause
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/fzi-forschungszentrum-informatik/cartesian_controllers.git
VCS Type git
VCS Version ros2
Last Updated 2024-10-30
Dev Status UNMAINTAINED
CI status No Continuous Integration
Released UNRELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

The cartesian_force_controller package

Additional Links

Maintainers

  • scherzin

Authors

  • Stefan Scherzinger

Cartesian Force Controller

This controller is for end-effector force control in contact with the robot’s environment. It’s also a good choice for intuitively steering the robot in transition tasks (from motion to contact) through teleoperation, or for combining it with the low-level action space of AI-based policies.

The responsiveness of the behavior can be tweaked by the following parameters:

  • The p and d gains determine the responsiveness in each individual Cartesian axis. The higher these values, the faster does the robot move in response to either the sensed contact forces or the published target wrench. Proportional gains (p) are normally sufficient and you’ll probably not need a d gain for most use cases. With a little bit of tweaking, though, they sometimes help to reduce oscillations in stiff contacts.
  • The error_scale influences the controller’s sensitivity uniformly for all axes. It post-scales the computed error from the controller gains (by multiplication) and is a little easier to adjust with a single parameter. Similar to pure motion control, the idea is to first weigh the different Cartesian axes with the controller gains and adjust the overall responsiveness with this parameter.

In contrast to the cartesian_motion_controller, the internal iterations parameter has no effect and is identically set to 1. Also note that all parameters can be changed at runtime and in realtime. This means that you could easily adjust them in your use cases with a running robot. For instance, error_scale could start in a higher value when teleoperating the robot and could be further decreased upon detecting contact to maintain stability during a guided assembly operation.

Getting Started

We assume that you have the cartesian_controller_simulation package installed. 1) Start the simulation environment as described here.

2) Now we activate the cartesian_force_controller:

   ros2 control switch_controllers --start cartesian_force_controller
   

3) Next, open rqt in a new, sourced terminal to publish a target wrench and see the robot move:

   rqt
   

Navigate to Plugins -> Topics -> Message Publisher and configure the following window: Target wrench publisher

Upon checking the checkbox for /target_wrench, the robot should move. The published force will pull the robot in some direction and you can experiment a little with different force-torque components.

4) Change some of the controller’s parameters: In rqt, open the Dynamic Reconfigure plugin under Plugins/Configuration and select the cartesian_force_controller. Play a little with the parameters (e.g. solver/error_scale = 0) and observe the changes of behavior in RViz.

When working with a new robot for the first time, it’s good practice to start with error_scale = 0 and carefully increment that (e.g. in rqt) while touching and guiding the robot’s end-effector by hand. The controller should follow your lead and behave plausible in each Cartesian dimension. If that’s not the case, there might be some issue with the sensor setup.

Example Configuration

Below is an example controller_manager.yaml for a controller specific configuration. Also see the simulation config for further information.

controller_manager:
  ros__parameters:
    update_rate: 100  # Hz

    cartesian_force_controller:
      type: cartesian_force_controller/CartesianForceController

    # More controller instances here
    # ...

cartesian_force_controller:
  ros__parameters:
    end_effector_link: "tool0"
    robot_base_link: "base_link"
    ft_sensor_ref_link: "sensor_link"
    joints:
      - joint1
      - joint2
      - joint3
      - joint4
      - joint5
      - joint6

    # Choose: position or velocity.
    command_interfaces:
      - position
        #- velocity

    solver:
        error_scale: 0.5

    pd_gains:
        trans_x: {p: 0.05}
        trans_y: {p: 0.05}
        trans_z: {p: 0.05}
        rot_x: {p: 1.5}
        rot_y: {p: 1.5}
        rot_z: {p: 1.5}


# More controller specifications here
# ...


Additional insights

Note that the controller does not strictly move only in the commanded direction. Although its behavior is linearized in operational space, there might be small drifts in other axes. This is a feature of the forward dynamics-based solver. In fact, there is no error reduction on axes orthogonal to the published target wrench. The benefit is that the controller finds approximate solutions near singular configurations.

CHANGELOG
No CHANGELOG found.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Package Dependencies

System Dependencies

No direct system dependencies.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Recent questions tagged cartesian_force_controller at Robotics Stack Exchange

No version for distro noetic. Known supported distros are highlighted in the buttons above.
No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.
No version for distro melodic. Known supported distros are highlighted in the buttons above.