[详细教程]使用ros编译运行自己写的程序

一、准备

需要在电脑上事先安装好ROS

二、创建工作区间

ROS不同于其他软件,需要在特定的工作区间下通过ros编译运行自己的程序。
假设电脑上已经安装好ROS,则

$ source /opt/ros/noetic/setup.bash
//创建和编译一个 catkin workspace
$ mkdir -p ~/catkin_ws/src
$ cd ~/catkin_ws/
$ catkin_make

在执行完上述操作后,会在~/目录下,生成catkin_ws文件夹,~/catkin_ws/src下有一个CMakeLists.txt。.catkin_workspace是个隐藏文件,在该文件下使用快捷键ctrl+h就可显示/隐藏隐藏文件
在这里插入图片描述

在这里插入图片描述
文件解说:src文件夹存放自己的源码、cmakelist等文件,devel中有.sh文件
程序编译完后,会在devel/lib/xxx中产生可执行文件,为执行可执行文件,source devel/setup.bash(只执行完代码框里的命令,并不会产生可执行文件,需要自己加入)

三、加入自己的代码

法一

适用情况:首次创建工作区间和包
在创建完工作区间后,接下来我们加入自己的代码.
1.在/home/ning/catkin_ws/src路径下打开终端

ning@ning:~/catkin_ws/src$ pwd
/home/ning/catkin_ws/src
ning@ning:~/catkin_ws/src$  catkin_create_pkg test image_transport cv_bridge  //catkin_create_pkg 是创建包的命令 test是包的名称  image_transport cv_bridge 是创建这个包所需要的库
Created file test/package.xml
Created file test/CMakeLists.txt
Successfully created files in /home/ning/catkin_ws/src/test. Please adjust the values in package.xml.

就可以看到/home/ning/catkin_ws/src下有一个新的文件夹test,里面有两个文件cmakelist.txt与package.xml
在这里插入图片描述
在这里插入图片描述
2.将自己的代码复制粘帖到/home/ning/catkin_ws/src/test路径下
在这里插入图片描述
3.修改CMakeLists.txt文件
原本的文件内容很长,删除掉注释精简下来就是

cmake_minimum_required(VERSION 3.0.2)
project(test)
find_package(catkin REQUIRED COMPONENTS
  cv_bridge
  image_transport
)
catkin_package(
)
include_directories(
# include
  ${catkin_INCLUDE_DIRS}
)

我们要对他修改下,修改完之后就变成

cmake_minimum_required(VERSION 3.0.2)
project(test222)
SET(CMAKE_CXX_FLAGS "-std=c++11")
find_package(catkin REQUIRED COMPONENTS
  cv_bridge
  image_transport
)
find_package(catkin REQUIRED COMPONENTS cv_bridge image_transport message_generation sensor_msgs) #此处为编译自己的cpp需要的库
include_directories(
# include
  ${catkin_INCLUDE_DIRS}
)
add_executable(test222 ros_publish_image.cpp) # 加入自己的程序cpp文件
add_dependencies(test222 ${catkin_EXPORTED_TARGETS} )
target_link_libraries(test222 ${catkin_LIBRARIES} ${OpenCV_LIBRARIES})

4.检查修改package.xml文件
使用gedit或者其他的编辑器打开package.xml文件(下面是把注释删掉精简过的),检查一下工程名字是否正确,链接的库是否齐全等

<?xml version="1.0"?>
<package format="2">
  <name>test</name>
  <version>0.0.0</version>
  <description>The test package</description>

  <maintainer email="ning@todo.todo">ning</maintainer>
  <license>TODO</license>

  <buildtool_depend>catkin</buildtool_depend>
  <build_depend>cv_bridge</build_depend>
  <build_depend>image_transport</build_depend>
  <build_export_depend>cv_bridge</build_export_depend>
  <build_export_depend>image_transport</build_export_depend>
  <exec_depend>cv_bridge</exec_depend>
  <exec_depend>image_transport</exec_depend>


  <!-- The export tag contains other, unspecified, tags -->
  <export>
    <!-- Other tools can request additional information be placed here -->

  </export>
</package>

法二

适用情况:已有cmakelist.txt与package.xml文件
1.在/home/ning/catkin_ws/src路径下,创建一个新的文件夹test(这里面的publish也是我自己创建的)
在这里插入图片描述
2.打开test文件,将cmakelist.txt、package.xml、自己的代码cpp文件拷贝进来。
在这里插入图片描述
3.检查修改cmakelist.txt、package.xml文件。注意,工程名不能与已有的包名重复

四、编译

进入~/catkin_ws文件夹,打开终端执行命令catkin_make
在这里插入图片描述
在这里插入图片描述

五、运行

1.新建第一个终端

roscore//如果遇到为找到命令的错误,可以尝试运行source /opt/ros/noetic/setup.bash

2.新建第二个终端

cd ~/catkin_ws
source devel/setup.bash
rosrun 自己的程序包

其他

$rostopic list -v #查看节点

参考资料:

http://wiki.ros.org/cn/ROS/Tutorials/

