四足机器人应用篇之solidwork导出URDF

2024-04-16 07:52

本文主要是介绍四足机器人应用篇之solidwork导出URDF,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 欢迎关注微信公众号 “四足机器人研习社”,本公众号的文章和资料和四足机器人相关,包括行业的经典教材、行业资料手册,同时会涉及到职业知识学习及思考、行业发展、学习方法等一些方面的文章。

 

|1.URDF介绍

图片

一个URDF pakage示例

    urdf是ROS用于描述机器人所有元素的模型文件,采用XML格式书写,全称是United Robotics Description Format,即统一机器人描述格式;而xacro则是升级版的urdf,简化了urdf模型,用于复杂机器人的建模。

    URDF在机器人领域很流行,尤其是在ROS社区中,机器人三维模型可视化主要用的就是URDF。一个URDF文件包就是一个ros的pakage,当你有了URDF包之后,就可以在RVIZ或者gazebo进行可视化或者仿真,当然,很多其他机器人仿真软件也支持URDF文件或者也有相应插件支持转换,如webots虽然不支持urdf文件,但是可以通过一个插件进行转换。

    

        一般来说创建URDF模型的第一步是创建机器人功能包,并在此功能包中创建所需的文件夹结构。一般来说,至少需要以下文件夹:

  • urdf:用于存放机器人模型的URDF文件或xacro文件;

  • config:用于保存rviz配置文件;

  • launch:用于保存相关启动文件;

meshes:用于放置URDF中引用的模型渲染文件,一般可以是stl格式的三维模型文件。

图片

meshs文件夹,存放模型的外观文件

图片

urdf文件夹中的urdf文件示例

    在创建了文件夹结构后,我们需要编写launch文件,调用mbot_base.urdf文件,并在rviz文件夹下放置rviz的配置文件。这样做是为了启动和配置机器人模型。

    

    URDF文件里面有着与XML语言格式。要定义好一个机器人,首先你得知道机器人有什么。一个机器人主要由连杆(link)和关节(joint)组成, URDF具有类似XML树状结构的,比如下面的例子:

图片

URDF文件结构

       上面的 link 与 joint 是 robot 下面的孩子,换句话说 joint 和 link 隶属于 robot 。知道了机器人的基本构成之后还不够,还需要知道基本组成部分的一些物理信息,例如连杆的质量属性,惯量属性,颜色,以及关节的种类,这到底是转动关节还是平动关节。因此 link 和 joint 也要有自己的子分量,比如 inertial 和 visual , visual 下面还可以再次细分 geometry 和 material ,然后 material 下面还可以有自己的子分量,由此往复我们就可以用URDF来充分定义好一个机器人的各个信息。所以一个增加了这些额外信息的URDF文件内容例子如下

图片

    我们定义好了机器人的组成部分以及各个部分所具有的信息,接着还需要有属性描述这些量。比如 robot,link,joint 都有 name属性,一个用来辨识模块的字符串。color 有 rgba 属性,用来定义连杆的外表颜色。添加了相关信息的URDF文件长这个样子:

图片

        在几何结构中,它们是这样子的,连杆link之间以关节joint连接,形成一种树状结构,一般树的根节点就是机器人的基坐标系base_link

图片

    完成了URDF文件的编写,就可以通过ROS(Robot Operating System)进行编译和验证。我们说过,一个URDF文件包就是一个ros的pakage,这样我们可以像正常运行ros pakage一样,新建工作空间并初始化,然后把urdf包放到src文件中,回到工作空间进行编译,编译后的URDF文件可以通过roslaunch命令进行启动和验证。同时,我们还可以使用urdf_to_graphviz工具将URDF文件转换为PDF格式,以便更直观地查看模型的整体结构图。

|2.SW2URDF插件

    大多数时候我们并不需要直接手写URDF文件,我i们可以直接通过三维建模软件建立机器人三维模型后使用插件直接导出为URDF文件,以solidworks为例:

|2.1.sw导出为urdf

假设你已经建立好了机器人三维模型,那么接下来只需要按照以下步骤即可获得urdf文件:

  1. 下载安装插件:地址如下:
    sw2urdf插件链接地址:ROS/solidworks_urdf_exporter (github.com)

    如果上不了github的朋友可以通过百度云下载:

    链接:https://pan.baidu.com/s/1TfldLXv0vVJJb2GtSVpfGg?pwd=1024,提取码:1024

    图片

  2. 打开solidworks并打开所需要转换的三维文件


依次在各个关节建立坐标轴和坐标系,如下图

图片

在个关节建立坐标轴和坐标系

图片

建立坐标系

然后点击工具——tools——找到插件,点击插件,如下图

图片

1这里命名连杆——2选择坐标系——3选择相应零件——4这里点击👆👇可以增加或者减少子连杆,如下图

图片

        同理设置第二个连杆:1——设置连杆名字——2设置关节名字——3选择关节坐标系——4选择关节轴——5选择关节类型,其中revolute是有关节限位的,是一般的机器人关节类型,而continous是无限旋转的,如车轮关节,prismatic是平移关节,fixed固定连接,如激光雷达固连在机器人身上——6依次选择连杆的零件——7设置子连杆数量,如下图

图片

设置步骤

图片

几种关节类型

        接着导出,选择Preview and Export..,之后界面如下:这里可以检查以下相关设置,如坐标系,旋转轴旋转方向(0是不转,1是旋转),关节限位大小等,如下图

图片

        然后点击next,如果没问题可以点击导出了;点击Export URDF and Meshes,这样会同时生成stl文件,作为其三维外观,如下图

图片

        稍等一会儿,大功告成!如下图:

图片

图片

        导出完成后可以检查一下.urdf文件,再次检查有没有错误。然后就可以使用URDF文件包在ros环境或者其他支持URDF文件的环境仿真了!!!

参考:

[1]URDF学习(一)什么是URDF以及怎么理解一个URDF文件-CSDN博客

这篇关于四足机器人应用篇之solidwork导出URDF的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/908207

相关文章

Java导出Excel动态表头的示例详解

《Java导出Excel动态表头的示例详解》这篇文章主要为大家详细介绍了Java导出Excel动态表头的相关知识,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录前言一、效果展示二、代码实现1.固定头实体类2.动态头实现3.导出动态头前言本文只记录大致思路以及做法,代码不进

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

Python数据处理之导入导出Excel数据方式

《Python数据处理之导入导出Excel数据方式》Python是Excel数据处理的绝佳工具,通过Pandas和Openpyxl等库可以实现数据的导入、导出和自动化处理,从基础的数据读取和清洗到复杂... 目录python导入导出Excel数据开启数据之旅:为什么Python是Excel数据处理的最佳拍档

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或