ROS control-----hardware_interface简介

本文详细介绍了ROS_Control中的hardware_interface模块,包括其主要数据结构如resource_handle、hardware_interface和RobotHW等,以及如何通过自定义实现扩展功能。同时给出了具体的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

   hardware_interface在ros_control中占有重要地位,controller通过hardware_interface与机器人硬件获得连接。


1 hardware_interface主要数据结构

1.1 resource handle

    这些handle主要功能包括存入resource,并提供相应获取resource接口。




1.2 hardware interface

    这些硬件接口主要功能有register handle/get handle/和claim resource/clearclaim/getclaims等。


1.3 RobotHW

    定义了一些框架接口如下,用户可以填充实现。

a)hardware interface切换:

virtual bool init (ros::NodeHandle &root_nh,ros::NodeHandle &robot_hw_nh)

virtual bool prepareSwitch (const std::list< ControllerInfo > &start_list, const std::list< ControllerInfo > &stop_list)

virtual void doSwitch (const std::list< ControllerInfo > &, const std::list< ControllerInfo > &)

virtual void read (const ros::Time &time, constros::Duration &period)

virtual void write (const ros::Time &time, constros::Duration &period)

b)resource管理

virtual bool checkForConflict (const std::list< ControllerInfo > &info) const

另外由于该接口继承了hardware_interface::InterfaceManager所以还支持:

T * get ()

std::vector< std::string > getInterfaceResources (std::string iface_type) const

std::vector< std::string > getNames () const

void registerInterface (T *iface)

void registerInterfaceManager (InterfaceManager *iface_man)




2 应用示例

  这里参考了ROS wiki给出如何定义自己robot并使用controller manager控制它。

  目前ros_control已经支持了一些常用标准hardware interface和controller,如果能满足需求可以直接使用,如果不能满足需求可以自定义扩展自己的接口和controller,如下示意图所示:


      上图中白色框中接口是ros_control已经支持的标准hardware接口,对应是已经支持的controller,下面Robot Specific controller是用户扩展定义的controller。


#include <hardware_interface/joint_command_interface.h>
#include <hardware_interface/joint_state_interface.h>
#include <hardware_interface/robot_hw.h>

class MyRobot : public hardware_interface::RobotHW
{
public:
  MyRobot() 
 { 

   //register and use existing robot standard hardware interfaces
   // connect and register the joint state interface
   hardware_interface::JointStateHandle state_handle_a("A", &pos[0], &vel[0], &eff[0]);
   jnt_state_interface.registerHandle(state_handle_a);

   hardware_interface::JointStateHandle state_handle_b("B", &pos[1], &vel[1], &eff[1]);
   jnt_state_interface.registerHandle(state_handle_b);

   registerInterface(&jnt_state_interface);

   // connect and register the joint position interface
   hardware_interface::JointHandle pos_handle_a(jnt_state_interface.getHandle("A"), &cmd[0]);
   jnt_pos_interface.registerHandle(pos_handle_a);

   hardware_interface::JointHandle pos_handle_b(jnt_state_interface.getHandle("B"), &cmd[1]);
   jnt_pos_interface.registerHandle(pos_handle_b);

   registerInterface(&jnt_pos_interface);

   
   //register some robot specific interfaces
registerInterface(&cool_interface);
//Implement robot-specific resouce management
bool checkForConflict(const std::list<ControllerInfo>& info) const
{ // this list of controllers cannot be running at the same time
 ... return true;
// this list of controller can be running at the same time
...
return false;
}

}

private: hardware_interface::JointStateInterface jnt_state_interface;
//standard hardware interface
hardware_interface::PositionJointInterface jnt_pos_interface;//standard hardware interface
MyCustomInterface cool_interface; //custom specific hardware interface
double cmd[2]; double pos[2]; double vel[2]; double eff[2];

}




以上添加了custom hardware interface来支持用特定controller做特定控制;另一种方式是在MyRobot仅仅添加一些特定函数接口实现特定控制(没有定义特定硬件接口class),通过MyRobot类自注册实现这些接口的可访问如下,

#include <hardware_interface/joint_command_interface.h>
#include <hardware_interface/joint_state_interface.h>
#include <hardware_interface/robot_hw.h>

