第6章 USV局部危险避障系统及综合仿真实验分析

2023-12-04 10:40

本文主要是介绍第6章 USV局部危险避障系统及综合仿真实验分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

水面无人艇局部危险避障算法研究

Local Risk Obstacle Avoidance Algorithm of USV


博主 的硕士毕业论文

第6章 USV局部危险避障系统及综合仿真实验分析

  以上三章分别就三层水面无人艇局部危险避障算法进行了深入研究,并分别在仿真实验平台上进行了验证和讨论。本章将综合考虑三层避障算法,并将三层避障算法合理地结合起来,建立能同时考虑已知静态环境下的全局优化目标(路径短、能耗低等),又能根据传感器信息实时规避未知障碍物的USV局部危险避障系统。之后简要的介绍自行开发的水面无人艇局部危险避障仿真实验平台;然后将在仿真实验平台上建立包含三种障碍物的真实环境,并对USV局部危险避障系统进行综合仿真实验分析。

6.1 USV局部危险避障系统

  本文提出的USV局部危险避障系统(见图6-1所示)基本思路为:以已知静态路径规划算法规划出来的局部静态最优路径为基础和依据向前航行,并不断的感知外界环境,若遇到新的障碍物,则以期望的航向和航速为优化性能指标,进行实时局部危险避障,实现边行进边规避障碍物的实时避障。
  在给定水面无人艇航行任务后,首先由离线的全局路径规划系统指定局部危险避障的子目标段。在无人艇航向过程中,每行进到子目标段的起点,便进入USV局部危险避障系统,并主动获取已知静态障碍物信息;同时进入“基于PSO的已知静态路径规划模块”,由该模块实时解算局部静态最优路径,所以该模块强调的是在较短的时间内得到子目标段内的路径最优化问题,对应的是本论文第三章的研究内容。当该模块求得局部最优路径之后,便已经根据当前环境信息确定了该子目标段的若干子目标点。此时,无人艇便可以朝着每个子目标点行进。
  无人艇在朝向子目标点行进途中,便一直利用自身携带的传感器作为环境反馈装置,实时探测环境信息,对威胁到无人艇行进的障碍物进行快速合理的规避,所以强调的是迅速可靠的产生可行路径。若在子目标点处,无人艇探测到运动状态可知或可预测的障碍物,便进入“基于PSO并融合海事规则的已知动态路径规划模块”,由该模块实时解算出满足海事规则的,最优航速和航向改变量,该模块对应的是本论文第四章的研究内容。在前两个模块的基础上,若无人艇实时探测到运动状态不可知或不可预测的障碍物,此时,无人艇首要任务便是进行快速避障,进入“基于滚动窗口的未知局部危险避障模块”,根据滚动窗口内障碍物所处的危险状态,实时规划出下一控制周期的运动状态,该模块对应的是本论文第五章的研究内容。
这里写图片描述
图6-1 水面无人艇局部危险避障系统

6.2 水面无人艇局部危险避障算法仿真实验平台

  为了可视化验证本文提出的三层水面无人艇局部危险避障算法的可行性,开发了此水面无人艇局部危险避障算法仿真实验平台,主界面如图6-2所示。
这里写图片描述
图6-2 水面无人艇局部危险避障算法仿真实验平台主界面

  该水面无人艇局部危险避障算法仿真实验平台,是在Microsoft Visual C++平台上进行开发的,并利用微软基础类库MFC实现C++的图形化界面。在用户界面上,采用了当今广泛流行使用的Ribbon界面进行设计。
  Ribbon界面最早应用于 Office 2007 中,在后来的Windows系统中,Ribbon界面已广泛的应用到了系统应用以及各种第三方应用中。与传统的菜单式用户界面相比较而言,Ribbon界面具有较多的优势:所有功能有组织的集中存放,无需查找级联菜单和工具栏;更好的组织命令;可以图示显示命令;更加适合触摸屏操作等。
  所以,在进行用户界面设计时,抛弃了传统的菜单式界面,转而采用Ribbon界面进行设计。
  本文开发的仿真实验平台,包括上方的Ribbon功能区(涵盖本仿真实验平台所有功能),中间的主显示绘图区域,绘图区域角落的避障信息显示,以及下方可实时显示绘图区域鼠标指向坐标的状态栏。下面分别对平台各区域做简要的说明。

