ROS方向第二次汇报(5)

news2025/1/10 10:34:39

文章目录

  • 1.本方向内学习内容:
    • 1.1.自定义msg:
      • 1.1.1.定义msg文件:
      • 1.1.2.编辑配置文件:
    • 1.2.自定义srv:
      • 1.2.1.定义srv文件:
      • 1.2.2.编辑配置文件:
    • 1.3.服务通信案例实现:
      • 1.3.1.服务端实现:
        • 重点语法、接口等的复现与记忆以及一些注意事项:
      • 1.3.1.客户端实现:
        • 重点语法、接口等的复现与记忆以及一些注意事项:
    • 1.4.参数服务器:
    • 1.5.URDF集成Rviz基本流程:
      • 1.5.1.新建功能包,导入依赖:
      • 1.5.2.编写urdf文件:
      • 1.5.3.在launch文件集成URDF与Rviz:
      • 1.5.4.在Rviz中显示机器人模型:
    • 1.6.再识URDF标签:
      • 1.6.1.link:
        • visual(描述外观):
            • geometry(设置连杆形状):
          • origin(设置偏移量与倾斜角度):
          • material(设置颜色):
        • 碰撞参数等:
      • 1.6.2.joint:
        • parent (必须):
        • child link:
        • origin:
        • axis:(需要转动的关节需要设置这个参数)
      • 1.6.3. 完成小车仿真并加载到launch文件中:
      • 1.6.4.base_footprint优化urdf:

1.本方向内学习内容:

1.1.自定义msg:

1.1.1.定义msg文件:

功能包下新建msg目录,添加文件 Person.msg

string name
uint16 age
float64 height

1.1.2.编辑配置文件:

package.xml中添加编译依赖与执行依赖

<build_depend>message_generation</build_depend>
<exec_depend>message_runtime</exec_depend>

CMakeLists.txt编辑msg相关配置
1.

find_package(catkin REQUIRED COMPONENTS
  roscpp
  rospy
  std_msgs #std_msgs必须有
  message_generation #添加编译时依赖,加入这个
)
#配置msg源文件
add_message_files(
   FILES
   Person.msg #添加创建的msg源文件
 )
#生成消息时依赖于std_msgs
generate_messages(
   DEPENDENCIES
   std_msgs#添加std_msgs依赖
 )

去掉该依赖的注释。
4.

#执行时依赖
catkin_package(
#  INCLUDE_DIRS include
#  LIBRARIES plumbing_pub_sub
  CATKIN_DEPENDS roscpp rospy std_msgs message_runtime#加上message_runtime
#  DEPENDS system_lib
)

只放开CATKIN_DEPENDS一句,并加上message_runtime即可。

1.2.自定义srv:

srv=请求+相应

1.2.1.定义srv文件:

功能包下新建srv目录,添加xxx.srv文件:

int32 num1
int32 num2
---
int32 sum

注意:一定要按照格式来创建,三个-分割线不能少。上面是请求,下面是应答,注意顺序。

1.2.2.编辑配置文件:

与msg编辑配置文件相同。
package.xml中添加编译依赖与执行依赖

<build_depend>message_generation</build_depend>
<exec_depend>message_runtime</exec_depend>

CMakeLists.txt编辑msg相关配置
1.

find_package(catkin REQUIRED COMPONENTS
  roscpp
  rospy
  std_msgs #std_msgs必须有
  message_generation #添加编译时依赖,加入这个
)
#配置msg源文件
add_message_files(
   FILES
   Addints.srv #添加创建的srv源文件
 )
#生成消息时依赖于std_msgs
generate_messages(
   DEPENDENCIES
   std_msgs#添加std_msgs依赖
 )

去掉该依赖的注释。
4.

#执行时依赖
catkin_package(
#  INCLUDE_DIRS include
#  LIBRARIES plumbing_pub_sub
  CATKIN_DEPENDS roscpp rospy std_msgs message_runtime#加上message_runtime
#  DEPENDS system_lib
)

只放开CATKIN_DEPENDS一句,并加上message_runtime即可。

1.3.服务通信案例实现:

1.3.1.服务端实现:

#! usr/bin/env python 

import rospy
from plumbing_server_client.srv import Addints,AddintsResponse,AddintsRequest

def doNum(request):
    num1 = request.num1
    num2 = request.num2
    
    sum = num1 + num2
    response =AddintsResponse()
    response.sum = sum
    rospy.loginfo("服务器解析的数据num1 = %d, num2 = %d,响应的结果: sum = %d",num1,num2,sum)

    return response


