1 ROS2介绍与安装

news2025/1/9 2:12:39

1 ROS2介绍与安装

  • 1.1 Ubuntu配置与ROS2安装
    • 1.1.1 Ubuntu22.04安装
    • 1.1.2 下载安装ROS2
    • 1.1.3 配置ROS2环境并测试
  • 1.2 使用VSCode搭建ROS2开发环境
    • 1.2.1 安装并配置VSCode
    • 1.2.2 创建ROS2工程的方法
    • 1.2.3 使用VSCode创建ROS2的C/C++项目
    • 1.2.4 使用VSCode创建ROS2的Python项目
  • 1.3 ROS2的基本体系
    • 1.3.1 ROS2架构
    • 1.3.2 ROS2和ROS1的区别
    • 1.3.3 ROS2应用方向
  • 1.4 总结和参考内容
    • 1.4.1 总结
    • 1.4.2 参考内容

  • 其他ROS2学习笔记: ROS2学习笔记
  • 代码仓库:Github连接地址
  • 欢迎各位互相学习交流

1.1 Ubuntu配置与ROS2安装

1.1.1 Ubuntu22.04安装

  1. 下载Ubuntu22.04:本文选择 中科大镜像网 ,选择Ubuntu22.04镜像下载,后续放入VMware进行 断网安装

在这里插入图片描述

VMware15链接:
链接:https://pan.baidu.com/s/1BbaGtDhjVXCWeS2vuk3bRw
提取码:7lzk 复制这段内容后打开百度网盘手机App,操作更方便哦

  1. Ubuntu22.04 换源:将桌面版本的Ubuntu的软件更新设置来源为国内的镜像,或者直接输入命令sudo gedit /etc/apt/sources.list将内容改为如下所示:
deb https://mirrors.ustc.edu.cn/ubuntu/ jammy main restricted universe multiverse
deb-src https://mirrors.ustc.edu.cn/ubuntu/ jammy main restricted universe multiverse
deb https://mirrors.ustc.edu.cn/ubuntu/ jammy-updates main restricted universe multiverse
deb-src https://mirrors.ustc.edu.cn/ubuntu/ jammy-updates main restricted universe multiverse
deb https://mirrors.ustc.edu.cn/ubuntu/ jammy-backports main restricted universe multiverse
deb-src https://mirrors.ustc.edu.cn/ubuntu/ jammy-backports main restricted universe multiverse
deb https://mirrors.ustc.edu.cn/ubuntu/ jammy-security main restricted universe multiverse
deb-src https://mirrors.ustc.edu.cn/ubuntu/ jammy-security main restricted universe multiverse
deb https://mirrors.ustc.edu.cn/ubuntu/ jammy-proposed main restricted universe multiverse
deb-src https://mirrors.ustc.edu.cn/ubuntu/ jammy-proposed main restricted universe multiverse

在这里插入图片描述

1.1.2 下载安装ROS2

  1. 输入命令sudo apt-get update -y对软件源进行更新,输入sudo apt-get upgrade -y对软件进行更新:
sudo apt-get update -y && sudo apt-get upgrade -y
  1. 获取ROS2的秘钥,并ROS2的存储库添加到源列表:
sudo apt install curl gnupg lsb-release && sudo curl -sSL https://raw.githubusercontent.com/ros/rosdistro/master/ros.key -o /usr/share/keyrings/ros-archive-keyring.gpg

echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/ros-archive-keyring.gpg] http://packages.ros.org/ros2/ubuntu $(source /etc/os-release && echo $UBUNTU_CODENAME) main" | sudo tee /etc/apt/sources.list.d/ros2.list > /dev/null
  1. 如果出现关于 raw.githubusercontent.com 连接失败的处理
    1. 访问 https://tool.lu/ip/ 并输入域名 raw.githubusercontent.com,查询 ip 地址,这里查询到的是 185.199.108.133

在这里插入图片描述

    1. 修改 sudo gedit /etc/hosts文件,并手动添加DNS解析:

在这里插入图片描述

  1. 下载ROS2-humble:更新软件到最新版本,然后下载ROS2-humble:
sudo apt-get update -y && sudo apt-get upgrade -y

sudo apt install ros-humble-desktop
  1. 安装colcon构建工具: 不同于之前ROS1的catkin工具,ROS2用colcon进行包的构建:sudo apt install python3-colcon-common-extensions

1.1.3 配置ROS2环境并测试

  1. 配置ROS2环境: 默认ROS2-humble安装在/opt/ros/humble/下,将ROS2的环境添加到用户环境文件~/.bashrc中,输入echo "source /opt/ros/humble/setup.bash" >> ~/.bashrc

  2. 测试ROS2:ros2 run turtlesim turtlesim_noderos2 run turtlesim turtle_teleop_key运行小乌龟

