宇树开源四足机器人仿真-之环境配置

本文详细介绍了如何在Gazebo中运行UnitreeGuide的开源代码,包括安装依赖(Eigen库、matplotlib、numpy、LCM通信库、pthread库),创建ROS工作空间,解决编译过程中遇到的问题(如move_base_msgs缺失、rospkg模块未找到、defusedxml模块未找到),以及如何启动和运行demo。在运行过程中,还提到了如何处理环境变量问题和控制器设置。

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

unitree guide开源代码在gazebo中的运行

1 安装依赖

  1. Eigen库

    方法1:使用apt安装

     sudo apt install libeigen3-dev
    

    方法2:
    首先下载源码:
    [http://eigen.tuxfamily.org/index.php?title=Main_Page]
    解压缩并在终端中打开该文件夹,然后进行编译:

     mkdir build
     cd build
     cmake ..
     sudo make install
    

    在任意终端输入命令:

     cd /usr/include/eigen3
    

    或者

     cd /usr/local/include/eigen3
    

    如果上述路径存在,则说明已经安装成功

  2. 安装调试用的matplotlib和numpy

    查看系统python版本,如果为3.6/7/8,则需切换为2.7, 命令如下:
    sudo ln -s /usr/bin/python2.7 /usr/bin/python
    PATH=/usr/bin:$PATH
    然后运行以下语句没有报错则说明已经有numpy和matplotlib两个python库,否则需要安装这两个库

     pip install numpy
     pip install matplotlib
    
  3. 安装通信库lcm
    在任意终端输入:

     lcm-tester	
    

    如果可以正常运行,则LCM已经成功安装,否则需要进行手动安装,如下所示:

     # 安装依赖
     # 必选
     sudo apt install build-essential libglib2.0-dev cmake
     # 可选(如果没安装它最后LCM失败则最好安装),可根据使用的语言选择安装
     sudo apt install default-jdk python-all-dev liblua5.1-dev golang doxygen
     # 拷贝源码
     git clone https://github.com/lcm-proj/lcm.git
     cd lcm
     # 编译并安装
     mkdir build && cd build
     cmake ..
     make -j4
     sudo make install
    
  4. 多线程pthread库

    这个库通常已经和ubuntu一同安装,在任意终端输入

     getconf GNU_LIBPTHREAD_VERSION
    

    如果显示版本信息,则已经成功安装。

2 创建ros工作空间并利用catkin_make工具编译

  1. 创建工作空间

     #catkin_ws是ROS工作的路径即ros的工作空间,可以自定义名字
     mkdir -p ~/catkin_ws/src
     cd ~/catkin_ws/
     catkin_make
    

    如果catkin_make报错,可能与系统安装了anaconda有关2,则在初始化工作空间时,将catkin_make替换为

     catkin_make -DPYTHON_EXECUTABLE=/usr/bin/python3
    
  2. 下载package并编译
    在下方网址
    https://github.com/unitreerobotics

    分别下载unitree_ros、unitree_guide,unitree_ros_to_real/unitree_legged_msgs,然后放到catkin_ws/src功能包下,然后编译

    cd ~/catkin_ws
    #catkin_ws是ROS工作的路径
    catkin_make
    有时因为catkin_make的软件包编译顺序没有配置,会导致找不到依赖项的报错,这时再次执行catkin_make即可解决;其他错误如下:

2.1*报错解决

错误如下:

错误一:
CMake Error at /opt/ros/noetic/share/catkin/cmake/catkinConfig.cmake:72 (find_package):
Could not find a configuration file for package move_base_msgs.

Set move_base_msgs_DIR to the directory containing a CMake configuration
file for move_base_msgs. The file will have one of the following names:

move_base_msgsConfig.cmake
move_base_msgs-config.cmake

Call Stack (most recent call first):
simple_navigation_goals/CMakeLists.txt:7 (find_package)

-- Configuring incomplete, errors occurred!
Invoking "cmake" failed

此报错是由于move_base_msgs缺失引起的,使用如下命令安装这个功能包:

sudo apt-get install ros-noetic-navigation

如果不是noetic版本的ros只需要更改版本名称即可。

错误二:
substitution args not supported: No module named 'rospkg'

解决方法:

pip install rospkg

错误三:

ModuleNotFoundError: No module named ‘defusedxml

解决方法:将系统python版本切换为2.7

sudo ln -s /usr/bin/python2.7 /usr/bin/python
PATH=/usr/bin:$PATH

运行demo

  1. catkin_make编译成功后

  2. 输入

     source ./devel/setup.bash
    
  3. 然后在工作空间下再打开一个终端,输入命令打开仿真器:

     roslaunch unitree_guide gazeboSim.launch 
    

    打开仿真器时可能会出现如下报错:

    RLException: [gazeboSim.launch] is neither a launch file in package [unitree_guide] nor is [unitree_guide] a launch file name
    The traceback for the exception was written to the log file
    在这里插入图片描述这种错误的出现,是因为此ros工作空间的环境变量没有被添加!!! 添加环境变量即可,添加环境变量方法不唯一,这里介绍两种方法,两种方式各有优点:
    方法一
    确保在建立工作空间的时候就已经执行catkin_make
    直接在命令行,进入到工作空间,然后执行以下命令:

     source ./devel/setup.bash
    

    这种方式,可以直接在命令行中操作,短时间内是看着比较简单的。每次不确定的时候就可以直source一下。

    方法二
    直接对环境变量文件进行修改
    在命令行打开文件./bashrc,命令如下:

     #不行的话在下面语句加sudo  
     gedit ~/.bashrc
    

    在文件最后加入以下语句:

     source ~/work_ws/devel/setup.bash
     export ROS_PACKAGE_PATH=${ROS_PACKAGE_PATH}:~/work_ws/
    

    注意:这里的work_ws是ROS工作的路径

    添加完之后,重启bashrc,直接执行以下语句

     source ~/.bashrc
    

    查看ROS路径是否添加上

     echo $ROS_PACKAGE_PATH
    

    在这里插入图片描述 添加上则如上图所示。

  4. 最后再在工作空间下打开一个终端,启动控制器:

     rosrun unitree_guide junior_ctrl
    

在这里插入图片描述出现[ERROR] Function setProcessScheduler failed.属于正常情况,这是因为没有将控制器程序设置为实时进程,初步仿真可以选择忽略。而后在该终端界面按下数字键<2>切入到固定站立模式,<1>返回阻尼模式

[1]https://blog.csdn.net/weixin_45467056/article/details/123569027
[2]https://zhuanlan.zhihu.com/p/628450886
[3]https://blog.csdn.net/qq_44164791/article/details/130351276

### 如何在 Gazebo 仿真中查看机器人元数姿态 在 ROS 和 Gazebo 的集成环境中,可以通过多种方式获取并查看机器人当前的姿态信息(包括位置和方向)。具体到元数表示的方向部分,以下是几种常见的方法: #### 使用 `tf` 或 `tf2` 获取元数 ROS 提供了强大的坐标变换工具 `tf` 和其改进版本 `tf2`。通过监听特定的坐标系转换关系,可以获得目标物体相对于某个参考帧的姿态数据。这些数据通常以几何消息形式发布,其中包含了线性位移和平面旋转角度以及三维空间中的朝向。 如果已经设置了正确的 TF结构,则可以直接利用命令行工具或者编程接口访问所需的信息。例如执行如下终端指令即可打印出两个指定链接间最新的相对变化情况,其中包括了用元数组成的部分[^1]: ```bash rosrun tf tf_echo /world_frame /robot_base_link ``` 这里 `/world_frame` 是全局参照系而 `/robot_base_link` 则代表移动平台底部固定点所在局部子框架名称,请依据实际项目调整参数值匹配各自定义好的命名约定。 另外也可以借助 Python 脚本来实现更灵活的功能扩展: ```python import rospy from geometry_msgs.msg import PoseStamped import tf2_ros import tf_conversions def get_pose(): try: trans = buffer.lookup_transform('map', 'base_footprint', rospy.Time()) pose_msg = PoseStamped() pose_msg.header.frame_id = "map" pose_msg.pose.position.x = trans.transform.translation.x pose_msg.pose.position.y = trans.transform.translation.y pose_msg.pose.position.z = trans.transform.translation.z quat_tf = [ trans.transform.rotation.x, trans.transform.rotation.y, trans.transform.rotation.z, trans.transform.w ] euler_angles = tf_conversions.transformations.euler_from_quaternion(quat_tf) print(f"EulerAngles: Roll={euler_angles[0]}, Pitch={euler_angles[1]}, Yaw={euler_angles[2]}") except (tf2_ros.LookupException, tf2_ros.ConnectivityException, tf2_ros.ExtrapolationException): pass if __name__ == '__main__': rospy.init_node('get_robot_pose') buffer = tf2_ros.Buffer() listener = tf2_ros.TransformListener(buffer) rate = rospy.Rate(10.0) while not rospy.is_shutdown(): get_pose() rate.sleep() ``` 上述脚本会持续查询 map 至 base_footprint 这两条路径间的最新映射关联,并输出对应的欧拉角数值便于直观理解方位概念[^3]. #### 订阅 Odometry 主题读取元数 许多导航堆栈都会定期广播里程计估计结果至标准主题名下比如 odom 。此消息类型一般包含速度分量外加完整的六自由度刚体运动学描述符即 SE(3) 特征集合 ,所以同样能够从中提取出感兴趣的目标属性字段。 下面给出了一段简单的 C++ 实现片段用于示范目的 : ```cpp #include <ros/ros.h> #include <nav_msgs/Odometry.h> void odometryCallback(const nav_msgs::OdometryConstPtr& msg){ double qx = msg->pose.pose.orientation.x; double qy = msg->pose.pose.orientation.y; double qz = msg->pose.pose.orientation.z; double qw = msg->pose.pose.orientation.w; ROS_INFO("Quaternion Orientation : (%f,%f,%f,%f)",qx,qy,qz,qw); } int main(int argc,char **argv){ ros::init(argc, argv,"read_odom"); ros::NodeHandle nh; ros::Subscriber sub = nh.subscribe("/odom",1,&odometryCallback); ros::spin(); } ``` 该程序订阅名为 "/odom" 的话题并将每次接收到的新样本里的定向成分逐一记录下来以便后续分析处理[^4]. #### 可视化 RViz 中观察元数表现形态 最后值得一提的是除了单纯依赖文字表达之外还可以充分利用图形界面的优势让抽象的数据变得形象起来。RViz 就是一个非常优秀的可视化调试辅助软件它支持渲染各种传感器采集回来的结果同时也兼容前面提到过的TF体系从而方便开发者快速定位潜在错误源或是验证算法效果等等[^2]. 只需简单配置好场景布局添加必要的显示插件组件之后就能即时看到动态更新后的轨迹曲线走向甚至还能附加额外的效果层进一步增强可读性和趣味性! ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值