2. 天津瀚海蓝帆海洋科技有限公司,天津 300300;
3. 天津科技大学 机械工程学院,天津 300222;
4. 天津市深远海智能移动勘测装备研发重点实验室, 天津 300300
2. Tianjin Hanhai Lanfan Marine Technology Co., Ltd., Tianjin 300300, China;
3. School of Mechanical Engineering, Tianjin University of Science and Technology, Tianjin 300222, China;
4. Tianjin Key Laboratory of Deep-sea Intelligent Mobile Survey Equipment , Tianjin 300300 , China
当前,自主水下航行器(Autonomous Underwater Vehicle, AUV)主要的工作环境为未知海域,即没有详细环境地图的海域,加之水下无线电信号衰减过快,AUV接收不到GPS等无线电波的数据,所以如何实现水下定位就成了当前AUV的主要研究方向之一。由于声波相比于电磁波和无线电波在水下衰减更小,传播距离更远,所以一些声学定位传感器如超短基线、短基线、长基线等是当前主流的AUV外部定位方式[1],但由于这些传感器价格昂贵,所以通常情况下AUV依靠价格相对低廉的内部定位传感器进行自主定位的方式更加受欢迎。内部定位传感器中最重要的是惯性测量单元(IMU)等惯性传感器,但这种传感器会随着运行时长的增加产生较大的累积误差。另外还有使用视觉里程计进行导航[2],但水下较差的光照条件和能见度导致图像难以获得有效信息。
为了解决现有研究存在的问题,卢健等[3]采用基于FastSLAM框架的SLAT算法用于同时定位与跟踪非合作主AUV。郑烨等[4]引入轻量级声呐全连接网络SonarMLP,嵌入声呐参数信息,提高算法鲁棒性。简杰等[5]提出信息增益评价标准的局部信息融合算法,通过阈值加权处理观测数据,进行局部信息滤波和优化以提高定位精度。黄聪等[6]基于双基地声呐定位原理,提出水下目标解算方法,通过数值仿真分析定位误差分布和不同投放距离的探测范围及定位精度。上述方法虽均能实现定位目标,但不能有效适应弱纹理环境,存在轨迹误差较大的问题。
为此,本文设计一套适用于水下机器人前视图像声呐加惯性传感器的滤波里程计。后续将里程计融入图优化框架后进行验证,首先通过公开数据集验证了码头这样的结构性场景中的定位性能,进行初步评估,然后进行实验验证了其定位性能。
1 水下声呐惯性系统定位方法设计 1.1 声呐成像原理声呐通过声波的发射和反射接收的时间差来计算声呐与物体的距离,而图像中亮度的不同则代表了声呐回波强度的不同[7]。设置声呐成像空间是一个半径为
基于声呐成像原理,提取声呐图像特征。由于声呐是声学成像,它的噪声信号强度不固定,受水下声学环境影响较大。恒定虚警率(Constant False Alarm Rate, CFAR)算法作为一种雷达信号处理技术,能稳健的对声呐图像进行特征提取。考虑到计算效果和计算复杂度之间的平衡,在CFAR算法的诸多变体中,本文选择使用最小单元平均CFAR(SOCA-CFAR)作为特征提取算法。声呐图像扇形映射如图1所示。
图1(a)为由电脑获取的原始声呐图像并不是扇形,而是以声呐波束数和距离粒度数为宽高的一个8位的内存深度图(这里使用的声呐输出图像大小为224×512)。对矩形图像进行特征提取,得到特征点云不能实现有效的点云匹配,需将矩形图像中提取的特征映射到实际扇形成像环境中的对应位置才能进行有效的点云匹配。
因此,将矩形特征点云使用声呐的角度分辨率参数
$ \begin{aligned}[b] &\varphi = {\varphi _{\min }} + i \cdot \Delta \varphi,\\ & r = {r_{\min }} + j \cdot \Delta r 。\end{aligned} $ | (1) |
在将矩形点云映射成扇形点云后,也就得到了特征在真实世界中对应的位置,之后进行点云配准就可得到2帧图像之间的位姿变换。
1.3 声呐图像特征匹配前面使用CFAR(恒定虚警率)算法完成了声呐图像的特征提取,并进行映射得到对应真实环境位置的特征点云,下面进行特征点云匹配工作。设
设
$ {\tilde x_s} = \mathop {{{\mathrm{argmax}}} }\limits_{{x_s}} \sum\limits_{{p_s} \in {P_s}} {\varphi r \times d\left( {{p_s}} \right)}。$ | (2) |
式中:
然后,将声呐图像中的特征点作为参考点集和目标点集,利用ICP算法迭代计算参考点集和目标点集之间的最佳转换,使它们尽可能拟合对齐,从而实现声呐图像的特征点匹配。
1.4 基于滤波的声呐惯性里程计在弱纹理条件下,使用匹配结果直接添加匹配因子更新位姿容易受到ICP匹配质量的影响,产生较大的定位误差。受到视觉惯性里程计MSCKF的启发,设计了一种适用于水下环境所使用的声呐惯性滤波里程计,它使用ICP匹配数据和IMU数据维持一个动态窗口进行多个位姿优化估计,减小不稳定的匹配对位姿估计的影响。在计算前先定义坐标系,
1)IMU状态。将状态向量定义为:
$ {X_{{B_k}}} = {\left[ {\begin{array}{*{20}{l}} {p_I^G}&{v_I^G}&\boldsymbol{q_I^G}&{b_{{a_k}}^{}}&{b_{{g_k}}^{}} \end{array}} \right]^{\text{T}}} 。$ | (3) |
式中:
2)EKF状态。状态向量由当前时刻
$ {X_K} = {\left[ {\begin{array}{*{20}{c}} {{X_{{I_k}}}}&{{X_{{S_{k - M}}}}}&{...}&{{X_{{S_{k - 1}}}}} \end{array}} \right]^{\text{T}}}。$ | (4) |
其中,声呐状态定义为:
$ {X_{{S_k}}} = \left[ {\begin{array}{*{20}{c}} {p_S^G}&{q_S^G} \end{array}} \right]。$ | (5) |
式中:
$ {\tilde X_K} = {\left[ {\begin{array}{*{20}{c}} {{{\tilde X}_{{I_k}}}}&{{{\tilde X}_{{S_{k - N}}}}}&{...}&{{{\tilde X}_{{S_{k - 1}}}}} \end{array}} \right]^{\text{T}}}。$ | (6) |
3)状态传播。根据
$ \begin{aligned}[b] &{{\tilde X}_{{I_{{\text{k}} + 1|{\text{k}}}}}} = \boldsymbol{F_{\boldsymbol{I_k}}}{{\tilde X}_{{I_{k|k}}}}{X_{{B_k}}}{X_K} + {n_{{I_k}}},\\ & {n_{{I_k}}} = \left[ {{n_a},{n_g},{n_{{b_a}}},{n_{{b_g}}}} \right]。\end{aligned} $ | (7) |
式中:
$ \boldsymbol{P_{k + 1|k}} = \left[ {\begin{array}{*{20}{c}} {\boldsymbol{P_{I{I_{k + 1|k}}}}}&{\boldsymbol{P_{I{S_{k + 1|k}}}}} \\ {{{\left( {\boldsymbol{P_{I{S_{k + 1|k}}}}} \right)}^T}}&{\boldsymbol{P_{S{S_{k|k}}}}} \end{array}} \right] $ | (8) |
式中:
4)声呐观测模型。由前面的滑动窗口中,ICP匹配结果,可得到相邻2帧的位姿变换
$ {z_k} = {\tilde X_{{I_{{\text{k}} + 1|{\text{k}}}}}}\Delta {T_{ICP,k}} \times {\tilde X_K}{P_{k + 1|k}}。$ | (9) |
式中:
$ h\left( {{X_k}} \right) = \left[ {\begin{array}{*{20}{c}} {{R_{ts}}\left( {{X_k}} \right)} \\ {{t_{ts}}\left( {{X_k}} \right)} \end{array}} \right]。$ | (10) |
式中:
$ {r_k} = {z_k} - h\left( {{X_k}} \right)。$ | (11) |
5)状态更新。
$ K = PH{r_k}{\left( {HP{H^{\mathrm{T}}} + \boldsymbol{R}} \right)^{ - 1}}。$ | (12) |
式中:
$ \begin{gathered} {X_{k|k}} = {X_{k|k - 1}} + K \cdot {r_k},\\ \boldsymbol{P_{k|k}} = \left( {I - {K_k}{H_k}} \right){P_{k|k{\text{ - 1}}}}。\\ \end{gathered} $ | (13) |
本方案包含3种类型的因子,分别为先验因子、滤波里程计因子、ICP关键帧匹配因子。因子图通过下式描述:
$ \begin{aligned}[b] f(\Theta ) = &{f^0}({\Theta _0})\prod\limits_i {{f_i}} ({\Theta _i}){\text{ }} \times \\ & \prod\limits_j {f_j^{ICP}} ({\Theta _j})\left( {{X_{k|k}} + {P_{k|k}}} \right)。\end{aligned} $ | (14) |
式中,
利用开源数据集验证本文方法在港口等结构性场景中的可行性。使用Jinkun Wang团队在美国商船学院港口中使用的BlueROV2数据集进行验证。
2.2 验证结果分析由图2可知,运行的轨迹水平运动范围小于50 m,纵向运动范围小于45 m。场景相对较小,并且由于是港口环境,其纹理特征比较丰富。由图3可知,本文的方案在结构化的港口环境中与真实轨迹之间的均方根误差最大值为1.45 m,最终的均方根误差为0.58 m,数据表明本文方法的定位误差较小能满足定位要求。
经过公开数据集的验证之后,在团队自有淡水湖泊内进行水下实验,对定位性能进行验证。实验结果如图4所示。
由于各个轨迹长度不一,并且都是与GPS真实轨迹进行计算得到,所以将横坐标统一为GPS真实轨迹的累计距离。可以看出,其余2个轨迹相较于真实轨迹的偏差较大,但本文使用滤波里程计参与图优化的轨迹相比于其他轨迹在定位精度上也具有明显优势。
计算轨迹的均方根误差(RMSE)、标准差、最大误差及平均误差,结果如表1和表2所示。
由表1可看出,本文方法轨迹的定位误差在使用均方根误差和标准差2个计算标准下,都明显优于其余2条轨迹。由表2可看出,本文轨迹的最大误差和平均误差也均小于其余2条轨迹。
3 结 语本文提出了一种水下二维定位系统,其核心为声呐惯性滤波里程计,主要针对的是弱纹理的水下场景定位问题。通过将里程计数据与全局初始化ICP匹配数据一起纳入因子图进行优化,提高定位精度。首先使用开源数据集验证了在结构性复杂纹理场景中的适应性和定位精度,然后使用AUV在弱纹理的湖泊进行实验。结果显示在弱纹理的水下环境中,该系统能提高定位精度。
[1] |
肖圳, 薛树强, 韩保民, 等. 参考声速剖面误差对主动式声呐定位影响仿真分析[J]. 地球物理学报, 2023, 66(12): 4889-4899. |
[2] |
郝宇, 邱龙皓, 邹男, 等. 无人平台自主探测声呐的发展现状和展望[J]. 哈尔滨工程大学学报, 2021, 42(9): 1347-1354. |
[3] |
卢健, 陈旭, 刘通, 等. 利用FastSLAM框架的多自治水下航行器同时定位与跟踪算法[J]. 控制理论与应用, 2020, 37(1): 89-97. |
[4] |
郑烨, 崔莉. 基于投影感知的水下声呐目标检测方法[J]. 高技术通讯, 2023, 33(6): 602-609. |
[5] |
简杰, 朱志宇. 基于加权信息增益的并行融合AUV协同定位方法[J]. 中国舰船研究, 2022, 17(4): 79-91. JIAN Jie, ZHU Zhiyu. A Parallel fusion method for AUV cooperative localization based on weighted information gain[J]. Chinese Journal of Ship Research, 2022, 17(4): 79-91. |
[6] |
黄聪, 朱伟锋, 李迪. 基于爆炸声源的远程水下目标定位方法[J]. 中国舰船研究, 2020, 15(6): 176-181. HUANG Cong, ZHU Weifeng, LI Di. Remote localization method for underwater target based on explosive sound sources[J]. Chinese Journal of Ship Research, 2020, 15(6): 176-181. |
[7] |
潘成胜, 毛家林, 杨阳. 基于深度学习的主动声呐目标回波识别研究[J]. 计算机仿真, 2020, 37(11): 179-183+293. |
[8] |
WANG J, CHEN F, HUANG Y, et al. Virtual maps for autonomous exploration of cluttered underwater environments[J]. IEEE Journal of Oceanic Engineering, 2022, 47(4): 916-935. DOI:10.1109/JOE.2022.3153897 |