在这里插入图片描述

1.2 使用VSCode搭建ROS2开发环境

1.2.1 安装并配置VSCode

  1. 安装VSCode: VSCode下载地址,持续下一步即可安装完成。

  2. 下载完成后安装VSCode插件:插件主要包括 C/C++Python 以及 CMake 的插件,如下图所示:

在这里插入图片描述

1.2.2 创建ROS2工程的方法

  1. ROS2 create命令:通过 ros2 pkg create --help 熟悉创建ROS2项目的方法
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter$ ros2 pkg create --help
usage: ros2 pkg create [-h] [--package-format {2,3}] [--description DESCRIPTION] [--license LICENSE]
                       [--destination-directory DESTINATION_DIRECTORY] [--build-type {cmake,ament_cmake,ament_python}]
                       [--dependencies DEPENDENCIES [DEPENDENCIES ...]] [--maintainer-email MAINTAINER_EMAIL]
                       [--maintainer-name MAINTAINER_NAME] [--node-name NODE_NAME] [--library-name LIBRARY_NAME]
                       package_name

Create a new ROS 2 package

positional arguments:
  package_name          The package name

options:
  -h, --help            show this help message and exit
  --package-format {2,3}, --package_format {2,3}
                        The package.xml format.
  --description DESCRIPTION
                        The description given in the package.xml
  --license LICENSE     The license attached to this package; this can be an arbitrary string, but a LICENSE file will only
                        be generated if it is one of the supported licenses (pass '?' to get a list)
  --destination-directory DESTINATION_DIRECTORY
                        Directory where to create the package directory
  --build-type {cmake,ament_cmake,ament_python}
                        The build type to process the package with
  --dependencies DEPENDENCIES [DEPENDENCIES ...]
                        list of dependencies
  --maintainer-email MAINTAINER_EMAIL
                        email address of the maintainer of this package
  --maintainer-name MAINTAINER_NAME
                        name of the maintainer of this package
  --node-name NODE_NAME
                        name of the empty executable
  --library-name LIBRARY_NAME
                        name of the empty library