6.2.1 Ribbon功能区

  Ribbon功能区涵盖了本仿真实验平台所有功能,根据三层避障算法的特点分为三个类别(即选项卡):已知局部危险避障,未知局部危险避障和设置。
  (1)“已知局部危险避障”类别包含了四个面板(见图6-3)。
这里写图片描述
图6-3 仿真实验平台Ribbon界面(1)
  “初始化设置”面板为设置无人艇的起始点和初始速度,对话框见图6-4。
这里写图片描述
图6-4 初始化对话框
  “基于PSO的已知静态避障策略”面板用来进行第一层避障算法的计算。包括静态圆形、静态矩形障碍物的设置,对话框见图6-5(1)(2);粒子群优化算法参数设置,对话框见图6-5(3);以及只进行粒子群优化算法的“计算路径”按钮,只进行路径优化“优化路径”按钮,和“计算并优化”按钮。
这里写图片描述
图6-5 静态已知环境建模及参数设置对话框
  “基于PSO的已知动态避障策略”面板用来进行第二层避障算法的计算。包括动态圆形、动态矩形障碍物的设置,对话框见图6-6(1)(2);粒子群优化算法参数设置,对话框见图6-6(3);进行粒子群优化算法的“计算”按钮;以及可设置显示避障结束点处动态障碍物位置的“动态显示”按钮。
这里写图片描述
图6-6 动态已知环境建模及参数设置对话框
  “数据”面板中的“数据输出”按钮,用来对环境信息和计算信息进行输出,保存计算数据以供分析。
  (2)“未知局部危险避障”类别包含了两个面板(见图6-7)。
这里写图片描述
图6-7 仿真实验平台Ribbon界面(2)
  “环境参数设置-未知”面板用来进行未知圆形、未知矩形障碍物的设置,对话框见图6-8(1)(2)。“基于滚动窗口法的避障策略”面板用来进行第三层避障算法的计算,包括无人艇未知局部危险避障参数设置,对话框见图6-8(3);进行滚动窗口算法计算的“计算”按钮。
这里写图片描述
图6-8 动态已知环境建模及参数设置对话框
  (3)“设置”类别包含了三个面板(见图6-9)。
  “窗口”面板可进行窗口大小的设置,对话框见图6-10;“视图”面板可设置状态栏、标题栏的显示与否;“显示设置”面板可设置主显示绘图区域中视图信息、始末点、路径节点、各个障碍物的显示方式。
这里写图片描述
图6-9 仿真实验平台Ribbon界面(3)

这里写图片描述
图6-10 改变窗口大小对话框

6.2.2 其它区域说明

  (1)中间的主显示绘图区域是用来可视化显示算法避障效果的,包括绘制障碍环境、避障路径、及显示相关参数。
  (2)绘图区域角落为避障信息显示区域。
  右上方的“Scale:1:4”为视图显示的比例尺。
  右下方区域中,“DynamicPSO”代表第二层已知动态路径规划方法中的粒子群优化算法,下方的“Generations”代表迭代次数,“Particle_num”代表粒子数,“WeightV”代表航速改变权值,“WeightDa”代表航向角改变权值。而“StaticPSO”代表第一层已知静态路径规划方法中的粒子群优化算法,下方的“Generations”代表迭代次数,“Particle_num”代表粒子数,“SetV_numMAX”代表调整速度最大次数,“SetInitialV”代表初始化速度值(为2π/ SetInitialV)。
  左下方区域中,“Test_Num”代表自打开程序进行过计算的次数;“ThisPSO_Num”代表在同一组粒子群参数下进行的计算次数;“StaticPSO_BestIndex”代表已知静态路径规划算法最佳代数;“UsedTime(S)”代表计算第一层已知静态路径规划算法的耗时;“UsedTime(D)”代表计算第二层已知动态路径规划算法的耗时;“BestFitness_CalculatePSO”代表计算第一层已知静态路径规划算法不进行路径优化的最优路径长度;“BestFitness_OptimizePath”代表第一层已知静态路径规划算法并进行路径平滑优化处理的最优路径长度;“BestFitness_DynamicPSO”代表经过前两层路径规划算法得到的最优路径长度。
  (3)下方状态栏处可实时显示绘图区域鼠标指向坐标的区域,可方便进行判断,及添加障碍物。

