From c8d034d3678054b58225025fa9540a7f1865fd7e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=81ron=20Svastits?= <49677296+Svastits@users.noreply.github.com> Date: Wed, 13 Mar 2024 13:42:21 +0100 Subject: [PATCH] Update documentation (#151) * Update doc * format --------- Co-authored-by: Svastits --- doc/wiki/Home.md | 23 ++++++++++++++++++++++- doc/wiki/iiQKA_EAC.md | 1 + 2 files changed, 23 insertions(+), 1 deletion(-) diff --git a/doc/wiki/Home.md b/doc/wiki/Home.md index aae2e10d..226e0070 100644 --- a/doc/wiki/Home.md +++ b/doc/wiki/Home.md @@ -102,7 +102,7 @@ The package contains a [launch file](https://github.com/kroshu/kuka_drivers/blob After activation, the Motion Planning plugin can be added (`Add` -> `moveit_ros_visualisation` -> `MotionPlanning`) to plan trajectories from the `rviz` GUI. (`Planning group` in the `Planning` tab should be changed to `manipulator`.) -The package also contains examples of sending planning requests from C++ code, in which case the `rviz` plugin is not necessary. The `MoveitExample` class implements a wrapper around the `MoveGroupInterface`, the example executables in the package use this class to interact with Moveit. Four examples are provided: +The package also contains examples of sending planning requests from C++ code, in which case the `rviz` plugin is not necessary. The `MoveitExample` class implements a wrapper around the `MoveGroupInterface`, the example executables in the package use this class to interact with `Moveit`. Four examples are provided: - `moveit_basic_planners_example`: the example uses the `PILZ` motion planner to plan a `PTP` and a `LIN` trajectory. It also demonstrates that planning with collision avoidance is not possible with the `PILZ` planner by adding a collision box that invalidates the planned trajectory. - `moveit_collision_avoidance_example`: the example adds a collision box to the scene and demonstrates, that path planning with collision avoidance is possible using the `OMPL` planning pipeline. - `moveit_constrained_planning_example`: this example demonstrates constrained planning capabilities, as the planner can find a valid path around the obstacle with the end effector orientation remaining constant (with small tolerance). @@ -112,6 +112,27 @@ Note: the first three examples should be executed consequently (without restarti Note: The examples need user interaction in `rviz`, the `Next` button (`RvizVisualToolsGui` tab) should be pressed each time the logs indicate it. + +### Planning in impedance mode + +Planning with `Moveit`, or simply moving the robot in impedance mode is quite tricky, as often there is a mismatch between the actual and commanded positions. +Both `Moveit` and the `joint_trajectory_controller` start planning/execution from the actually measured values, creating a jump in the commands (from the previous command to the measured state), which can trigger a joint limit violation. To solve this issue, the planning request must be modified to start from the commanded position instead of the measured one. +For example in the `moveit_basic_planners_example` the following lines must be added before each planning request: +```C++ + moveit_msgs::msg::RobotState start_state; + std::vector commanded_pos; // TODO: fill this vector with the actually commanded positions + start_state.joint_state.name = example_node->moveGroupInterface()->getJointNames(); + start_state.joint_state.position = commanded_pos; + example_node->moveGroupInterface()->setStartState(start_state); +``` +Additionally the `trajectory_execution.allowed_start_tolerfance` parameter in `moveit_controllers.yaml` (found in the moveit support packages) should be increased based on the actual displacement between commanded and measured joint values. + +If you would like to only move the robot by sending a goal to the `joint_trajectory_controller` for interpolation (e.g. with the [example trajectory publisher](https://github.com/kroshu/kuka_drivers/blob/master/examples/iiqka_moveit_example/launch/launch_trajectory_publisher.launch.py)), the following line should be added to the controller configuration file: +```yaml +open_loop_control: true +``` + + ## Multi-robot scenario As the robot controllers manage the timing of the drivers, it does not make sense to add more robots to the same control loop, as it would only lead to timeouts on the controller side. Therefore to start the drivers of multiple robots, all components has to be duplicated. This can be achieved by using the `namespace` argument of the launch files (which is available for all drivers) to avoid name collisions. This will add a namespace to all nodes and controllers of the driver and will also modify the `prefix` argument of the robot description macro to `namespace_`. To adapt to the new namespace and prefix, the configurations files of the driver must also be modified to reflect the new node and joint names. An example of this can found in the `iiqka_moveit_example` package, that starts two robots with `test1` and `test2` namespaces and modified configuration files. diff --git a/doc/wiki/iiQKA_EAC.md b/doc/wiki/iiQKA_EAC.md index 399c7cc7..5c5dcda4 100644 --- a/doc/wiki/iiQKA_EAC.md +++ b/doc/wiki/iiQKA_EAC.md @@ -9,6 +9,7 @@ #### Controller side - Install ExternalAPI.Control toolbox (requires iiQKA 1.2) + - The toolbox is not available by default and should be requested from KUKA Customer Support - Set KONI IP (System Settings -> Network -> KONI) + restart - Connect external client to KONI port (XF7) - Release SPOC on the Teach Pendant