class MyRobot : public hardware_interface::RobotHW, public hardware_interface::HardwareInterface
{
public:
  MyRobot()
 {
   //register and use existing robot standard hardware interfaces
   // connect and register the joint state interface

   hardware_interface::JointStateHandle state_handle_a("A", &pos[0], &vel[0], &eff[0]);
   jnt_state_interface.registerHandle(state_handle_a);

   hardware_interface::JointStateHandle state_handle_b("B", &pos[1], &vel[1], &eff[1]);
   jnt_state_interface.registerHandle(state_handle_b);

   registerInterface(&jnt_state_interface);

   // connect and register the joint position interface
   hardware_interface::JointHandle pos_handle_a(jnt_state_interface.getHandle("A"), &cmd[0]);
   jnt_pos_interface.registerHandle(pos_handle_a);

   hardware_interface::JointHandle pos_handle_b(jnt_state_interface.getHandle("B"), &cmd[1]);
   jnt_pos_interface.registerHandle(pos_handle_b);

   registerInterface(&jnt_pos_interface);

 

    // register the MyRobot class itself to make the 'someCoolFunction' available
    // the MyRobot class inherits from HardwareInterface to make this possible


     registerInterface(this);

     void someCoolFunction();


   // Implement robot-specific resouce management
    bool checkForConflict(const std::list<ControllerInfo>& info) const
    {
       // this list of controllers cannot be running at the same time
       ...
       return true;

       // this list of controller can be running at the same time
       ...
       return false;
    }


  }

  private:
  hardware_interface::JointStateInterface jnt_state_interface; //standard hardware interface
  hardware_interface::PositionJointInterface jnt_pos_interface;//standard hardware interface
  double cmd[2]; double pos[2]; double vel[2]; double eff[2];

};



以上的MyRbot class通过如下代码,就可以被controller manager和controller使用了:


main()
{
   MyRobot robot;
  controller_manager::ControllerManager cm(&robot);

  while (true)
  {
     robot.read(); //to access hardware driver, generally need do some wrap and customization in MyRobot class
     cm.update(robot.get_time(), robot.get_period());
     robot.write(); //to access hardware driver, generally need do some wrap and customization in MyRobot class
     sleep();
  }
}




3 参考文献

  参考ROS WiKi改编。





