-
Notifications
You must be signed in to change notification settings - Fork 525
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Dynamics controllers for Computed Torque Control / Gravity Compensation #433
Open
francofusco
wants to merge
14
commits into
ros-controls:melodic-devel
Choose a base branch
from
francofusco:dynamics-controllers
base: melodic-devel
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
14 commits
Select commit
Hold shift + click to select a range
75a24ba
Controllers based on the inverse dynamics
af1220e
updated README
17afe8d
Updated README
c9d9152
sub-tree extraction
7882749
Updated doc
c98cc8a
Merge branch 'melodic-devel' into dynamics-controllers
francofusco bba9155
Removing external dependency on Tree dynamics solver
francofusco 1fb22f8
Addressing first comments in PR review
francofusco 1a4f880
Multiple sub-controllers
francofusco 58d3a9a
Effort limits (saturation)
francofusco 1de3987
Removed personal TODOs
francofusco bbd6f96
Merge branch 'melodic-devel' of https://github.com/ros-controls/ros_c…
francofusco d6ebc76
Added pluginlib as dependency to solve link errors
francofusco 1e5f2dd
Added controller_manager as dependency
francofusco File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
cmake_minimum_required(VERSION 2.8.3) | ||
project(dynamics_controllers) | ||
|
||
# Compile as C++11, supported in ROS Kinetic and newer | ||
add_compile_options(-std=c++11) | ||
|
||
# For now, latest build from source is needed | ||
find_package(orocos_kdl REQUIRED) | ||
|
||
# Find catkin macros and libraries | ||
find_package(catkin REQUIRED COMPONENTS | ||
controller_interface | ||
controller_manager | ||
kdl_parser | ||
pluginlib | ||
) | ||
|
||
# Declare catkin package | ||
catkin_package( | ||
INCLUDE_DIRS include | ||
LIBRARIES ${PROJECT_NAME} | ||
DEPENDS | ||
orocos_kdl | ||
CATKIN_DEPENDS | ||
controller_interface | ||
kdl_parser | ||
pluginlib | ||
) | ||
|
||
include_directories(include ${orocos_kdl_INCLUDE_DIRS} ${catkin_INCLUDE_DIRS}) | ||
|
||
add_library(${PROJECT_NAME} | ||
src/dynamics_controller_base.cpp | ||
src/kdl_chain_controller.cpp | ||
src/kdl_tree_controller.cpp | ||
src/kdl/treeidsolver_recursive_newton_euler.cpp # NOTE: this will be removed | ||
) | ||
|
||
# the options are used to force the linker to report undefined symbols as errors | ||
target_link_libraries(${PROJECT_NAME} ${orocos_kdl_LIBRARIES} ${catkin_LIBRARIES} -Wl,--no-undefined) | ||
|
||
# Install the library | ||
install(TARGETS ${PROJECT_NAME} | ||
ARCHIVE DESTINATION ${CATKIN_PACKAGE_LIB_DESTINATION} | ||
LIBRARY DESTINATION ${CATKIN_PACKAGE_LIB_DESTINATION} | ||
RUNTIME DESTINATION ${CATKIN_GLOBAL_BIN_DESTINATION} | ||
) | ||
|
||
install( | ||
FILES dynamics_controllers.xml | ||
DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION} | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,180 @@ | ||
## Dynamics Controllers | ||
|
||
Package that implements controllers that add a "dynamic control layer" to | ||
existing effort controllers. | ||
|
||
The controllers contained in this package allow to take into account the | ||
dynamics of a kinematic chain/tree and to perform Computed Torque Control. | ||
Controllers are meant to operate in conjunction with existing controllers that | ||
operate with `hardware_interface::EffortJointInterface`, which act as | ||
"*sub-controllers*". | ||
The command from the sub-controllers - which would normally be an effort - is | ||
instead interpreted as an acceleration and injected in the Inverse Dynamic Model | ||
(IDM) of the mechanism, allowing to better compensate for the nonlinearity of | ||
robots' Dynamic Models. | ||
|
||
Currently, there exist two controllers: `KdlChainController` and | ||
`KdlTreeController`. | ||
They are both based on KDL's implementation of the Recursive Newton-Euler | ||
algorithm for the inverse dynamics. | ||
|
||
|
||
|
||
### Gravity Compensation vs Full Inverse Dynamics | ||
|
||
By default, the controllers perform full Inverse Dynamics computations. | ||
However, you can ask them to perform gravity compensation only. | ||
In this case, the command evaluated by the sub-controllers is added to the | ||
gravitational efforts - this corresponds to assuming the Generalized Inertia | ||
Matrix to be the Identity and Coriolis/Centrifugal efforts to be null. | ||
|
||
To enable gravity compensation only, you can specify the parameter | ||
`gravity_compensation_only: true` in the controller configuration. | ||
|
||
|
||
|
||
### Resource Handling | ||
|
||
Since the dynamic model of a generic robot operates on multiple joints at the | ||
same time, sub-controllers must claim all joints exactly once. | ||
As an example, if a dynamic controller is loaded for a chain with three joints, | ||
*e.g.*, `joint1`, `joint2` and `joint3`, the sub-controllers must be loaded so | ||
that they handle all of them without conflicts. | ||
For instance, a valid option is to have a single sub-controller that claims all | ||
the joints. | ||
However, a single controller claiming only `joint1` and `joint2` would cause | ||
failure upon initialization (since `joint3` would remain unclaimed). | ||
On the other hand, having one sub-controller for `joint1` and `joint3` plus | ||
another controller handling `joint2` would be legit. | ||
Note that if the second controller in this last example was also managing | ||
`joint1`, then initialization would fail since both the first and second | ||
controllers try to claim the same resource. | ||
Finally, failure will also happen if any sub-controller tries to claim any | ||
joint not being part of the chain/tree (such as `joint4` in the example). | ||
|
||
|
||
|
||
### Example of Controller Configuration | ||
|
||
Assuming that you have a simple kinematic chain with two joints `joint1` and | ||
`joint2`, you might have some controllers configured as: | ||
|
||
```yaml | ||
joint1_position_controller: | ||
type: effort_controllers/JointPositionController | ||
joint: joint1 | ||
pid: {p: 10.0, i: 0.0, d: 5.0} | ||
|
||
joint2_position_controller: | ||
type: effort_controllers/JointPositionController | ||
joint: joint2 | ||
pid: {p: 10.0, i: 0.0, d: 5.0} | ||
|
||
velocity_controller: | ||
type: effort_controllers/JointGroupVelocityController | ||
joints: | ||
- joint1 | ||
- joint2 | ||
joint1/pid: {p: 10.0, i: 0.0, d: 5.0} | ||
joint2/pid: {p: 10.0, i: 0.0, d: 5.0} | ||
``` | ||
|
||
To use the new controllers, you can change it, *e.g.*, as follows: | ||
```yaml | ||
gravity: [0, 0, -9.81] # this should be projected on the base frame | ||
|
||
position_controller: | ||
type: dynamics_controllers/KdlChainController | ||
sub_controller: | ||
# the sub-controller is basically the set of controllers you had before! | ||
joint1: | ||
type: effort_controllers/JointPositionController | ||
joint: joint1 | ||
pid: {p: 10.0, i: 0.0, d: 5.0} | ||
joint2: | ||
type: effort_controllers/JointPositionController | ||
joint: joint2 | ||
pid: {p: 10.0, i: 0.0, d: 5.0} | ||
|
||
velocity_controller: | ||
type: dynamics_controllers/KdlTreeController | ||
sub_controller: | ||
# the subcontroller is basically the controller you had before! | ||
type: effort_controllers/JointGroupVelocityController | ||
joints: | ||
- joint1 | ||
- joint2 | ||
joint1/pid: {p: 10.0, i: 0.0, d: 5.0} | ||
joint2/pid: {p: 10.0, i: 0.0, d: 5.0} | ||
``` | ||
|
||
Note that you will likely have to tune again the gains of the sub-controllers to | ||
achieve good performances. | ||
|
||
#### Detailed Controllers Configuration | ||
|
||
Below, parameters relative to each controller are listed. | ||
Those marked as "searched for" can live in any parent namespace since the | ||
`NodeHandle::searchParam` method is used to locate them. | ||
This facilitates "sharing" common parameters such as the gravity vector, which | ||
should not depend on a specific controller (at least in principle!). | ||
|
||
##### KdlChainController | ||
|
||
- `sub_controller`: should contain the configuration of a set of controllers | ||
of type compatible with `EffortJointInterface`. It cen either be a single | ||
"unnamed" controller directly living in the `sub_controller` namespace or a | ||
set of "named" controllers. | ||
- `robot_description`: should contain the URDF of the robot. Searched for. | ||
- `gravity`: list with three elements, representing the gravity vector in the | ||
base frame of the chain. Searched for. Default: `[0,0,0]`. | ||
- `chain_base`: base of the chain. Searched for. Default: name of the root link | ||
from the robot description. | ||
- `chain_tip`: tip of the chain. Searched for. Default: if a single "branch" | ||
is rooted at `base_link`, `chain_tip` will correspond to the last link of the | ||
chain. If at any point multiple children are found, loading will fail. | ||
- `gravity_compensation_only`: as discussed above. Default: `false`. | ||
|
||
##### KdlTreeController | ||
|
||
- `sub_controller`: should contain the configuration of a set of controllers | ||
of type compatible with `EffortJointInterface`. It cen either be a single | ||
"unnamed" controller directly living in the `sub_controller` namespace or a | ||
set of "named" controllers. | ||
- `robot_description`: should contain the URDF of the robot. Searched for. | ||
- `gravity`: list with three elements, representing the gravity vector in the | ||
base frame of the chain. Searched for. Default: `[0,0,0]`. | ||
- `tree_root`: base of the tree. Searched for. Default: name of the root link | ||
from the robot description. | ||
- `gravity_compensation_only`: as discussed above. Default: `false`. | ||
|
||
|
||
|
||
### Limitations | ||
|
||
The following is a list of "limitations" in the sense that if you need one or | ||
more of the following features, you will likely have to write new controllers | ||
by yourself or to find proper workarounds. | ||
|
||
- They all assume a static base. The main implication is that you cannot | ||
"serially join" controllers for different parts of the robot. | ||
- They require proper identification of the Dynamic Parameters. | ||
- The parameters must be provided in URDF format. This is a limitation since | ||
the identification will often return a smaller set of regrouped parameters. | ||
- The sub-controllers must control all joints of the internal `Chain`/`Tree`. | ||
|
||
|
||
|
||
### Possible Improvements | ||
|
||
- [ ] Compensation of external payloads, mainly in two ways: | ||
- By adding a subscriber that can update the `wrenches_` members | ||
- Allowing to dynamically modify the `Chain`/`Tree` instances | ||
- [ ] Support for moving bases. This likely requires to re-implement the | ||
controllers using another library, such as pinocchio, or to expand KDL. | ||
A possible workaround is to add a "floating joint" (in the form of a | ||
3T3R chain) as the parent of the base. | ||
- [ ] Additional parameters such as joint inertia and viscous friction. | ||
Note that some of these parameters are already inside KDL, | ||
even though they are still not used in many solvers (eg, the damping). | ||
- [x] Allow multiple sub-controllers to manage different joints. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
<library path="lib/libdynamics_controllers"> | ||
|
||
<class | ||
name="dynamics_controllers/KdlChainController" | ||
type="dynamics_controllers::KdlChainController" | ||
base_class_type="controller_interface::ControllerBase"> | ||
<description> | ||
Computes the efforts based on the Inverse Dynamics of a kinematic chain. | ||
Wraps around controllers compatible with an EffortJointInterface. | ||
</description> | ||
</class> | ||
|
||
<class | ||
name="dynamics_controllers/KdlTreeController" | ||
type="dynamics_controllers::KdlTreeController" | ||
base_class_type="controller_interface::ControllerBase"> | ||
<description> | ||
Computes the efforts based on the Inverse Dynamics of a kinematic tree. | ||
Wraps around controllers compatible with an EffortJointInterface. | ||
</description> | ||
</class> | ||
|
||
</library> |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you please add some pointers on how one would go about this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That is supposed to be a warning about the fact that model-based computed torque controls require a sufficiently good identification of the parameters. Do you want me to add references about possible identification strategies?