def server():
    rospy.init_node("company")
    server = rospy.Service("addInts",Addints,doNum)
    rospy.loginfo("服务器已经启动了")
    rospy.spin()


if __name__=="__main__":
    server()

请添加图片描述

重点语法、接口等的复现与记忆以及一些注意事项:

1.实例化服务端对象**rospy.Service("话题名",数据类,回调函数)。
2.导包的时候为了方便可以使用通配符*,需要将Response类和Request类都导入。
3.可以这么理解:AddInts是一个大数据类,而AddIntsResponseAddIntsRequestAddInts.srv文件编译之后产生的子类。(不准确的说是一分为二)
请添加图片描
在产生的中间文件中便可发现
继承关系**。所以我们在服务端是用AddIntsResponse实例化对象,在客户端用AddIntsRequest实例化对象,而不是用AddInts实例化对象。
4.回调函数自动接收的参数是请求类型的(在本例中是两个数据),然后需要将数据取出来进行处理num1 = request.num1 num2 = request.num2 sum = num1 + num2
5.处理过后的结果放入实例化的response=AddintsResponse()对象中,然后存入处理过后的数据结果response.sum=sum,并返回response。
6.有回调函数都需要使用rospy.spin()

1.3.1.客户端实现:

#! usr/bin/env python

import rospy
from plumbing_server_client.srv import *
import sys

# ROS中内置了相关函数,这些函数可以判断服务器的状态,如果服务没有启动,那么就让客户端挂起。

def client():
    if len(sys.argv)!=3 :#包括一个默认的参数
        rospy.loginfo("传入的参数个数有误")
        sys.exit(1)

    rospy.init_node("me")
    client = rospy.ServiceProxy("addInts",Addints) #实例化客户端对象
    num1 = int (sys.argv[1])
    num2 = int (sys.argv[2])
    #等待服务器启动
    client.wait_for_service()#如果用rospy.wait_for_service("这里面需要话题名称")
    response = client.call(num1,num2)#组织请求数据,并发送请求,接收响应数据

    rospy.loginfo("响应的数据:%d",response.sum)# 处理响应

 

if __name__=="__main__":
    client()
重点语法、接口等的复现与记忆以及一些注意事项:

1.实例化客户端对象client=rospy.ServiceProxy("话题名",数据类),注意这里不是rospy.client,它是一个方法。
2.组织请求数据,并发送请求,接收相应数据。用已经实例化的客户端对象client.call(num1,num2),接收数据response=client.call(num1,num2)
优化:
3.从终端中传入参数:导入sys包,判断参数是否为三个(第一个参数为文件名,加上两个数字应该是三个)

if len(sys.argv)!=3 :#包括一个默认的参数
        rospy.loginfo("传入的参数个数有误")
        sys.exit(1)

不满足条件就打印错误日志信息并退出。len(sys.args)用来获取终端中传入的参数个数,sys.argv是一个列表(list)/数组,里面存放参数(字符),所以取出的时候应该使用下标引用操作符并进行强制转换。

    num1 = int (sys.argv[1])
    num2 = int (sys.argv[2])

4.解决先打开客户端抛出异常的问题:

	client.wait_for_service()#如果用rospy.wait_for_service("这里面需要话题名称")

加在发送请求前即可。

1.4.参数服务器:

1.设置参数:

	rospy.set_param("参数名(键)",value(值))

如:

	rospy.set_param("type_p","car")
    rospy.set_param("radius_p",0.15)

复用可以实现覆盖(修改)
查看参数列表:

	rosparam list

查看参数值:

	rosparam get <参数名>

2.查询参数:
相关函数有:(rospy包中)

1.get_param(“参数名”,默认值)#当参数存在时,返回对应的值,不存在返回默认值。
2.get_param_cached(“参数名”,默认值),与get_param使用方法一致,只是效率更高。
3.get_param_names(),获取所有参数名(键)的集合,可用for names in names来遍历输出。
4.has_param("参数名"),判断某个参数是否存在,返回true or false
5.search_param("参数名"),查找某个参数的键(/参数名)

3.删除参数:

	rospy.delete_param("参数名")

1.5.URDF集成Rviz基本流程:

1.5.1.新建功能包,导入依赖:

请添加图片描述
由于不涉及编写py/cpp文件,所以不需要导入roscpp、rospy等功能包。需要导入urdfxacro依赖。
在这里插入图片描述
在功能包路径下创建以下四个文件夹。