6.3 综合仿真实验及结果分析

  下面将结合前文提出的三层水面无人艇局部危险避障算法,建立较为真实的障碍环境,同时使用三层避障算法进行避障仿真分析。
  水面无人艇在沿全局优化路径行进的途中,不断的在全局优化路径中选取子路径起点和子路径终点,设置子路径段,供局部危险避障算法计算。假设无人艇运行到某海域,由全局路径优化算法指定了本段局部危险避障算法的起点“Start”和终点“Goal”。至此,无人艇便进入了局部危险避障。下面将分步进行描述本段子路径段的局部危险避障。
  首先给出无人艇以及各个算法的初始化设置。子路径段起点“Start”和终点“Goal”之间的距离为4400m。设置无人艇航速为40Kn。在第一层基于PSO的已知静态路径规划中,粒子群优化算法的惯性权重ω采用线型递减策略,且 ωmax=0.95,ωmin=0.2;c1=c2=2;迭代次数100,粒子数50。在第二层基于PSO的已知动态路径规划中,粒子群优化算法的惯性权重ω采用线型递减策略,且ωmax=0.95,ωmin=0.2;c1=c2=2;m1=1,m2=70;设置粒子群迭代次数50,粒子数50。在第三层基于滚动窗口的未知环境下的避障中,滚动窗口半径为800m,控制周期为2s。
  (1) 基于PSO的已知静态路径规划
  在该段路径中存在四个已知静态圆形障碍物(SOC1、SOC2、SOC3、SOC4),和两个已知静态矩形障碍物(SOR1、SOR2),相关参数见表6-1和表6-2,每个粒子共八个维度。经过第一层基于PSO的已知静态路径规划算法的解算,得到最优路径为4491.78m,计算耗时为1.466s,如图6-11所示,规划的路径节点见表6-3所列。
这里写图片描述
图6-11 基于PSO的已知静态路径规划

表 6-1 已知静态圆形障碍物SOC参数

序号极径(m)极角(rad)直径(m)
11000.000.000400
22000.000.000800
32630.596.131200
43492.850.231400

表 6-2 已知静态矩形障碍物SOR参数

序号中心点极径(m)中心点极角(rad)半长(m)半宽(m)方向角(°)
12340.9405.93411220140
23820.9956.17812024200

表 6-3 已知静态路径规划路径节点

路径点极径(m)极角(rad)路径点极径(m)极角(rad)
11000.000.22652630.590.125
22000.000.22663492.850.048
32229.950.18273714.150.034
42455.240.14883930.800.022

  (2) 起点“Start”和“Path1”之间的避障
这里写图片描述
图6-12 “Start”和“Path1”之间的避障

这里写图片描述
图6-13 “Path1”和 “Path2”之间的避障

  如图6-12所示,无人艇在起点“Start”处首先探测到了已知动态矩形障碍物DOR1(上海外高桥18,000箱级集装箱船,相关参数见表6-4),并与无人艇呈252.03°相遇,即夹角在195°和315°之间,为海事规则中的交叉相遇情形,需要从DOR1的后方通过,即无人艇左转向通行。通过第二层基于PSO的已知动态路径规划算法解算,耗时0.094s,得到的避障方法为向左舷转向13.01°,航速不变行进,相关参数见表6-5。无人艇运行到避障结束点后,就已成功完成了对障碍物DOR1的规避,此时便转向朝向本段的子目标点Path1行进。
  
表 6-4 已知动态矩形障碍物DOR1参数

序号中心点极径(m)中心点极角(rad)半长(m)半宽(m)方向角(°)速度(Kn)
1581.3776840.4642002826520

表 6-5 已知动态环境避障路径节点及改变量

路径点航向(°)改变量航速(Kn)改变量极径(m)极角(rad)航速(Kn)解算时间(s)
013.010.00539.770.453400.094

  无人艇从起点“Start”开始行进时,便不断的进行未知障碍物的探测。当无人艇运行到(极径:539.78m,极角:0.453rad)位置时探测到未知动态矩形障碍物UOR1(相关参数见表6-6),此刻开始进行基于滚动窗口的避障。经过判断此时刻无人艇处在潜在危险状态,在下一个周期内不会发生碰撞,如表6-7所列第一周期极角不变,所以继续行进。在第2周期,无人艇处于准危险状态,避障模块做出解算,调整航向。行进到第3周期结束时,UOR1就已完全消失在无人艇的滚动窗口中,无人艇也完成了对UOR1的避障。在第4周期开始转向,从第5周期开始无人艇便沿着到达子目标点“Path1”的方向前进。