### 回答1: A*算法是一种常用的搜索算法,用于寻找图形中两点之间的最短路径。ROS(Robot Operating System)是一个用于机器人应用程序开发的开源框架。下面是使用ROS实现A*算法的详细教程。 首先,需要创建一个ROS工作空间,并在该空间下创建一个ROS软件包,命名为"a_star"。然后,在该软件包下创建一个名为"src"的目录,用于存放源代码。 在src目录下,创建一个名为"a_star.cpp"的源文件,用于编A*算法的实现代码。首先,需要引入所需的ROS库和头文件。然后,定义一个ROS节点,并在其中创建一个ROS服务,用于接收开始节点和目标节点的位置信息。 接下来,实现A*算法的核心部分。首先,创建一个包含所有节点的列表,并将开始节点添加到该列表中。然后,创建一个表示每个节点的数据结构,并初始化各个节点的代价(代表从开始节点到该节点的路径长度)和启发式代价(代表从该节点到目标节点的估计路径长度)。 在一个循环中,从列表中选择具有最小代价和启发式代价之和的节点,并将其设置为当前节点。然后,遍历当前节点的所有邻居节点,并计算从开始节点经过当前节点到邻居节点的路径长度。如果新计算的路径长度比邻居节点当前的代价值小,则更新邻居节点的代价值,并将当前节点设置为其父节点。 当目标节点被添加到列表中时,表示搜索完成。此时,从列表中按照父节点关系逆向遍历,即可得到从开始节点到目标节点的最短路径。 最后,编译运行ROS节点。通过调用该节点的服务,将开始节点和目标节点的位置信息传递给A*算法,即可获取最短路径。 总结:以上是使用ROS实现A*算法的详细教程。通过创建ROS软件包,编A*算法的实现代码,并与ROS节点进行交互,可以实现对图形中最短路径的搜索和计算。 ### 回答2: A*算法是一种常用的图搜索算法,常用于路径规划问题。下面是一个关于如何在ROS中实现A*算法的详细教程。 首先,你需要创建一个ROS包,可以使用catkin工具进行创建。在创建的过程中,你需要确保包含所需的依赖项,如roscpp和std_msgs。 接下来,你需要创建一个节点,用于执行A*算法。在节点中,你需要订阅地图数据和起始点与目标点的坐标信息,并在节点中实现A*算法的主要逻辑。 在实现A*算法时,你需要首先创建一个地图数据结构,并使用地图数据进行初始化。地图数据可以是一个二维数组,每个元素代表一个格子,格子可以是一个障碍物或者自由空间。 接着,你需要实现A*算法中的open列表和closed列表,用于存储已经访问过的节点和待访问的节点。算法开始时,将起始点加入open列表。 然后,你需要实现A*算法的循环部分。在循环中,你需要选择open列表中的节点,根据启发函数计算节点的代价,并选择代价最小的节点作为当前节点。然后,你需要将当前节点移动到closed列表,并扩展当前节点的相邻节点。 在扩展节点时,你需要计算相邻节点的代价,并更新其代价和父节点。如果相邻节点不在open列表中,你需要将其加入open列表。如果相邻节点已经在open列表中,并且新的代价更小,你需要更新其代价和父节点。 当目标节点被加入closed列表时,说明路径已经找到。你可以通过回溯父节点,从目标节点到起始节点,得到最佳路径。 最后,你可以将最佳路径发布出去,以便其他节点进行使用。 总结起来,实现A*算法的详细教程包括创建ROS包,实现A*算法的节点,创建地图数据结构,实现open列表和closed列表,实现A*算法的循环部分,以及回溯最佳路径。通过这些步骤,你可以在ROS中成功实现A*算法来解决路径规划问题。 ### 回答3: A*算法是一种常用的寻找最短路径的算法,而ROS作为一个机器人操作系统,可以很方便地实现A*算法来进行路径规划。 首先,需要创建一个ROS的工作空间(catkin workspace),并在src文件夹下创建一个package来进行开发。可以使用catkin_create_pkg命令创建一个新的package,并在package.xml文件中添加依赖关系。 接下来,在src文件夹中创建一个新的源文件,并在该文件中编A*算法的代码。A*算法主要包括两个步骤:路径搜索和路径回溯。 路径搜索是通过优先级队列(或堆)来选择距离起点最近的节点,并计算该节点到终点的估计代价(一般采用曼哈顿距离或欧氏距离)。然后,将该节点的相邻节点加入到优先级队列中,并更新它们的代价和父节点。 路径回溯是从终点开始,根据每个节点的父节点指针,一直回溯到起点,从而得到最优路径。 在ROS中,可以使用std::priority_queue来实现优先级队列。同时,需要定义一个数据结构来表示每个节点,包括节点的坐标、代价、父节点等信息。 为了使算法更加有效和灵活,可以在ROS使用tf库来进行坐标转换和地图表示。还可以通过可视化工具(如rviz)来显示地图和路径,以及进行调试。 最后,在CMakeLists.txt文件中添加编译信息,并运行catkin_make命令进行编译。 通过以上步骤,就可以在ROS中实现A*算法,并且能够在仿真环境或实际机器人上进行路径规划。同时,可以根据具体需求对A*算法进行优化和扩展,以满足更复杂的任务需求。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值