ROS2教程turtlebot3仿真

安装turtlebot3

首先需要安装Gazebo turtlebot3

sudo apt-get install ros-foxy-gazebo-*
sudo apt install ros-foxy-turtlebot3
sudo apt install ros-foxy-turtlebot3-simulations

添加环境变量

vim ~/.bashrc

export TURTLEBOT3_MODEL=burger

启动仿真环境

ros2 launch turtlebot3_gazebo turtlebot3_world.launch.py

在这里插入图片描述

绘图

打开rviz准备绘图

ros2 launch turtlebot3_cartographer cartographer.launch.py use_sim_time:=True

在这里插入图片描述

打开键盘绘制节点控制机器人移动绘制地图

 ros2 run turtlebot3_teleop teleop_keyboard

在这里插入图片描述
保存建好的地图

ros2 run nav2_map_server map_saver_cli -f ~/ROS2/map/tutorial

关闭所有窗口后执行下面命令

导航

打开下面launch文件

ros2 launch turtlebot3_gazebo turtlebot3_world.launch.py

ros2 launch turtlebot3_navigation2 navigation2.launch.py use_sim_time:=true 

在rviz 在其上方工具栏中有2D Pose estimate,用来设置大概的初始点
通过RViz中的navigation2 goal按钮,发送一个目标位置。然后自动规划路线到达目的的
在这里插入图片描述

简单的自动避障

通过订阅/scan话题获取正前方的距离与发布/cmd_vel话题的速度控制可以实现一个简单的避障功能,距离前方距离小于1m停止前进并转动,就这样一直循环下去就可以避障了,但是

import rclpy
from rclpy.node import Node
from sensor_msgs.msg import LaserScan
from geometry_msgs.msg import Twist
import time

class AvoidOb(Node):
    def __init__(self):
        self.disp = 0

        super().__init__("avoid_node")
        self.subLidar = self.create_subscription(
            LaserScan,
            'scan',
            self.listener_callback,
            10
        )
        self.pubVel = self.create_publisher(
            Twist,
            'cmd_vel',
            10
        )
        self.time = self.create_timer(1,self.time_callback)

    def time_callback(self):
        vel = Twist()

        if self.disp < 1:
            vel.angular.z = 0.3
        else:
            vel.linear.x = 0.3
        self.pubVel.publish(vel)

        self.get_logger().info(f'disp:{self.disp},send vel: {vel.linear.x},{vel.angular.z}')

    def listener_callback(self,msg):
        self.disp = msg.ranges[0]
      

def main(args=None):
    rclpy.init(args=args)
    fun = AvoidOb()
    rclpy.spin(fun)
    fun.destroy_node()
    rclpy.shutdown()

if __name__ == '__main__':
    main()

在这里插入图片描述

航向锁定

通过订阅/imu话题可以获取机器人的角度信息,再通过发布cmd_vel话题控制机器人的航向
安装四元数转换工具

sudo apt install ros-foxy-tf-transformations
sudo pip3 install transforms3d
import rclpy
from rclpy.node import Node
from sensor_msgs.msg import Imu
from geometry_msgs.msg import Twist
from tf_transformations import euler_from_quaternion
import math

class AvoidOb(Node):
    def __init__(self):
        self.target_yaw = 45

        super().__init__("imu_node")
        self.subLidar = self.create_subscription(
            Imu,
            'imu',
            self.listener_callback,
            10
        )
        self.pubVel = self.create_publisher(
            Twist,
            'cmd_vel',
            10
        )

    def listener_callback(self,msg):
        if msg.orientation_covariance[0] < 0:
            return
        quaternion = [
            msg.orientation.x,
            msg.orientation.y,
            msg.orientation.z,
            msg.orientation.w,
        ]
        [pitch,row,yaw] = euler_from_quaternion(quaternion)
        pitch = pitch*180/math.pi
        row = row*180/math.pi
        yaw = yaw*180/math.pi

        diff = self.target_yaw - yaw 
        vel_cmd = Twist()
        vel_cmd.angular.z = diff * 0.01
        self.pubVel.publish(vel_cmd)

        self.get_logger().info(f'pitch:{pitch},row:{row},yaw:{yaw}. angularZ:{vel_cmd.angular.z}')

def main(args=None):
    rclpy.init(args=args)
    fun = AvoidOb()
    rclpy.spin(fun)
    fun.destroy_node()
    rclpy.shutdown()

if __name__ == '__main__':
    main()

运行代码机器人将转动45度并固定角度
在这里插入图片描述

  • 12
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值