-
Notifications
You must be signed in to change notification settings - Fork 0
Sunrise_FRI
- It is recommended to use the driver on a real-time capable client machine (further information about setting up the PREEMPT_RT patch can be found here).
- Set a fixed IP in the subnet of the controller for the real-time machine.
- Modify the
_remoteIP
variable of the FRIConfigurationParams.java file to the IP address of the client machine - Upload the robot application under
robot_application/src
to the controller using Sunrise Workbench
The following configuration files are available in the config
directory of the package:
-
driver_config.yaml
: : contains runtime parameters of therobot_manager
node -
ros2_controller_config.yaml
: contains the controller types for every controller name. Should be only modified if a different controller is to be used. Theconfigure_components_on_start
parameter should never be modified, which ensures that the hardware interface is not activated at startup. - configuration files for specific controllers, for further information, see the documentation of the given controller
-
gpio_config.xacro
: contains the I/O setup of the system, but this was not tested yet
The IP address of robot controller must be provided as a launch argument. For further information see section launch arguments.
The parameters in the driver configuration file can be also changed during runtime using the parameter interface of the robot_manager
node:
-
send_period_ms
(integer): this parameter defines the send rate in milliseconds (with which the controller sends robot state updates). It must be between 1 and 10 for control and can be only changed ininactive
andconfiguring
states. -
receive_multiplier
(integer): this parameter defines the answer rate factor (the client should sends commands in everyreceive_multiplier
*send_period_ms
milliseconds). It must be at least 1 and can be only changed ininactive
andconfiguring
states. -
control_mode
,command_mode
(strings): control mode related parameters, which will be combined to support the defined enums. They cannot be changed in active state. -
joint_damping
,joint_stiffness
(double vectors): these parameters change the stiffness and damping attributes of joint impedance control mode. They will be removed after changing to using thejoint_group_impedance_controller
to adapt to conventions. -
position_controller_name
: The name of the controller (string) that controls theposition
interface of the robot. It can't be changed in active state. -
torque_controller_name
: The name of the controller (string) that controls theeffort
interface of the robot. It can't be changed in active state.
-
On the controller, start the uploaded robot application (ROS2_Control).
-
To start the driver, two launch file are available, with and without
rviz
. To launch (withoutrviz
), runros2 launch kuka_sunrise_fri_driver startup.launch.py controller_ip:=0.0.0.0
- This starts the 3 core components of every driver (described in the Non-real-time interface section of the project overview) and the following controllers:
-
joint_state_broadcaster
(no configuration file, all state interfaces are published) -
joint_trajectory_controller
(configuration file) -
fri_configuration_controller
(no configuration file) -
fri_state_broadcaster
(no configuration file)
-
- This starts the 3 core components of every driver (described in the Non-real-time interface section of the project overview) and the following controllers:
-
After successful startup, the
robot_manager
node has to be activated to start the cyclic communication with the robot controller (before this only a collapsed robot is visible inrviz
):ros2 lifecycle set robot_manager configure ros2 lifecycle set robot_manager activate
On successful activation the brakes of the robot will be released and external control is started using the requested control mode. To test moving the robot, the rqt_joint_trajectory_controller
is not recommended, use the launch file in the iiqka_moveit_example
package instead (usage is described in the Additional packages section of the project overview).
Both launch files support the following argument:
-
controller_ip
: IP address of the robot controller -
robot_model
: defines which LBR iiwa robot to use. Available options:lbr_iiwa14_r820
(default) -
use_fake_hardware
: if true, themock_components/GenericSystem
will be used instead of theKukaFRIHardwareInterface
. This enables trying out the driver without actual hardware. -
namespace
: adds a namespace to all nodes and controllers of the driver, and modifies theprefix
argument of the robot description macro tonamespace_
-
x
,y
,z
: define the position ofbase_link
relative to theworld
frame (default: [0, 0, 0]) -
roll
,pitch
,yaw
: define the orientation ofbase_link
relative to theworld
frame (default: [0, 0, 0]) -
controller_config
: the location of theros2_control
configuration file (defaults tokuka_sunrise_fri_driver/config/ros2_controller_config.yaml
) -
jtc_config
: the location of the configuration file for thejoint_trajectory_controller
(defaults tokuka_sunrise_fri_driver/config/joint_trajectory_controller_config.yaml
)
The startup_with_rviz.launch.py
additionally contains one argument:
-
rviz_config
: the location of therviz
configuration file (defaults tokuka_resources/config/"view_6_axis_urdf.rviz
)
To stop external control, all components have to be deactivated with ros2 lifecycle set robot_manager deactivate
BEWARE, that this is a non-realtime process including lifecycle management, so the connection is not terminated immediately, in cases where an abrupt stop is needed, the safety stop of the Teach Pendant should be used! (This will also deactivate all components to allow reactivation without a restart.)
- Not all hardware-related communication is implemented in the hardware interface, therefore the mock hardware option is not working properly
- The control mode handling for the driver is not the one defined in the
kuka_drivers_core
package- enum definition and controller switching logic is not used
- joint impedance control is not implemented properly using command interfaces
- I/O control was not tested
- Cartesian modes are not yet supported