下列软件包有未满足的依赖关系: ros-noetic-camera-info-manager : 依赖: libboost-all-dev 但是它将不会被安装 依赖: ros-noetic-camera-calibration-parsers 但是它将不会被安装 依赖: ros-noetic-image-transport 但是它将不会被安装 依赖: ros-noetic-roscpp 但是它将不会被安装 依赖: ros-noetic-roslib 但是它将不会被安装 ros-noetic-control-toolbox : 依赖: libtinyxml-dev 但是它将不会被安装 依赖: ros-noetic-dynamic-reconfigure 但是它将不会被安装 依赖: ros-noetic-realtime-tools 但是它将不会被安装 依赖: ros-noetic-roscpp 但是它将不会被安装 ros-noetic-controller-manager : 依赖: ros-noetic-controller-interface 但是它将不会被安装 依赖: ros-noetic-controller-manager-msgs 但是它将不会被安装 依赖: ros-noetic-hardware-interface 但是它将不会被安装 依赖: ros-noetic-pluginlib 但是它将不会被安装 依赖: ros-noetic-roscpp 但是它将不会被安装 依赖: ros-noetic-rospy 但是它将不会被安装 ros-noetic-joint-limits-interface : 依赖: ros-noetic-hardware-interface 但是它将不会被安装 依赖: ros-noetic-roscpp 但是它将不会被安装 依赖: ros-noetic-urdf 但是它将不会被安装 ros-noetic-polled-camera : 依赖: ros-noetic-image-transport 但是它将不会被安装 依赖: ros-noetic-roscpp 但是它将不会被安装 ros-noetic-transmission-interface : 依赖: libtinyxml-dev 但是它将不会被安装 依赖: ros-noetic-hardware-interface 但是它将不会被安装 依赖: ros-noetic-pluginlib 但是它将不会被安装 依赖: ros-noetic-roscpp 但是它将不会被安装
03-15
<think>好的,我现在需要解决用户遇到的关于ROS软件包依赖问题。用户列出了多个ros-noetic开头的软件包,每个都有未满足的依赖项。首先,我应该分析这些依赖项的共同点,看看是否有共同的解决方案。 首先看第一个包ros-noetic-camera-info-manager,它需要libboost-all-dev,但无法安装。这可能是系统中缺少Boost库的开发版本。同样,其他依赖如ros-noetic-camera-calibration-parsers、image-transport等可能因为基础依赖未满足而无法安装。此外,多个包都依赖roscpp、roslib等,这说明可能ROS Noetic的基础环境没有正确安装或者部分组件缺失。 接下来,ros-noetic-control-toolbox需要libtinyxml-dev,这个包可能未被安装。同样的问题出现在transmission-interface中。而controller-manager、joint-limits-interface等包依赖hardware-interface、pluginlib等,这些可能是ROS中的中间件包,可能用户没有完整安装相关的ROS组件。 我的思路应该是先处理系统级的依赖,比如libboost-all-dev和libtinyxml-dev。这两个都是Debian/Ubuntu的系统包,用户可能需要使用apt-get来安装。然后,处理ROS相关的依赖,可能需要通过rosdep或者重新安装ROS的特定组件来补全缺失的包。 可能的步骤包括: 1. 更新系统包列表,确保软件源是最新的。 2. 安装提到的系统依赖,如libboost-all-dev和libtinyxml-dev。 3. 使用rosdep检查并安装缺失的ROS依赖。 4. 如果仍然有问题,考虑重新安装ROS Noetic的桌面完整版,确保所有基础组件都已安装。 5. 最后,再次尝试安装这些软件包,看是否问题解决。 需要注意的是,用户可能在安装这些包时没有正确配置ROS的软件源,或者没有运行rosdep初始化。此外,软件包的依赖关系可能需要递归处理,可能需要使用apt的-f install选项来修复损坏的依赖。 另外,用户可能没有正确添加ROS的仓库到apt源中,导致无法找到相关的ROS包。需要确认/etc/apt/sources.list.d/中的ROS源是否正确。 最后,在解决依赖问题时,可能需要按照依赖顺序逐个安装,或者同时安装多个包,让apt自动处理依赖关系。</think>在安装ROS Noetic软件包时遇到依赖关系问题,通常是由于系统库缺失或ROS组件未完整安装导致。以下是分步解决方案: --- ### **一、系统级依赖处理** #### 1. 安装缺失的系统库 以下两个库是多个ROS包的基础依赖: ```bash sudo apt-get install libboost-all-dev libtinyxml-dev ``` #### 2. 更新软件源并修复依赖 ```bash sudo apt-get update sudo apt-get -f install # 自动修复依赖链 ``` --- ### **二、ROS组件依赖处理** #### 1. 安装ROS核心组件 多个软件包依赖`roscpp`, `rospy`, `roslib`等基础组件,需确保安装完整ROS环境: ```bash sudo apt-get install ros-noetic-desktop-full ``` #### 2. 安装缺失的ROS包 手动安装未满足的ROS依赖: ```bash sudo apt-get install \ ros-noetic-camera-calibration-parsers \ ros-noetic-image-transport \ ros-noetic-dynamic-reconfigure \ ros-noetic-realtime-tools \ ros-noetic-controller-interface \ ros-noetic-controller-manager-msgs \ ros-noetic-pluginlib \ ros-noetic-urdf ``` #### 3. 使用rosdep检查依赖 如果仍有问题,运行以下命令自动安装依赖: ```bash sudo rosdep init rosdep update rosdep install --from-paths src --ignore-src -r -y ``` --- ### **三、验证安装** 尝试重新安装目标软件包: ```bash sudo apt-get install \ ros-noetic-camera-info-manager \ ros-noetic-control-toolbox \ ros-noetic-controller-manager \ ros-noetic-joint-limits-interface \ ros-noetic-polled-camera \ ros-noetic-transmission-interface ``` --- ### **四、常见问题排查** 1. **软件源问题** 确保已正确配置ROS仓库: ```bash sudo sh -c 'echo "deb http://packages.ros.org/ros/ubuntu $(lsb_release -sc) main" > /etc/apt/sources.list.d/ros-latest.list' sudo apt-key adv --keyserver 'hkp://keyserver.ubuntu.com:80' --recv-key C1CF6E31E6BADE8868B172B4F42ED6FBAB17C654 sudo apt-get update ``` 2. **依赖冲突** 如果出现版本冲突,尝试单独安装冲突包并指定版本: ```bash sudo apt-get install <包名>=<版本号> ``` --- ### **五、总结** 该问题的核心原因是: 1. 缺少系统库(如`libboost-all-dev`) 2. ROS基础组件未完整安装(如`roscpp`, `image-transport`等) 3. 未通过`rosdep`自动解析依赖 按上述步骤操作后,大部分依赖问题可解决。如果仍有报错,建议提供完整的终端输出以便进一步分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值