前言

本节教程演示UUV的一些玩法,基于开源项目UUV,官方介绍文档uuvsimulator  https://uuvsimulator.github.io/packages/uuv_simulator/intro/

仿真环境

系统:ubuntu16.04
软件:ROS – kinetic
仿真:gazebo7

安装仿真软件

官网介绍目前支持的版本有三个:kunetic、lunar、melodic

安装命令:

kinetic版本:sudo apt install ros-kinetic-uuv-simulatorlunar版本:sudo apt install ros-lunar-uuv-simulatormelodic版本:sudo apt install ros-melodic-uuv-simulator

如果希望从源码安装的朋友参考这里:

源码安装教程   https://uuvsimulator.github.io/installation/

这里不推荐源码安装,因为看了下github项目的issue中很多人显示安装报错,所以emmm省的折腾。

启动AUV海底世界

启动带海底的世界执行命令:

roslaunch uuv_gazebo_worlds auv_underwater_world.launch

水世界效果图如下(还是很帅的天空的云和海水都是在动的):

启动赫尔库勒斯沉船的世界执行命令:

roslaunch uuv_gazebo_worlds herkules_ship_wreck.launch

启动湖泊

roslaunch uuv_gazebo_worlds lake.launch

其他的一些场景

roslaunch uuv_gazebo_worlds mangalia.launchroslaunch uuv_gazebo_worlds munkholmen.launchroslaunch uuv_gazebo_worlds ocean_waves.launch

!注意这里的海浪都只是视觉效果不会将波浪的载荷加载在水下机器人上

水下机器人运动控制

启动环境和水下机器人pid控制

执行命令:

roslaunch uuv_gazebo start_pid_demo_with_teleop.launch
这里机器人的速度控制还是经典的cmd_vel话题,我们可以自己创建速度控制脚本teletop.py:
#!/usr/bin/env pythonimport rospyfrom geometry_msgs.msg import Twistimport sys, select, osif os.name == 'nt':  import msvcrtelse:  import tty, termiosFETCH_MAX_LIN_VEL = 5FETCH_MAX_ANG_VEL = 2.84LIN_VEL_STEP_SIZE = 0.01ANG_VEL_STEP_SIZE = 0.1msg = """Control Your Robot!---------------------------Moving around:        w   a    s    d        x"""e = """Communications Failed"""def getKey():    if os.name == 'nt':      return msvcrt.getch()    tty.setraw(sys.stdin.fileno())    rlist, _, _ = select.select([sys.stdin], [], [], 0.1)    if rlist:        key = sys.stdin.read(1)    else:        key = ''    termios.tcsetattr(sys.stdin, termios.TCSADRAIN, settings)    return keydef vels(target_linear_vel, target_angular_vel):    return "currently:\tlinear vel %s\t angular vel %s " % (target_linear_vel,target_angular_vel)def makeSimpleProfile(output, input, slop):    if input > output:        output = min( input, output + slop )    elif input < output:        output = max( input, output - slop )    else:        output = input    return outputdef constrain(input, low, high):    if input < low:      input = low    elif input > high:      input = high    else:      input = input    return inputdef checkLinearLimitVelocity(vel):    vel = constrain(vel, -FETCH_MAX_LIN_VEL, FETCH_MAX_LIN_VEL)    return veldef checkAngularLimitVelocity(vel):    vel = constrain(vel, -FETCH_MAX_ANG_VEL, FETCH_MAX_ANG_VEL)    return velif __name__=="__main__":    if os.name != 'nt':        settings = termios.tcgetattr(sys.stdin)    rospy.init_node('fetch_teleop')    pub = rospy.Publisher('/rexrov/cmd_vel', Twist, queue_size=10)    status = 0    target_linear_vel   = 0.0    target_angular_vel  = 0.0    control_linear_vel  = 0.0    control_angular_vel = 0.0    try:        print(msg)        while(1):            key = getKey()            if key == 'w' :                target_linear_vel = checkLinearLimitVelocity(target_linear_vel + LIN_VEL_STEP_SIZE)                status = status + 1                print(vels(target_linear_vel,target_angular_vel))            elif key == 'x' :                target_linear_vel = checkLinearLimitVelocity(target_linear_vel - LIN_VEL_STEP_SIZE)                status = status + 1                print(vels(target_linear_vel,target_angular_vel))            elif key == 'a' :                target_angular_vel = checkAngularLimitVelocity(target_angular_vel + ANG_VEL_STEP_SIZE)                status = status + 1                print(vels(target_linear_vel,target_angular_vel))            elif key == 'd' :                target_angular_vel = checkAngularLimitVelocity(target_angular_vel - ANG_VEL_STEP_SIZE)                status = status + 1                print(vels(target_linear_vel,target_angular_vel))            elif key == ' ' or key == 's' :                target_linear_vel   = 0.0                control_linear_vel  = 0.0                target_angular_vel  = 0.0                control_angular_vel = 0.0                print(vels(target_linear_vel, target_angular_vel))            else:                if (key == '\x03'):                    break            if status == 20 :                print(msg)                status = 0            twist = Twist()            control_linear_vel = makeSimpleProfile(control_linear_vel, target_linear_vel, (LIN_VEL_STEP_SIZE/2.0))            twist.linear.x = control_linear_vel; twist.linear.y = 0.0; twist.linear.z = 0.0            control_angular_vel = makeSimpleProfile(control_angular_vel, target_angular_vel, (ANG_VEL_STEP_SIZE/2.0))            twist.angular.x = 0.0; twist.angular.y = 0.0; twist.angular.z = control_angular_vel            pub.publish(twist)    except:        print(e)    finally:        twist = Twist()        twist.linear.x = 0.0; twist.linear.y = 0.0; twist.linear.z = 0.0        twist.angular.x = 0.0; twist.angular.y = 0.0; twist.angular.z = 0.0        pub.publish(twist)    if os.name != 'nt':        termios.tcsetattr(sys.stdin, termios.TCSADRAIN, settings)