1.5.2.编写urdf文件:

<robot name="myCar">
    <link name="base_link">
        <visual>
            <geometry>
                <box size="0.5 0.2 0.1"/>
            </geometry>
        </visual>
    </link>
</robot>

一定要要注意/的位置!!!!!!!!!

1.5.3.在launch文件集成URDF与Rviz:

<launch>
     <!-- 在参数服务器载入urdf文件 -->
    <param name="robot_description" textfile="$(find urdf01_rviz)/urdf/car.urdf"/>
    <!-- 启动Rviz -->
    <node pkg="rviz" type="rviz" name="rviz" args="-d $(find urdf01_rviz)/config/show_myCar.rviz "/>

</launch>

------------------------ 在参数服务器载入urdf文件 ------------------------
robot name固定(robot_description),文件路径格式$(find 包名)路径到文件
--------------------------------- 启动Rviz ---------------------------------
pkg、type、name都是rviz,后面的args是rviz配置文件的路径,该配置文件最好放在当前功能包下的config文件夹中。

1.5.4.在Rviz中显示机器人模型:

roslaunch启动。
请添加图片描述
添加RobotModelAxes,然后将FIxed Frame设置为base_link

请添加图片描述
成功显示模型。

1.6.再识URDF标签:

成双标签/加在第二个最前面,单标签/加在最后面。

1.6.1.link:

linkrobot标签都有name的属性。

visual(描述外观):
geometry(设置连杆形状):

