ros2_control - iron
|
Public Member Functions | |
SystemInterface (const SystemInterface &other)=delete | |
SystemInterface copy constructor is actively deleted. | |
SystemInterface (SystemInterface &&other)=default | |
virtual CallbackReturn | on_init (const HardwareInfo &hardware_info) |
Initialization of the hardware interface from data parsed from the robot's URDF. | |
virtual std::vector< StateInterface > | export_state_interfaces ()=0 |
Exports all state interfaces for this hardware interface. | |
virtual std::vector< CommandInterface > | export_command_interfaces ()=0 |
Exports all command interfaces for this hardware interface. | |
virtual return_type | prepare_command_mode_switch (const std::vector< std::string > &, const std::vector< std::string > &) |
Prepare for a new command interface switch. | |
virtual return_type | perform_command_mode_switch (const std::vector< std::string > &, const std::vector< std::string > &) |
virtual return_type | read (const rclcpp::Time &time, const rclcpp::Duration &period)=0 |
Read the current state values from the actuator. | |
virtual return_type | write (const rclcpp::Time &time, const rclcpp::Duration &period)=0 |
Write the current command values to the actuator. | |
virtual std::string | get_name () const |
Get name of the actuator hardware. | |
const rclcpp_lifecycle::State & | get_state () const |
Get life-cycle state of the actuator hardware. | |
void | set_state (const rclcpp_lifecycle::State &new_state) |
Set life-cycle state of the actuator hardware. | |
Protected Attributes | |
HardwareInfo | info_ |
rclcpp_lifecycle::State | lifecycle_state_ |
|
delete |
SystemInterface copy constructor is actively deleted.
Hardware interfaces are having a unique ownership and thus can't be copied in order to avoid failed or simultaneous access to hardware.
|
pure virtual |
Exports all command interfaces for this hardware interface.
The command interfaces have to be created and transferred according to the hardware info passed in for the configuration.
Note the ownership over the state interfaces is transferred to the caller.
Implemented in gazebo_ros2_control::GazeboSystem, gz_ros2_control::GazeboSimSystem, mock_components::GenericSystem, ros2_control_demo_example_1::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_10::RRBotSystemWithGPIOHardware, ros2_control_demo_example_11::CarlikeBotSystemHardware, ros2_control_demo_example_12::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_2::DiffBotSystemHardware, ros2_control_demo_example_3::RRBotSystemMultiInterfaceHardware, ros2_control_demo_example_4::RRBotSystemWithSensorHardware, ros2_control_demo_example_5::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_7::RobotSystem, ros2_control_demo_example_8::RRBotTransmissionsSystemPositionOnlyHardware, and ros2_control_demo_example_9::RRBotSystemPositionOnlyHardware.
|
pure virtual |
Exports all state interfaces for this hardware interface.
The state interfaces have to be created and transferred according to the hardware info passed in for the configuration.
Note the ownership over the state interfaces is transferred to the caller.
Implemented in gazebo_ros2_control::GazeboSystem, gz_ros2_control::GazeboSimSystem, mock_components::GenericSystem, ros2_control_demo_example_1::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_10::RRBotSystemWithGPIOHardware, ros2_control_demo_example_11::CarlikeBotSystemHardware, ros2_control_demo_example_12::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_2::DiffBotSystemHardware, ros2_control_demo_example_3::RRBotSystemMultiInterfaceHardware, ros2_control_demo_example_4::RRBotSystemWithSensorHardware, ros2_control_demo_example_5::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_7::RobotSystem, ros2_control_demo_example_8::RRBotTransmissionsSystemPositionOnlyHardware, and ros2_control_demo_example_9::RRBotSystemPositionOnlyHardware.
|
inlinevirtual |
Get name of the actuator hardware.
|
inline |
Get life-cycle state of the actuator hardware.
|
inlinevirtual |
Initialization of the hardware interface from data parsed from the robot's URDF.
[in] | hardware_info | structure with data from URDF. |
Reimplemented in mock_components::GenericSystem, ros2_control_demo_example_1::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_10::RRBotSystemWithGPIOHardware, ros2_control_demo_example_11::CarlikeBotSystemHardware, ros2_control_demo_example_12::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_2::DiffBotSystemHardware, ros2_control_demo_example_3::RRBotSystemMultiInterfaceHardware, ros2_control_demo_example_4::RRBotSystemWithSensorHardware, ros2_control_demo_example_5::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_7::RobotSystem, ros2_control_demo_example_8::RRBotTransmissionsSystemPositionOnlyHardware, ros2_control_demo_example_9::RRBotSystemPositionOnlyHardware, gazebo_ros2_control::GazeboSystem, and gz_ros2_control::GazeboSimSystem.
|
inlinevirtual |
Perform the mode-switching for the new command interface combination.
[in] | start_interfaces | vector of string identifiers for the command interfaces starting. |
[in] | stop_interfaces | vector of string identifiers for the command interfaces stopping. |
Reimplemented in gazebo_ros2_control::GazeboSystem, gz_ros2_control::GazeboSimSystem, and mock_components::GenericSystem.
|
inlinevirtual |
Prepare for a new command interface switch.
Prepare for any mode-switching required by the new command interface combination.
[in] | start_interfaces | vector of string identifiers for the command interfaces starting. |
[in] | stop_interfaces | vector of string identifiers for the command interfaces stopping. |
Reimplemented in mock_components::GenericSystem, and ros2_control_demo_example_3::RRBotSystemMultiInterfaceHardware.
|
pure virtual |
Read the current state values from the actuator.
The data readings from the physical hardware has to be updated and reflected accordingly in the exported state interfaces. That is, the data pointed by the interfaces shall be updated.
[in] | time | The time at the start of this control loop iteration |
[in] | period | The measured time taken by the last control loop iteration |
Implemented in gazebo_ros2_control::GazeboSystem, gz_ros2_control::GazeboSimSystem, mock_components::GenericSystem, ros2_control_demo_example_1::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_10::RRBotSystemWithGPIOHardware, ros2_control_demo_example_11::CarlikeBotSystemHardware, ros2_control_demo_example_12::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_2::DiffBotSystemHardware, ros2_control_demo_example_3::RRBotSystemMultiInterfaceHardware, ros2_control_demo_example_4::RRBotSystemWithSensorHardware, ros2_control_demo_example_5::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_7::RobotSystem, ros2_control_demo_example_8::RRBotTransmissionsSystemPositionOnlyHardware, and ros2_control_demo_example_9::RRBotSystemPositionOnlyHardware.
|
inline |
Set life-cycle state of the actuator hardware.
|
pure virtual |
Write the current command values to the actuator.
The physical hardware shall be updated with the latest value from the exported command interfaces.
[in] | time | The time at the start of this control loop iteration |
[in] | period | The measured time taken by the last control loop iteration |
Implemented in mock_components::GenericSystem, ros2_control_demo_example_7::RobotSystem, gazebo_ros2_control::GazeboSystem, gz_ros2_control::GazeboSimSystem, ros2_control_demo_example_1::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_10::RRBotSystemWithGPIOHardware, ros2_control_demo_example_11::CarlikeBotSystemHardware, ros2_control_demo_example_12::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_2::DiffBotSystemHardware, ros2_control_demo_example_3::RRBotSystemMultiInterfaceHardware, ros2_control_demo_example_4::RRBotSystemWithSensorHardware, ros2_control_demo_example_5::RRBotSystemPositionOnlyHardware, ros2_control_demo_example_8::RRBotTransmissionsSystemPositionOnlyHardware, and ros2_control_demo_example_9::RRBotSystemPositionOnlyHardware.