运行脚本就可以控制船运动了:

python teletop.py
生成螺旋线控制水下机器人运动

执行命令启动pid控制和环境:

roslaunch uuv_gazebo start_pid_demo_with_teleop.launch

生成螺旋线并巡线(这里我生成的是2股螺旋线):

roslaunch uuv_control_utils start_helical_trajectory.launch uuv_name:=rexrov n_turns:=2

发布一组导航点导航执行命令启动pid控制和环境:

roslaunch uuv_gazebo start_pid_demo_with_teleop.launch

执行命令生成直线路径:

roslaunch uuv_control_utils send_waypoints_file.launch uuv_name:=rexrov interpolator:=linear

机器人路径根据贝塞尔曲线原理生成,可以保证轨迹上的点速度方向是连续的,并且规定路径点生成的整条路径是必过路径点的。

小编这里写了个二维三阶贝赛尔曲线的路径生成的代码:https://github.com/xmy0916/bezier大家可以参考参考!

执行命令生成三维贝赛尔曲线路径:

roslaunch uuv_control_utils send_waypoints_file.launch uuv_name:=rexrov interpolator:=cubic

更多操作参考:项目官方文档  https://uuvsimulator.github.io/packages/uuv_simulator/intro/项目github地址https://github.com/uuvsimulator/

古月居原创作者签约计划已开启,网站(guyuehome.com)已上线【投稿】功能,欢迎大家积极投稿,原创优质文章作者将有机会成为古月居签约作者。