标签1:
box(盒状),属性:size=“长 宽 高”
标签2:
cylinder(圆柱),属性:radius="半径 length=“高”
标签3:
sphere(球体),属性:radius=“半径”
标签4:
mesh(为连杆添加皮肤),属性filename=“路径”(格式:package://功能包名/路径到文件)
请添加图片描述

origin(设置偏移量与倾斜角度):

属性1:
xyz="x偏移 y偏移 z偏移 "
属性2:
rpy=“x翻滚量 y俯仰量 z偏航量”(单位是弧度)

material(设置颜色):

material含有name属性。
标签1:
color,属性rgba(红绿蓝透明度)=“x y z a”(四者取值[0,1])

碰撞参数等:

后续介绍。

1.6.2.joint:

有两个属性:nametype
其中type包括:
在这里插入图片描述

parent (必须):

属性:
link=“父link名”

child link:

属性:
link=“子link名”

origin:

属性:
xyz=“x y z”(各轴线上的偏移量) rpy=“r p y”(各轴线上的偏移弧度)

axis:(需要转动的关节需要设置这个参数)

属性:
**xyz用于设置围绕哪个轴运动。**xyz=“ 0 0 1 ”表示绕z轴旋转

1.6.3. 完成小车仿真并加载到launch文件中:

编写urdf文件:
小炮车(mesh)

 0.17" rpy="0.0 1.05 1.57"/>
        
        
    </joint>
    <link name="paoGuan">
        <visual>
            <geometry>
                <cylinder radius="0.02" length="0.45"/>
            </geometry>
            <material name="color">
                <color rgba="1.0 0.2 0.3 0.55"/>
            </material> 
        </visual>
    </link>
</robot>

请添加图片描述

简陋小车:(带camera)

<robot name="myCar">
    <link name="base_link">
        <visual>
            <geometry>
                <box size="0.3 0.2 0.1"/>
            </geometry>
            <origin xyz="0 0 0" rpy="0 0 0"/>
            <material name="color">
                <color rgba="0.8 0.5 0.0 0.5"/>
            </material>
        </visual>
    </link>

    <link name="cam">
        <visual>
            <geometry>
                <box size="0.02 0.05 0.05"/>
            </geometry>
            <origin xyz="0.0 0.0 0.025" rpy="0.0 0.0 0.0"/>
            <material name="cam_color">
                <color rgba="0 0 1 0.5"/>
            </material>
        </visual>
    </link>

    <joint name="camera2Base" type="continuous">
        
        <parent link="base_link"/>
        <child link="cam"/>
        <origin xyz="0.12 0 0.05" rpy="0.0 0.0 0.0"/>
        <axis xyz="0 0 1"/> 
    </joint>
</robot>

1.关节优先:
关节的位置确定了子连杆父连杆的相对位置关系,关节的参考系是主参考系,而子连杆的参考系是以关节为中心的参考系
2.配置机器人状态发布者及相关节点:
要成功显示机器人模型,需要在launch文件中添加:

 <node pkg="joint_state_publisher" type="joint_state_publisher" name="joint_state_publisher"/>
<node pkg="robot_state_publisher" type="robot_state_publisher" name="robot_state_publisher"/>

如果要查看机器人关节旋转效果,需要在launch文件中添加:

<node pkg="robot_state_publisher" type="robot_state_publisher" name="robot_state_publisher"/>

并注释关节信息发布节点(解决cam抖动的问题)。
3.关节中心(位置)默认与父连杆中心重合

1.6.4.base_footprint优化urdf:

默认情况下,底盘中心点位于地图原点上,所以会导致机器人模型半沉入地下,可以使用优化策略,将初始link设置为一个尺寸极小的link(如半径为0.001m的球体或边长为0.001的立方体),然后再在初始link上添加底盘等刚体,这样实现,虽然仍然存在半沉现象,但可以基本忽略。
添加初始link:

<link name="base_footprint">
        <visual>
            <geometry>
                <box size="0.001 0.001 0.001"/>
            </geometry>
            <origin xyz="0 0 0" rpy="0 0 0"/>
            <material name="color">
                <color rgba="0.8 0.5 0.0 0.5"/>
            </material>
        </visual>
    </link>

添加关节:

<joint name="fp" type="fixed">
        <parent link="base_footprint"/>
        <child link="base_link"/>
        <origin xyz="0 0 0.05" rpy="0.0 0.0 0.0"/>
    </joint>

注意将base_footprint作为父连杆。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1430054.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

HTML+CSS:导航栏组件

效果演示 实现了一个导航栏的动画效果&#xff0c;当用户点击导航栏中的某个选项时&#xff0c;对应的选项卡会向左平移&#xff0c;同时一个小圆圈会出现在选项卡的中心&#xff0c;表示当前选项卡的位置。这个效果可以让用户更加清晰地了解当前页面的位置和内容。 Code <…

正点原子--STM32定时器学习笔记(2)

书接上文&#xff0c;本篇是对基本定时器实验部分进行的总结~ 实验目标&#xff1a;通过TIM6基本定时器定时500ms&#xff0c;让LED0每隔500ms闪烁。 解决思路&#xff1a;使用定时器6&#xff0c;实现500ms产生一次定时器更新中断&#xff0c;在中断里执行“翻转LED0”。 定时…

【leetcode题解C++】98.验证二叉搜索树 and 701.二叉搜索树中的插入操作

98. 验证二叉搜索树 给你一个二叉树的根节点 root &#xff0c;判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下&#xff1a; 节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。 示例…

kubernetes基本概念和操作

基本概念和操作 1.Namespace1.1概述1.2应用示例 2.Pod2.1概述2.2语法及应用示例 3.Label3.1概述3.2语法及应用示例 4.Deployment4.1概述4.2语法及应用示例 5.Service5.1概述5.2语法及应用示例5.2.1创建集群内部可访问的Service5.2.2创建集群外部可访问的Service5.2.3删除服务5.…

Zoho Mail企业邮箱商业扩展系列第1部分:入门指南与基础设置

今天让我们来认识一下王雪琳&#xff0c;她是一位独立经营的营销咨询机构的个体企业家。在开始自己的事业之前&#xff0c;她进行了广泛的市场调研&#xff0c;明确了自己的业务定位&#xff0c;并全力以赴地投入到了自己的企业中。 一、创业背景 王雪琳的营销业务主要集中在…

日志报错 git -c dif.mnemonicprefix=false -c core.guotepath=false 解决方法

前言: 在进行下面操作前,必须确保,你是否安装了Git。 查看Git 在命令行窗口中输入`git --version`: 如果这个命令成功显示了Git的版本信息,这表明Git已经被安装。 1. 使用Sourcetree SourceTree 是 Windows 和Mac OS X 下免费的 Git 和 Hg 客户端…

Kubernetes operator(五)api 和 apimachinery 篇

云原生学习路线导航页&#xff08;持续更新中&#xff09; 本文是 Kubernetes operator学习 系列第五篇&#xff0c;主要对 k8s.io/api 和 k8s.io/apimachinery 两个项目 进行学习基于 kubernetes v1.24.0 代码分析Kubernetes operator学习系列 快捷链接 Kubernetes operator&a…

数字巨轮航行大数据海洋:数据可视化引领时代潮流

在大数据时代的潮流中&#xff0c;数据可视化如同一艘畅行无阻的科技巨轮&#xff0c;引领我们穿越数字浩瀚的大海&#xff0c;使我们在信息的航程中游刃有余。下面我就从可视化从业者的角度&#xff0c;来简单说说数据可视化是如何帮助我们在大数据时代畅行无阻的。 数据可视化…

【Servlet】——Servlet API 详解

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【Servlet】 本专栏旨在分享学习Servlet的一点学习心得&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 一、HttpServlet二、Htt…

【unity小技巧】unity3d环境带雾的昼夜系统变化

最终效果 文章目录 最终效果眩光素材眩光配置全局灯光配置天空盒配置天空盒资产配置天空盒&#xff0c;开启雾 代码控制天空盒 环境 雾 灯光昼夜交替变化参考完结 眩光素材 链接&#xff1a;https://pan.baidu.com/s/1qlFSJSju6ZjwCylwkh14eA?pwdveww 提取码&#xff1a;veww…

Oracle和Mysql数据库

数据库 Oracle 体系结构与基本概念体系结构基本概念表空间(users)和数据文件段、区、块Oracle数据库的基本元素 Oracle数据库启动和关闭Oracle数据库启动Oracle数据库关闭 Sqlplussqlplus 登录数据库管理系统使用sqlplus登录Oracle数据库远程登录解锁用户修改用户密码查看当前语…

Android学习之路(29) Gradle初探

前言: 大家回想一下自己第一次接触Gradle是什么时候&#xff1f; 相信大家也都是和我一样&#xff0c;在我们打开第一个AS项目的时候&#xff0c; 发现有很多带gradle字样的文件&#xff1a;setting.gradle, build.gradle,gradle.warpper,以及在gradle文件中各种配置&#xff…

来看看Tomcat和Web应用的目录结构

在前面两篇大致了解了Tomcat的架构和运行流程&#xff0c;以及Tomcat应用中的web.xml。 聊一聊Tomcat的架构和运行流程&#xff0c;尽量通俗易懂一点-CSDN博客 来吧&#xff0c;好好理解一下Tomcat下的web.xml-CSDN博客 那接下来&#xff0c;再看看Tomcat的目录&#xff0c;…

BeanDefinitionRegistry学习

Spring版本5.1.x 简介 在Spring框架中&#xff0c;BeanDefinitionRegistry是一个接口&#xff0c;它主要用于向注册表中注册BeanDefinition实例&#xff0c;完成注册的过程。该接口的主要方法是registerBeanDefinition&#xff0c;用于将一个BeanDefinition实例注册到注册表中…

分享一个WPF项目

最近在学习WPF开发方式&#xff0c;找到一些项目进行拆解学习&#xff1b;本位主要分享一个WPF项目&#xff0c;叫做WPFDevelopers&#xff0c;在git上大约有1.3K星&#xff0c;话不多说&#xff0c;先看看效果&#xff1a; 这个项目开发可以编译启动后直接查看样例、Xaml、Cha…

如何搭建私有云盘SeaFile并实现远程访问本地文件资料

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-hsDnDEybLME85dTx {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…

让AI作为人类的“副驾驶”

让AI作为副驾驶&#xff0c;辅助人类完成工作&#xff0c;是人工智能技术在实际应用中的一个重要方向。这个设想在多个领域都有广泛应用的可能性&#xff1a; 驾驶场景&#xff1a;自动驾驶技术中&#xff0c;AI副驾驶可以实时监测路况、规划最优行驶路线、预警潜在危险&#x…

接口自动化测试详解

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号【互联网杂货铺】&#xff0c;回复 1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 引言 与UI相比&#xff0c;接口一旦研发完成&#xff0c;通常变…

Unity | Spine动画记录

https://blog.csdn.net/linshuhe1/article/details/79792432 https://blog.csdn.net/winds_tide/article/details/128925407 1.需要的三个文件 通常制作好的 Spine 动画导出时会有三个文件&#xff1a; .png 、.json 和 .atlas&#xff1a; skeleton-name.json 或 skeleton-…

【10秒开服】雾锁王国服务器全自动部署教程

你是火焰之子&#xff0c;一个濒死种族最后的希望火苗。苏醒吧&#xff0c;克服腐化一切的迷雾所裹挟的恐怖&#xff0c;重新夺回你的王国所失落的瑰丽。置身于广袤世界&#xff0c;战胜难以想象的强大Boss&#xff0c;修造宏伟厅堂&#xff0c;在这款至多16名玩家的合作类生存…