下面对上诉的命令进行简单的介绍:

  • 提示当中的[]的内容表示命令关键字,{}的内容表示可以携带的参数示例,例如创建 --build-type 后面就可以接着 ament_cmake 参数

  • [--destination-directory DESTINATION_DIRECTORY] :ROS2的项目的位置,即在哪里创建你的ROS2项目

  • [--build-type {cmake,ament_cmake,ament_python}] :ROS2编译项目的方式,有cmake ament_camkeament_python三种可选,ament_cmake是基于cmake的一个cmake升级工具, 了解更多的ROS2 ament工具:(https://blog.csdn.net/gongdiwudu/article/details/126192244)

  • [--dependencies] :ROS2项目的依赖项,这部分内容后面可以手动增加,其中常见的rclpy 是 python的节点依赖项,rclcpp是C/C++节点的依赖项,(rcl表示ros2 client

  • [--node-name] :预先设置的ROS2节点名字

  1. 因此可以使用命令:ros2 pkg create <你的项目名字> --build-type <选择cmake/ament_camke/ament_python三者之一作为项目的编译工具> --node-name <节点名称,这一项可以不写,后续手动配置> --dependencies <依赖项名字,例如在ROS1中常用的rclpy rclcpp std_msgs sensor_msgs等>,如:
ros2 pkg create demo --build-type ament_cmake --node-name demo_node --dependencies rclcpp

1.2.3 使用VSCode创建ROS2的C/C++项目

  1. 创建ROS2 C++工程:ros2 pkg create vscodeCppDemo --build-type ament_cmake --node-name vscodeCppDemoNode --dependencies rclcpp std_msgs

  2. 查看工程目录结构:tree . ,可以发现在src目录下 存在了节点名称的cpp文件 ,即ROS2项目已经构建了配置好节点内容的工程

pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ ros2 pkg create vscodeCppDemo --build-type ament_cmake --node-name vscodeCppDemoNode --dependencies rclcpp std_msgs
going to create a new package
package name: vscodeCppDemo
destination directory: /mnt/hgfs/VMware/ROS2_DEMO/1_Chapter/code
package format: 3
version: 0.0.0
description: TODO: Package description
maintainer: ['pldz <pldz@R7000.com>']
licenses: ['TODO: License declaration']
build type: ament_cmake
dependencies: ['rclcpp', 'std_msgs']
node_name: vscodeCppDemoNode
creating folder ./vscodeCppDemo
creating ./vscodeCppDemo/package.xml
creating source and include folder
creating folder ./vscodeCppDemo/src
creating folder ./vscodeCppDemo/include/vscodeCppDemo
creating ./vscodeCppDemo/CMakeLists.txt
creating ./vscodeCppDemo/src/vscodeCppDemoNode.cpp

[WARNING]: Unknown license 'TODO: License declaration'.  This has been set in the package.xml, but no LICENSE file has been created.
It is recommended to use one of the ament license identitifers:
Apache-2.0
BSL-1.0
BSD-2.0
BSD-2-Clause
BSD-3-Clause
GPL-3.0-only
LGPL-3.0-only
MIT
MIT-0

pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ tree .
.
└── vscodeCppDemo
    ├── CMakeLists.txt
    ├── include
    │   └── vscodeCppDemo
    ├── package.xml
    └── src
        └── vscodeCppDemoNode.cpp

4 directories, 3 files
  1. <ROS2工程目录下>/src/<节点cpp>.cpp进行节点编程,ROS2是C++11的编程风格:
#include "rclcpp/rclcpp.hpp"

// 继承ROS2的客户端节点
class VSCodeCppDemo: public rclcpp::Node{
public:
    // ROS2节点的构造函数
    VSCodeCppDemo(const char* nodeName):Node(nodeName){
        RCLCPP_INFO(this->get_logger(),"hello world!");
    }

};

int main(int argc, char *argv[])
{
    rclcpp::init(argc,argv);
    // 生成自定义的ROS2客户端对象, node是一个对象指针
    auto node = std::make_shared<VSCodeCppDemo>("vscodeCppDemoNode");
    rclcpp::shutdown();
    return 0;
}
  1. 针对VSCode的settings.json进行配置:在项目下面新建 .vscode 文件夹,然后在在该文件夹下新建 settings.json , 添加下列内容:
{
    // Settings.json的配置,主要在于添加/opt/ros/humble文件夹下的ros2的include路径
    
    // pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code/.vscode$ tree .
    // .
    // └── settings.json
    // 0 directories, 1 file

    "files.associations": {
        "cstdio": "cpp"
    },
    "C_Cpp.default.includePath": ["/opt/ros/humble/include/**"]
}

在这里插入图片描述

  1. 配置ROS2项目的 package.xml 文件:package.xml 文件是ROS2项目的功能包管理文件,下面添加了一点注释:
<?xml version="1.0"?>
<?xml-model href="http://download.ros.org/schema/package_format3.xsd" schematypens="http://www.w3.org/2001/XMLSchema"?>
<package format="3">
  <name>vscodeCppDemo</name>
  <version>0.0.0</version>
  <description>TODO: Package description</description>
  <!-- 包的作者信息,主要来自Git的配置 -->
  <maintainer email="pldz@R7000.com">pldz</maintainer>
  <license>TODO: License declaration</license>

  <!-- 编译工程的工具 -->
  <buildtool_depend>ament_cmake</buildtool_depend>

  <!-- 编译需要的依赖项,可以手动添加 -->
  <depend>rclcpp</depend>
  <depend>std_msgs</depend>

  <test_depend>ament_lint_auto</test_depend>
  <test_depend>ament_lint_common</test_depend>

  <export>
    <build_type>ament_cmake</build_type>
  </export>
</package>
  1. 配置 CMakeLists.txt 文件:CMakeLists.txt 是ROS2项目的编译配置文件,下面添加了一点注释:
cmake_minimum_required(VERSION 3.8)
project(vscodeCppDemo)

if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang")
  add_compile_options(-Wall -Wextra -Wpedantic)
endif()

# find dependencies, 这里可以引入外部依赖包
find_package(ament_cmake REQUIRED)
find_package(rclcpp REQUIRED)
find_package(std_msgs REQUIRED)

# 节点(也叫可执行文件)的映射
add_executable(vscodeCppDemoNode src/vscodeCppDemoNode.cpp)

# Include文件的位置
target_include_directories(vscodeCppDemoNode PUBLIC
  $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
  $<INSTALL_INTERFACE:include>)

# 目标依赖库
target_compile_features(vscodeCppDemoNode PUBLIC c_std_99 cxx_std_17)  # Require C99 and C++17
ament_target_dependencies(
  vscodeCppDemoNode
  "rclcpp"
  "std_msgs"
)

# 安装规则
install(TARGETS vscodeCppDemoNode
  DESTINATION lib/${PROJECT_NAME})

if(BUILD_TESTING)
  find_package(ament_lint_auto REQUIRED)
  # the following line skips the linter which checks for copyrights
  # comment the line when a copyright and license is added to all source files
  set(ament_cmake_copyright_FOUND TRUE)
  # the following line skips cpplint (only works in a git repo)
  # comment the line when this package is in a git repo and when
  # a copyright and license is added to all source files
  set(ament_cmake_cpplint_FOUND TRUE)
  ament_lint_auto_find_test_dependencies()
endif()

ament_package()

  1. 利用 colcon 工具构建项目:在项目的工程目录下,输入colcon build进行构建
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ colcon build
WARNING: Package name "vscodeCppDemo" does not follow the naming conventions. It should start with a lower case letter and only contain lower case letters, digits, underscores, and dashes.
Starting >>> vscodeCppDemo
--- stderr: vscodeCppDemo                              
WARNING: Package name "vscodeCppDemo" does not follow the naming conventions. It should start with a lower case letter and only contain lower case letters, digits, underscores, and dashes.
---
Finished <<< vscodeCppDemo [8.27s]

Summary: 1 package finished [8.62s]
  1 package had stderr output: vscodeCppDemo
  1. 执行该项目节点文件:
    1. 尝试手动执行,在项目目录下的 build/<ROS2项目名称> 下存放着项目节点 ROS2项目节点,直接运行该文件:如下所示
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ ./build/vscodeCppDemo/vscodeCppDemoNode 
[INFO] [1682264164.879460585] [helloworld_node]: hello world!
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ file ./build/vscodeCppDemo/vscodeCppDemoNode 
./build/vscodeCppDemo/vscodeCppDemoNode: ELF 64-bit LSB pie executable, x86-64, version 1 (GNU/Linux), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=53b5061fab0864a3b53f587b0cbc8a6be1d342f1, for GNU/Linux 3.2.0, not stripped
    1. 通过ROS2运行节点:首先需要添加项目的install环境,即 source <项目目录>/install/setup.bash,然后可以通过ros2 run <项目名称> <节点名称> 运行节点
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ source ./install/setup.bash 
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ ros2 run vscodeCppDemo vscodeCppDemoNode 
[INFO] [1682264459.635230302] [helloworld_node]: hello world!
  1. ROS2的C/C++项目的目录结构:在项目目录下输入tree -L 3 查看最多三级文件结构,其中:
    1. build文件夹:存储编译的文件和可执行的ROS2节点
    1. install文件夹:直接反应叫安装目录,包括能够通过 ros2 run ... 指令运行ROS2节点的环境
    1. log文件夹:存储日志文件
    1. <项目名的文件夹>:存放ROS2项目的源码,其中的 package.xml配置包信息(包名、版本、作者、依赖项);CMakeLists.txt 用于配置编译规则(源文件位置,编译所要连接的依赖项等等);
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ tree -L 3
.
├── build
│   ├── COLCON_IGNORE
│   └── vscodeCppDemo
│       ├── ament_cmake_core
│       ├── ament_cmake_environment_hooks
│       ├── ... 这里手动省略
│       ├── Makefile
│       └── vscodeCppDemoNode
├── install
│   ├── COLCON_IGNORE
│   ├── local_setup.bash
│   ├── ... 这里手动省略
│   ├── setup.bash
│   └── vscodeCppDemo
│       ├── lib
│       └── share
├── log
│   ├── build_2023-04-23_23-31-44
│   │   ├── events.log
│   │   ├── logger_all.log
│   │   └── vscodeCppDemo
│   └── COLCON_IGNORE
└── vscodeCppDemo
    ├── CMakeLists.txt
    ├── include
    │   └── vscodeCppDemo
    ├── package.xml
    └── src
        └── vscodeCppDemoNode.cpp

23 directories, 30 files

1.2.4 使用VSCode创建ROS2的Python项目

  1. 创建ROS2的Python项目:ros2 pkg create vscodePythonDemo --build-type ament_python --dependencies rclpy std_msgs --node-name vscodePythonDemoNode,其中依赖项与C/C++的节点不同是rclpy,此时在项目的同名目录下,已经有了节点.py文件
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ ros2 pkg create vscodePythonDemo --build-type ament_python --dependencies rclpy std_msgs --node-name vscodePythonDemoNode
going to create a new package
package name: vscodePythonDemo
destination directory: /mnt/hgfs/VMware/ROS2_DEMO/1_Chapter/code
package format: 3
version: 0.0.0
description: TODO: Package description
maintainer: ['pldz <pldz@R7000.com>']
licenses: ['TODO: License declaration']
build type: ament_python
dependencies: ['rclpy', 'std_msgs']
node_name: vscodePythonDemoNode
creating folder ./vscodePythonDemo
creating ./vscodePythonDemo/package.xml
creating source folder
creating folder ./vscodePythonDemo/vscodePythonDemo
creating ./vscodePythonDemo/setup.py
creating ./vscodePythonDemo/setup.cfg
creating folder ./vscodePythonDemo/resource
creating ./vscodePythonDemo/resource/vscodePythonDemo
creating ./vscodePythonDemo/vscodePythonDemo/__init__.py
creating folder ./vscodePythonDemo/test
creating ./vscodePythonDemo/test/test_copyright.py
creating ./vscodePythonDemo/test/test_flake8.py
creating ./vscodePythonDemo/test/test_pep257.py
creating ./vscodePythonDemo/vscodePythonDemo/vscodePythonDemoNode.py

[WARNING]: Unknown license 'TODO: License declaration'.  This has been set in the package.xml, but no LICENSE file has been created.
It is recommended to use one of the ament license identitifers:
Apache-2.0
BSL-1.0
BSD-2.0
BSD-2-Clause
BSD-3-Clause
GPL-3.0-only
LGPL-3.0-only
MIT
MIT-0
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ cd vscodePythonDemo/
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code/vscodePythonDemo$ tree .
.
├── package.xml
├── resource
│   └── vscodePythonDemo
├── setup.cfg
├── setup.py
├── test
│   ├── test_copyright.py
│   ├── test_flake8.py
│   └── test_pep257.py
└── vscodePythonDemo
    ├── __init__.py
    └── vscodePythonDemoNode.py

3 directories, 9 files
  1. 创建一个简单的ROS2的Python节点:代码如下,基本内容见注释
import rclpy
from rclpy.node import Node

# 继承Node类,定义VSCodePythonDemo类
class VSCodePythonDemo(Node):
    # 初始化Python构造函数
    def __init__(self, nodeName:str):
        super().__init__(nodeName)
    
    def printHello(self):
        self.get_logger().info("hello world!")

def main():
    rclpy.init()
    # 创建VSCodePythonDemo对象
    node = VSCodePythonDemo("vscodePythonDemo")
    # 调用成员函数
    node.printHello()
    rclpy.shutdown()
  1. Python的VSCode环境配置:默认情况下VSCode的Python解析器,能够定位到rclpy.py的位置在/opt/ros/humble/local/lib/python3.10/dist-packages/下,如果无法找到,可以手动配置.vscode 文件夹下的 settings.json文件,加入"python.analysis.extraPaths": ["/opt/ros/humble/local/lib/python3.10/dist-packages/"],,这样的配置同样能够将自己安装的的Python依赖项加入到vscode的开发环境中

在这里插入图片描述

  1. ROS2的Python项目的简单配置:与C/C++项目不同,Python项目主要配置packages.xml文件来管理依赖项和Python包,setup.py主要给Python项目进行打包配置
    1. packages.xml文件的简单注释:
<?xml version="1.0"?>
<?xml-model href="http://download.ros.org/schema/package_format3.xsd" schematypens="http://www.w3.org/2001/XMLSchema"?>
<package format="3">
  <name>vscodePythonDemo</name>
  <version>0.0.0</version>
  <!-- 包的作者信息,主要来自Git的配置 -->
  <description>TODO: Package description</description>
  <maintainer email="pldz@R7000.com">pldz</maintainer>
  <license>TODO: License declaration</license>
  
  <!-- 编译需要的依赖项,可以手动添加 -->
  <depend>rclpy</depend>
  <depend>std_msgs</depend>

  <test_depend>ament_copyright</test_depend>
  <test_depend>ament_flake8</test_depend>
  <test_depend>ament_pep257</test_depend>
  <test_depend>python3-pytest</test_depend>

  <export>
    <build_type>ament_python</build_type>
  </export>
</package>
    1. setup.py文件的简单注释:
from setuptools import setup

# 项目包名
package_name = 'vscodePythonDemo'

setup(
    name=package_name,
    version='0.0.0',
    packages=[package_name],
    data_files=[
        ('share/ament_index/resource_index/packages',
            ['resource/' + package_name]),
        ('share/' + package_name, ['package.xml']),
    ],
    # 依赖的打包工具
    install_requires=['setuptools'],
    zip_safe=True,
    # 项目用户信息
    maintainer='pldz',
    maintainer_email='pldz@R7000.com',
    description='TODO: Package description',
    license='TODO: License declaration',
    tests_require=['pytest'],
    entry_points={
        'console_scripts': [
            # 可执行文件的入口
            'vscodePythonDemoNode = vscodePythonDemo.vscodePythonDemoNode:main'
        ],
    },
)

  1. 编译ROS2的Python项目:在项目目录下,输入:colcon build,利用ament_python工具构建Python项目
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ colcon build
WARNING: Package name "vscodeCppDemo" does not follow the naming conventions. It should start with a lower case letter and only contain lower case letters, digits, underscores, and dashes.
WARNING: Package name "vscodePythonDemo" does not follow the naming conventions. It should start with a lower case letter and only contain lower case letters, digits, underscores, and dashes.
Starting >>> vscodeCppDemo
Starting >>> vscodePythonDemo
--- stderr: vscodePythonDemo                                                            
/usr/lib/python3/dist-packages/setuptools/command/install.py:34: SetuptoolsDeprecationWarning: setup.py install is deprecated. Use build and pip and other standards-based tools.
  warnings.warn(
---
Finished <<< vscodePythonDemo [1.41s]
Finished <<< vscodeCppDemo [1.79s]                     

Summary: 2 packages finished [2.10s]
  1 package had stderr output: vscodePythonDemo
  1. 运行ROS2的Python项目:.py文件本身就是一个可执行的脚本,如果Python解析器的环境依赖都能够被找到的话,可以直接输入python3 xx.py运行文件,同样通过激活./install/setup.bash文件,利用ROS2运行Python节点
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ python3 ./build/vscodePythonDemo/build/lib/vscodePythonDemo/vscodePythonDemoNode.py 
[INFO] [1682341866.812861345] [helloworld_py_node]: hello world!
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ python3 ./vscodePythonDemo/vscodePythonDemo/vscodePythonDemoNode.py 
[INFO] [1682341890.895240693] [helloworld_py_node]: hello world!
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ ros2 run vscodePythonDemo/ --prefix 
build/             install/           log/               .vscode/           vscodeCppDemo/     vscodePythonDemo/
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ source ./install/setup.bash 
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ ros2 run vscodePythonDemo 
--prefix              vscodePythonDemoNode  
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ ros2 run vscodePythonDemo vscodePythonDemoNode 
[INFO] [1682341946.345360821] [helloworld_py_node]: hello world!
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ 
  1. ROS2的Python项目的简单文件结构:在项目文件夹下输入tree -L 3查看项目三级目录;其中的setup.cfg是功能包基本配置文件,它的作用会影响项目.build文件夹下对Python项目的配置。
pldz@pldz-pc:~/share/ROS2_DEMO/1_Chapter/code$ tree -L 3
.
├── build
│   ├── COLCON_IGNORE
│   ├── vscodeCppDemo
| ... 手动删除了C/C++项目的内容
└── vscodePythonDemo
    ├── package.xml
    ├── resource
    │   └── vscodePythonDemo
    ├── setup.cfg
    ├── setup.py
    ├── test
    │   ├── test_copyright.py
    │   ├── test_flake8.py
    │   └── test_pep257.py
    └── vscodePythonDemo
        ├── __init__.py
        └── vscodePythonDemoNode.py

1.3 ROS2的基本体系

1.3.1 ROS2架构

ROS2的介绍中,有这么一张图,习惯划分说ROS2分为三层来源于B站UP:

在这里插入图片描述

  1. 操作系统层(OS Layer):如前所述,ROS虽然称之为机器人操作系统,但实质只是构建机器人应用程序的软件开发工具包,ROS必须依赖于传统意义的操作系统,目前ROS2可以运行在Linux、Windows、Mac或RTOS上。

  2. 中间层(Middleware Layer):主要由数据分发服务DDS与ROS2封装的关于机器人开发的中间件组成。DDS是一种去中心化的数据通讯方式,ROS2还引入了服务质量管理 (Quality of Service)机制,借助该机制可以保证在某些较差网络环境下也可以具备良好的通讯效果。ROS2中间件则主要由客户端库、DDS抽象层与进程内通讯API构成。

  3. 应用层(Application Layer):是指开发者构建的应用程序,在应用程序中是以功能包为核心的,在功能包中可以包含源码、数据定义、接口等内容。

1.3.2 ROS2和ROS1的区别

老生常谈的一个话题了,总结来说:

  1. 协议不一样:ROS1用的是TCP和UDP协议,而ROS2用DDS协议;DDS是ROS2的一个很重要的概念,DDS是专用总线协议,速度更快更可靠;

  2. 架构不一样,ROS1通过ROS Master管理节点,而ROS2是分布式通讯架构,不需要ROS Master

  3. ROS2支持的平台更多,能够支撑嵌入式开发板,实时操作系统RTOS等平台

1.3.3 ROS2应用方向

  1. Nav2项目:Nav2项目继承自ROS Navigation Stack。该项目旨在可以让移动机器人从A点安全的移动到B点。它也可以应用于涉及机器人导航的其他应用,例如跟随动态点。Nav2将用于实现路径规划、运动控制、动态避障和恢复行为等一系列功能

  2. microROS:在基于ROS的机器人应用中,micro-ROS正在弥合性能有限的微控制器和一般处理器之间的差距。micro-ROS在各种嵌入式硬件上运行,使ROS能直接应用于机器人硬件

1.4 总结和参考内容

1.4.1 总结

  1. 创建ROS2项目的流程:
    1. 创建功能包: ros2 pkg create <项目名> --build-type <cmake/ament_camke/ament_python> --node-name <节点名> --dependencies <rclpy/rclcpp ...>
    1. 编辑源文件:采用继承rcl节点发方式,创建ROS2节点
    1. 编辑配置文件: C/C++ 配置packages.xmlCMakeLists.txt分别进行依赖项管理和编译配置,Python项目配置packages.xmlsetup.py分别进行依赖项和编译安装配置
    1. 编译:安装colcon工具,sudo apt install python3-colcon-common-extensions并且在项目目录下,进行colcon build
    1. 执行:激活项目环境source <项目>/install/setup.bash,然后输入ros2 run <package> <node>

1.4.2 参考内容

    1. 【ROS2原理3】:构建系统“ament_cmake”和构建工具“ament_tools”
    1. ROS2学习笔记(五)-- ROS2命令行操作常用指令总结(一)
    1. Developing a ROS 2 package
    1. C++日志(三十一)类继承时的构造函数
    1. ROS2 API
    1. ROS2中文网
    1. ROS2.0整体架构说明
    1. ROS 2 Design

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

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

相关文章

Samba配置回收站功能

部门确实需要给Samba配置回收站&#xff0c;查阅了下回收站的资料&#xff0c;配置也挺简单的。 配置说明&#xff1a; 在Samba配置回收站功能中各参数作用如下。 (1) vfs object recycle&#xff1a;载入Samba用于回收站功能的模块recycle.so。 (2) recycle:repository /Pr…

企业如何保护外发文件的数据安全?

随着数字化转变&#xff0c;企业的业务文件大多通过电子形式在内外部流转。这增加了外发文件数据泄露或被篡改的风险&#xff0c;如何保护外发文件安全已成为企业不容忽视的课题。 企业外发文件&#xff0c;特别是电子文件&#xff0c;存在一定的数据安全风险&#xff1a; 文件…

第十二章 外观模式

文章目录 前言一、外观模式基本介绍完整代码DVD类爆米花类投影仪类屏幕类立体声类灯光类家庭影院类进行聚合Client测试类 二、 外观模式在MyBatis框架应用的源码分析三、外观模式的注意事项和细节 前言 一、外观模式基本介绍 完整代码 DVD类 package tanchishell.SJMS.faca…

Layui 2.8.0 正式发布,朴实归来

Layui 是一套开源的 Web UI 组件库&#xff0c;采用自身轻量级模块化规范&#xff0c;遵循原生态的 HTML/CSS/JavaScript 开发模式&#xff0c;极易上手&#xff0c;拿来即用。其风格简约轻盈&#xff0c;而内在雅致丰盈&#xff0c;甚至包括文档在内的每一处细节都经过精心雕琢…

On the Efficacy of Knowledge Distillation 解析

paper&#xff1a;On the Efficacy of Knowledge Distillation 本文的题目是《论知识蒸馏的有效性》&#xff0c;主要是对教师模型并不是越大越好这一现象进行研究&#xff0c;并提出了缓解方法&#xff1a;early stop。 Bigger models are not better teachers 知识蒸馏背…

S32k3系列开发学习(FlexCAN)

前言 由于之前没有接触过CAN总线模块&#xff0c;对这一块的知识仍比较陌生&#xff0c;于是乎想简单梳理一下CAN总线的工作流程&#xff0c;加深理解。 一、CAN是什么&#xff1f; 参考&#xff1a;https://zhuanlan.zhihu.com/p/346696648 二、CAN框架 各模块功能如下&am…

NLP基础:标注器Label Studio的入门使用

目录 一、环境准备 二、操作 文章来源&#xff1a; 简介&#xff1a; Label Studio是一个开源的数据标注工具&#xff0c;它可以用于各种机器学习和深度学习项目。它的主要目的是帮助数据科学家和机器学习工程师快速、高效地标注数据&#xff0c;以构建和训练准确的机器学…

Linux入门---开发的Linux命令手册

Linux 基础知识 基础 启动过程&#xff1a; 内核的引导。运行 init。系统初始化。建立终端 。用户登录系统。 命令介绍 磁盘 #文件#a&#xff1a;相当於 -pdr 的意思&#xff0c;至於 pdr 请参考下列说明&#xff1b;(常用)&#xff1b;f&#xff1a;为强制(force)进行&…

Ubuntu20.04使用多卡训练HyperNetwork模型和LoRA模型全流程及疑难问题解决方案

目录 一. LoRA模型多卡训练1.1 安装xformer等库1.2 设置路径1.3 多卡训练 二. LoRA模型多卡训练疑难报错解决方案多卡训练报错 软硬件配置&#xff1a; CPU: AMD 5800 8core 16Thread GPU: NVIDIA RTX 3090 *1 NVIDIA TITAN RTX *1 OS: Ubuntu20.04 一. LoRA模型多卡训练 1.1 …

JavaScript概述四(DOM文档对象模型)

1.DOM(Document Object Model) 会把网页里面的元素当成对象去操作,包含对象的属性,属性值,方便我们去 操作网页。 整个页面最终会形成一个对象 :document ,页面里面的所有的元素(如 标签 ) 最终都会转换成 js 里面的对象。 1.1 获取页面的元素&#xff08;通过选择器&#xff0…

S32K3系列单片机学习

前言 定时器中断&#xff0c;每个平台的实现方式均有差异&#xff0c;从51单片机通过寄存器配置实现定时器周期计数&#xff0c;再到使用HAL库配置STM32的定时器&#xff0c;他们的实现原理都是大同小异的&#xff0c;只不过不同的平台使用的底层库不同&#xff0c;导致实现的…

公司25k招了一个测试员不会自动化,试用期没过就赶走了...

最近翻了一些网站的招聘信息&#xff0c;把一线大厂和大型互联网公司看了个遍&#xff0c;发现市场还是挺火热的&#xff0c;虽说铜三铁四&#xff0c;但是软件测试岗位并没有削减多少&#xff0c;建议大家有空还是多关注和多投简历&#xff0c;不要闭门造车&#xff0c;错过好…

手推FlinkML2.2(一)

Java 快速入门 # 本文档提供了一个关于如何使用Flink ML的快速入门。阅读本文档的用户将被指导提交一个简单的Flink作业&#xff0c;用于训练机器学习模型并提供预测服务。 求助&#xff0c;我卡住了&#xff01;# 如果你遇到困难&#xff0c;请查看社区支持资源。特别是&…

第一个 Servlet 程序

1. 创建项目 使用 IDEA 创建一个 Maven 项目. 1.1、File -> New Project Name:javaservlet2 Location:选择要存放的路径 Language:Java Build system:Maven 点击Create按钮 1.2、Pom.xml引入依赖 依赖包来源&#xff1a; <dependencies> <!-- https…

【Hive实战】探索Hive 2.X以及更早版本的MetaStore

探索Hive 2.X以及更早版本的MetaStore 文章目录 探索Hive 2.X以及更早版本的MetaStore概述配置元数据服务和元数据存储库基础配置参数其他配置参数默认配置配置元服务数据库使用内嵌模式的Derby库使用远程数据存储库 配置元数据服务本地/内嵌服务配置远程服务配置 元数据服务配…

Java Collection源码分析(JDk corretto 11)

文章目录 Collection 系列源码分析 (JDK Amazon corretto 11)Collection接口Iterable接口 子接口 QueueQueue的子接口 Deque双端队列 子接口ListArrayList 实现类序列化与反序列化(后续解决)获取Calss对象的方式 主要有三种&#xff1a;Arrays工具类System类 LinkedList实现类t…

kotlin的let,with,run,apply,also,异同区别

kotlin的let&#xff0c;with&#xff0c;run&#xff0c;apply&#xff0c;also&#xff0c;异同区别 例如&#xff1a; class Person(var name: String, var age: Int) {fun eat() {println("吃饭")}fun work(hour: Int): Int {println("$name $age 工作 $ho…

【论文写作】如何写引言?应该思考什么问题?总体架构!!!

结构 大多数的科技论文都聚焦于简单地说明&#xff0c;做了什么&#xff0c;发现了什么&#xff1f;虽然这个可以帮助你写出一篇研究型论文当中的核心的东西&#xff08;方法论和结果&#xff09;&#xff0c;但是不能完全把引言的部分完成。在这篇文章当中&#xff0c;将展示…

【Python】Python学习笔记(三)条件语句

条件语句 Python中的条件语句与c/cpp基本无异。 if语句 基本结构见以下代码。 Python使用缩进控制if/else语句之间的嵌套关系。 #判断两数是否相等。a int(input(a:)) b int(input(b:))if a b:print(Same) else:print(No Same)elif 代替了cpp中“else if”的写法&#…

数据结构(顺序结构、链式结构、索引结构、散列结构)

文章目录 1.概述2.数据间逻辑关系3.数据的存储结构&#xff08;或物理结构&#xff09;3.1顺序结构3.2链式结构3.3索引结构3.4散列结构 4.运算结构 1.概述 数据结构&#xff0c;就是一种程序设计优化的方法论&#xff0c;研究数据的逻辑结构和物理结构以及它们之间相互关系&am…