表 6-6 未知动态矩形障碍物UOR1参数

序号中心点极径(m)中心点极角(rad)半长(m)半宽(m)方向角(°)速度(Kn)
16000.001203218030

表 6-7 “Start”和“Path1”之间的未知动态避障路径节点

序号极角(rad)序号极角(rad)序号极角(rad)
10.45330.98150.318
20.98140.632————

  (3) “Path1”和“Path2”之间的避障
  无人艇在第一路径点“Path1”处探测到了已知动态矩形障碍物DOR2(上海外高桥18,000箱级集装箱船,相关参数见表6-8),已知动态圆形障碍物DOC1和DOC2(相关参数见表6-9)。经第二层基于PSO的已知动态路径规划算法判断DOC1和DOR2均不会与无人艇相碰,不予进行避障考虑。而DOC2与无人艇呈182.03°相遇,即夹角在165°和195°之间,为海事规则中的正面相遇情形,需要从DOC2的左侧通行,即无人艇左转向通行。通过第二层基于PSO的已知动态路径规划算法解算,耗时0.125s,得到的避障方法为向左舷转向13.01°,航速不变行进。无人艇运行到避障结束点后,就已成功完成了对障碍物DOC2的规避,此时便转向朝向本段的子目标点Path2行进,如图6-1,3所示。

表 6-8 已知动态矩形障碍物DOR2参数

序号中心点极径(m)中心点极角(rad)半长(m)半宽(m)方向角(°)速度(Kn)
11360.005.7932002832017

表 6-9 已知圆形动态障碍物DOC1、DOC2参数

序号极径(m)极角(rad)直径(m)方向角(°)速度(Kn)
11501.470.7292006010
21620.490.2241201955

表 6-10 已知动态环境避障路径节点及改变量

路径点航向(°)改变量航速(Kn)改变量极径(m)极角(rad)航速(Kn)解算时间(s)
09.660.001457.180.280400.125

  (4) “Path5”和“Path6”之间的避障

这里写图片描述
图6-14 各路径点之间的避障
  “Path5”和“Path6”之间的避障如图6-14(1)所示。无人艇在“Path5”处探测到了已知动态矩形障碍物DOR3,通过基于PSO的已知动态路径规划算法解算出“P_AD5”动态路径点。向前运动的途中先后探测到了UOC1和UOC2,并通过基于滚动窗口的避障算法解算出实时规划路径,如途中虚线。相关障碍物参数和路径节点就不再赘述。
  (5) “Path6”和“Path7”之间的避障
  “Path6”和“Path7”之间的避障如图6-14(2)所示。无人艇在“Path6”处探测到了已知动态矩形障碍物DOC3,通过基于PSO的已知动态路径规划算法解算处“P_AD6”动态路径点。
  (6) “Path8”和目标点“Goal”之间的避障
  “Path8”和目标点“Goal”之间的避障如图6-14(3)所示。无人艇在从“Path8”驶向目标点“Goal”途中,探测到了UOC3,并通过基于滚动窗口的避障算法解算出实时规划路径,如途中虚线。

这里写图片描述
图6-15 最终避障示意图

  为了验证本论文提出的水面无人艇三层局部危险避障算法,在仿真平台上建立了包含三种障碍物的综合避障场景。从上述仿真结果和分析中可以得出,在综合避障场景中,本论文提出的避障算法较好的完成了各项避障任务;且该避障算法有效可行、运行速度快,可以很好的满足在线实时避障的要求,使得水面无人艇具备了对真实复杂、具有多种不确定性因素环境的自主适应性。

博主 的硕士毕业论文


===========文档信息============
版权声明:非商用自由转载-保持署名-注明出处
署名(BY) :dkjkls(dkj卡洛斯)
文章出处:http://blog.csdn.net/dkjkls

这篇关于第6章 USV局部危险避障系统及综合仿真实验分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/453165

相关文章

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用

Debian如何查看系统版本? 7种轻松查看Debian版本信息的实用方法

《Debian如何查看系统版本?7种轻松查看Debian版本信息的实用方法》Debian是一个广泛使用的Linux发行版,用户有时需要查看其版本信息以进行系统管理、故障排除或兼容性检查,在Debia... 作为最受欢迎的 linux 发行版之一,Debian 的版本信息在日常使用和系统维护中起着至关重要的作

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re