安装gazebo_手把手教你用Gazebo仿真UUV水下机器人相关推荐

  1. Gazebo仿真UUV水下机器人

    最近准备学习一下ros,gazebo和一个水下rov模拟器. uuv_simulator(https://github.com/uuvsimulator/uuv_simulator)是一个非常优秀的基 ...

  2. 【转载】用Gazebo仿真UUV水下机器人(古月居)

    前言 教程演示UUV的一些玩法,基于开源项目UUV,官方介绍文档:官网 仿真环境 系统:ubuntu16.04 软件:ROS – kinetic 仿真:gazebo7.16 安装仿真软件 官网介绍目前 ...

  3. 【CCS仿真系列教程】手把手教你纯软件仿真实现音频滤波

    [CCS仿真系列教程]手把手教你纯软件仿真实现音频滤波 事先说明 示例项目下载 示例使用说明 首先用Matlab生成加了噪声的音频 将我的项目弄你的CCS的WorkSpace中 把Matlab生成后的 ...

  4. 2021win11最新最全MySQL下载安装教程——手把手教你安装MySQL

    2021win11最新最全MySQL下载安装教程--手把手教你安装MySQL 最近重装了win11,给我MySQL整没了,故今天重新装一下. 第一步,进入官网 https://www.mysql.co ...

  5. centos7 nginx安装_手把手教你PHP(一) Centos7上的LEMP配置

    相信有些刚刚接触web开发的小伙伴对于服务器上搭建web环境还不太了解,今天手把手教大家搭建lemp的线上环境,您需要做如下一些准备: 阿里云或者其他服务商的云主机一台 云主机已安装Centos 7 ...

  6. 服务器系统2022安装wsl2,手把手教你踩坑:老白的Docker for Windows安装初探WSL 2 backend...

    手把手教你踩坑:老白的Docker for Windows安装初探WSL 2 backend 2020-06-16 13:29:47 15点赞 63收藏 4评论 创作立场声明:老白的踩坑记录 嗨,大家 ...

  7. 在linux下怎么安装mysql,手把手教你在Linux系统下安装MySQL

    在CentOS中默认安装有MariaDB,这个是MySQL的分支,但为了需要,还是要在系统中安装MySQL,而且安装完成之后可以直接覆盖掉MariaDB. 1. 下载并安装MySQL官方的 Yum R ...

  8. 机器人新车号牌安装_手把手教你打造智能小车(0)-写在前面的话

    每个男孩都有一个机器人的梦,这个梦也许就是从第一次玩遥控汽车玩具开始的.只是那时的男孩还不能够明白,神奇的小车为什么能够按照自己的指令行动,随着知识的增长,他开始明白了一个叫做电磁波的东西传递这其中的 ...

  9. 石头机器人拖地水量调节_宅小秘课堂:手把手教你如何用好石头扫地机器人T6...

    [CNMO评测]从上架众筹到如今,石头扫地机器人T6已经亮相有一段时间,宅小秘作为提前拿到产品的科技编辑(嘚瑟的插会腰),在这期间里,将石头扫地机器人T6作为家中清扫的主力机.随着众筹结束以及各大平台 ...

最新文章

  1. unity2018关联不到vs_律道|蓝月传奇VS烈焰武尊:角色扮演类游戏独创性如何认定?...
  2. wxpython多个面板_wxpython:隐藏其中一个拆分窗口面板
  3. NeurIPS 2021 | 微软研究院提出CLUES,用于NLU的少样本学习评估
  4. ubuntu下的各种环境变量
  5. 如何解决无法显示隐藏文件文件夹
  6. PDE14 heat equation intuition
  7. 网络爬虫之Xpath用法汇总
  8. Windows 10部署与管理指南(1)之环境准备篇
  9. 新浪博客中特殊字符不显示的问题
  10. php++redius,【答疑】edius中快进播放的快捷键是什么啊? - 羽兔网问答
  11. 单片机内部FLASH的字节操作
  12. tplogin怎么创建虚拟服务器,TP-Link路由器作为二级路由器用的设置方法
  13. C#中新建用户控件示例
  14. RGB颜色值与十六进制颜色码对照表
  15. Vue.js 使用cordova camera插件调取相机
  16. 第三方登陆实践之基于OAuth的FACEBOOK Web Login(最新版)
  17. 【大学物理实验】用霍尔传感器测通电螺线管的磁场分布
  18. ARM惹众怒,美国芯片行业也开始抛弃它,跟随中国芯片支持新架构
  19. 【Python】Python中字符串格式化实现整数前面自动补0
  20. MIUI10设置Android通知,Miui10状态栏美化修改工具

热门文章

  1. MPEG1 Audio介绍
  2. [转]showModalDialog()、showModelessDialog()方法使用详解
  3. PIE SDK影像坏线修复
  4. Dagger2 + MVP示例
  5. 1、python的基础
  6. python 安装 pip,setuptools
  7. Lfie has sweet
  8. 【数据结构】顺序栈与链表栈
  9. python按键盘上哪个键运行_pythonshell哪个键执行命令
  10. 没有维护在库存管理中用于工厂1112的参数