路径跟踪之导航向量场——二维导航向量场

今天带来一期轨迹跟踪算法的讲解,首先讲解二维平面中的导航向量场[1]。该方法具有轻量化、计算简便、收敛性强等多项优点。该方法根据期望的轨迹函数,计算全局位置的期望飞行向量,将期望飞行向量转为偏光角,输入底层控制器,即可导引被控对象不断跟踪至期望轨迹。该方法适用于非全约束的移动机器人,如固定翼无人机、独轮车、小车(非全向麦克纳姆轮式)、船舶等。对于全约束的移动机器人,如四旋翼无人机、麦克纳姆轮式小车,仅控制前进方向和偏航方向,也是同样可以使用的。

在本期文章中,主要讲解向量场计算方式和使用,机器人根据向量场给出的方向最终会收敛至期望轨迹的相关证明过程可以参考原始论文。

轨迹表达式

考虑以(0,0)为圆心, r = 10 r=10 r=10为半径的期望圆轨迹,有如下轨迹方程:
x 2 + y 2 = 100 x^2+y^2=100 x2+y2=100
对上式等式两边开平方,移到一边,得到如下函数 φ ( x , y ) \varphi(x,y) φ(x,y)
φ ( x , y ) = x 2 + y 2 − 10 \varphi(x,y)=\sqrt{x^2+y^2}-10 φ(x,y)=x2+y2 10
如下图所示,当 φ = c = c o n s t \varphi=c=const φ=c=const时,期望轨迹为一个水平集。设无人机位置坐标为 r ⃗ = ( r x , r y ) \vec{r}=(r_x,\ r_y) r =(rx, ry),当 φ ( r ⃗ ) = 0 \varphi(\vec r)=0 φ(r )=0时,无人机坐标落在期望轨迹水平集上;当 φ ( r ⃗ ) > 0 \varphi(\vec r)>0 φ(r )>0,轨迹在期望轨迹水平集之上;当 φ ( r ⃗ ) < 0 \varphi(\vec r)<0 φ(r )<0,轨迹在期望轨迹水平集之下。因此 φ ( r ⃗ ) \varphi(\vec r) φ(r )的值可以被看作是无人机位置与期望轨迹之间的距离

通常,我们可以在此基础上定义跟踪误差
e = ψ [ φ ( r ⃗ ) ] e=\psi[\varphi(\vec r)] e=ψ[φ(r )]
ψ \psi ψ一阶连续单调递增函数 ψ ( 0 ) = 0 \psi(0)=0 ψ(0)=0 ∀ z ≠ 0 , ψ ( z ) z > 0 \forall z\neq0,\ \psi(z)z>0 z=0, ψ(z)z>0
函数 ψ \psi ψ可以看作为算法的参数,通过选取 ψ \psi ψ ϕ \phi ϕ自由组合,来定义跟踪误差,从而区分轨迹函数 φ ( r ⃗ ) \varphi(\vec r) φ(r ) e e e

导航向量场

下面给出导航向量场的形式
v ⃗ ( r ⃗ ) = τ ⃗ ( r ⃗ ) − k n e ( r ⃗ ) n ⃗ ( r ⃗ ) \vec v(\vec r)=\vec{\tau}(\vec r)-k_ne(\vec r)\vec n(\vec r) v (r )=τ (r )kne(r )n (r )
式中, n ⃗ ( r ⃗ ) \vec n(\vec r) n (r )梯度方向
n ⃗ ( r ⃗ ) = ( ∂ φ ∂ x , ∂ φ ∂ y ) = ( x x 2 + y 2 , y x 2 + y 2 ) \begin{aligned} \vec n(\vec r) &= (\frac{\partial \varphi}{\partial x},\frac{\partial \varphi}{\partial y}) \\ &=(\frac{x}{\sqrt{x^2+y^2}},\frac{y}{\sqrt{x^2+y^2}})\\ \end{aligned} n (r )=(xφ,yφ)=(x2+y2 x,x2+y2 y)
τ ⃗ ( r ⃗ ) \vec{\tau}(\vec r) τ (r )为与 n ⃗ ( r ⃗ ) \vec n(\vec r) n (r )垂直的方向, E E E旋转矩阵 E c w E_{cw} Ecw为顺时针旋转矩阵, E c c w E_{ccw} Eccw为逆时针旋转矩阵
{ τ ⃗ ( r ⃗ ) = E n ⃗ ( r ⃗ ) E c w = [ 0 1 − 1 0 ] E c c w = [ 0 − 1 1 0 ] \begin{cases} \begin{aligned} \vec{\tau}(\vec r)&= E\ \vec{n}(\vec r)\\ E_{cw}&= \begin{bmatrix} 0 & 1 \\ -1 & 0 \end{bmatrix}\\ E_{ccw}&= \begin{bmatrix} 0 & -1 \\ 1 & 0 \end{bmatrix} \end{aligned} \end{cases} τ (r )EcwEccw=E n (r )=[0110]=[0110]
e ( r ⃗ ) e(\vec r) e(r )为误差,这里为了方便起见,令
e ( r ⃗ ) = φ ( r ⃗ ) = x 2 + y 2 − 10 e(\vec r)=\varphi(\vec r)=\sqrt{x^2+y^2}-10 e(r )=φ(r )=x2+y2 10
k n k_n kn为增益,我们暂且令 k n = 1 k_n = 1 kn=1

v ⃗ ( r ⃗ ) = τ ⃗ ( r ⃗ ) − k n e ( r ⃗ ) n ⃗ ( r ⃗ ) \vec v(\vec r)=\vec{\tau}(\vec r)-k_ne(\vec r)\vec n(\vec r) v (r )=τ (r )kne(r )n (r )中, τ ⃗ ( r ⃗ ) \vec{\tau}(\vec r) τ (r )为传播项, − k n e ( r ⃗ ) n ⃗ ( r ⃗ ) -k_ne(\vec r)\vec n(\vec r) kne(r )n (r )为收敛项。 ∣ − k n e ( r ⃗ ) n ⃗ ( r ⃗ ) ∣ |-k_ne(\vec r)\vec n(\vec r)| kne(r )n (r )项越大,产生的向期望轨迹方向的分量越大。 τ ⃗ ( r ⃗ ) \vec{\tau}(\vec r) τ (r )决定了跟踪期望轨迹的方向。

最终将 v ⃗ ( r ⃗ ) \vec v(\vec r) v (r )进行归一化操作

m ⃗ = v ⃗ ∣ ∣ v ⃗ ∣ ∣ \vec m = \frac{\vec v}{||\vec v||} m =∣∣v ∣∣v

∣ ∣ v ⃗ ∣ ∣ ||\vec v|| ∣∣v ∣∣为欧几里得范数(L2范数), m ⃗ \vec m m 即为导航向量场给出的期望飞行方向向量。

向量场结果

我们令增益 k n = 0.2 k_n = 0.2 kn=0.2 k n = 1 k_n = 1 kn=1 k n = 2 k_n = 2 kn=2 k n = 4 k_n = 4 kn=4,跟踪方向为顺时针方向,旋转矩阵为 E = [ 0 , 1 ; − 1 , 0 ] E=[0,1;-1,0] E=[0,1;1,0],绘制出向量场结果图像,可得

令旋转矩阵为逆时针方向,旋转矩阵为 E = [ 0 , − 1 ; 1 , 0 ] E=[0,-1;1,0] E=[0,1;1,0],可得

根据四个不同增益下的导航向量场结果,不难发现, ∣ − k n e ( r ⃗ ) n ⃗ ( r ⃗ ) ∣ |-k_ne(\vec r)\vec n(\vec r)| kne(r )n (r )越大,导航向量场方向往期望轨迹方向偏转越大。在距离期望轨迹较近的情况下,过大的偏转方向可能会产生震荡,但是距离较远的情况下有助于快速收敛至期望轨迹。

向量场使用

根据上面的讲解,对于任意给定的期望轨迹函数式,在全局任何位置,都可以计算得出一个期望飞行向量,将向量做反正切计算,得到期望的飞行航向角。将这个期望航向角,输入至底层控制器,即可导引无人机(或其他类型机器人)飞行收敛至期望轨迹。对于固定翼无人机,不建议直接使用航向角误差作为姿态控制器的偏航输入,建议将航向角误差对滚转做映射函数处理,作为姿态控制器的滚转输入,会有更好的效果。

总结

本期文章介绍了二维导航向量场,其简洁优雅的形式,在很多方面有着比较广泛的适用性,可以自行构建轨迹函数,来实现例如目标追踪、避障、对峙跟踪等功能。

在此留下一个思考题,如有兴趣,请尝试推导出直线 x = 5 x=5 x=5和椭圆轨迹 x 2 9 + y 2 4 \frac{x^2}{9}+\frac{y^2}{4} 9x2+4y2=1的导航向量场形式,尝试绘制导航向量场结果。如果推导出结果,可以尽快与我私信,有精美礼品和源码答疑。数量有限(5个名额),先到先得。

参考文献及链接

[1]KAPITANYUK, Yuri A.; PROSKURNIKOV, Anton V.; CAO, Ming. A guiding vector-field algorithm for path-following control of nonholonomic mobile robots. IEEE Transactions on Control Systems Technology, 2017, 26.4: 1372-1385.

END

迅翼SwiftWing致力于固定翼技术共享,汇聚固定翼领域技术极客,推动固定翼技术持续创新!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/443936.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【STM32单片机_(HAL库)】4-5-3【定时器TIM】【感应开关盖垃圾桶项目】项目实现

1.项目需求 以下几个事件触发时&#xff0c;垃圾桶自动开盖&#xff0c;并伴随蜂鸣器短响一声&#xff0c;同时 LED 灯闪烁一下&#xff0c;2秒后自动关盖&#xff1a; 检测到有人靠近检测到有震动按下按键 KEY1 2.硬件 STM32单片机最小系统震动传感器模块蜂鸣器模块&#…

CentOS 6文件系统

由冯诺依曼在 1945 年提出的计算机五大组成部分&#xff1a;运算器&#xff0c;控制器&#xff0c;存储器&#xff0c;输入设 备&#xff0c;输出设备。 1. 硬盘结构&#xff1a; &#xff08;1&#xff09;机械硬盘结构&#xff1a; 磁盘拆解图&#xff1a; 扇区&#xff0c;…

研发中台拆分之路:深度剖析、心得总结与经验分享

背景在 21 年&#xff0c;中台拆分在 21 年&#xff0c;以下为中台拆分的过程心得&#xff0c;带有一定的主观&#xff0c;偏向于中小团队中台建设参考&#xff08;这里的中小团队指 3-100 人的团队&#xff09;&#xff0c;对于大型团队不太适用&#xff0c;毕竟大型团队人中 …

UGUI(六大UI根基组件)

Rect Transform 各种参数 是显示pos还是width/height 还是left/top/right/bottom之类巴拉巴拉&#xff0c;各种混合的展示baby&#xff0c;都是看anchor的设置 pivot的设置影响具体数值 至于blueprint mode &#xff0c;就是用了之后框框不变&#xff0c;who wanna do thi…

理解PID(零)——什么是PID

PID控制器是一种广泛用于各种工业控制场合的控制器&#xff0c;它结构简单&#xff0c;可以根据工程经验整定参数Kp,Ki,Kd. 虽然现在控制专家提出了很多智能的控制算法&#xff0c;比如神经网络&#xff0c;模糊控制等&#xff0c;但是PID仍然被广泛使用。常见的PID控制器有位置…

开源全文搜索(搜索引擎)

吃水不忘挖井人&#xff0c;介绍Doug Cutting大牛是十分有必要的。 最早&#xff0c;接触到搜索引擎&#xff0c;知道有个Nutch&#xff08;开源搜索引擎&#xff09;&#xff0c;于是开始查看Nutch相关的资料&#xff0c;发现了Nutch的创始人Doug Cutting&#xff0c;随着项目…

初创公司首选HR软件推荐与功能解析

初创企业需HR软件自动化招聘、文书、日常任务及合规管理&#xff0c;提升效率。ZohoPeople是理想选择&#xff0c;性价比高&#xff0c;版本多样&#xff0c;满足不同需求。 1、简化招聘流程 您一直在寻找杰出的人才&#xff0c;以助您的初创企业飞跃发展。您选择的HR软件应该…

Python数字图像处理实战——基于OpenCV实现多种滤波器(附完整代码和结果图)

Python数字图像处理实战——基于OpenCV实现多种滤波器&#xff08;附完整代码和结果图&#xff09; 关于作者 作者&#xff1a;小白熊 作者简介&#xff1a;精通python、matlab、c#语言&#xff0c;擅长机器学习&#xff0c;深度学习&#xff0c;机器视觉&#xff0c;目标检测…

极客兔兔Gee-Cache Day7

protobuf配置&#xff1a; 从 Protobuf Releases 下载最先版本的发布包安装。解压后将解压路径下的 bin 目录 加入到环境变量即可。 如果能正常显示版本&#xff0c;则表示安装成功。 $ protoc --version libprotoc 3.11.2在Golang中使用protobuf&#xff0c;还需要protoc-g…

LSTM时间序列模型实战——预测上证指数走势

LSTM时间序列模型实战——预测上证指数走势 关于作者 作者&#xff1a;小白熊 作者简介&#xff1a;精通python、matlab、c#语言&#xff0c;擅长机器学习&#xff0c;深度学习&#xff0c;机器视觉&#xff0c;目标检测&#xff0c;图像分类&#xff0c;姿态识别&#xff0c;…

影刀RPA实战:Excel排序、替换与格式

1.实战目标 今天继续介绍影刀RPA操作Excel的指令&#xff0c;内容替换&#xff0c;数据排序与单元格格式设置&#xff0c;这几个功能在日常工作中使用率还是比较频繁的。我们可以使用影刀来处理这些重复繁琐的工作。 2.内容替换 我们手动替换内容时 打开Excel文件&#xff1…

鸿蒙进入“无人区”:该如何闯关?

按照华为方面的说法&#xff0c;“打造鸿蒙操作系统是三大战役&#xff0c;目前已经完成了底座和体验两大战役&#xff0c;第三大战役则是生态。”生态固然重要&#xff0c;但要让鸿蒙与当今世界主流操作系统抗衡&#xff0c;乃至成为新一代操作系统中的翘楚&#xff0c;其实还…

上市四天暴涨又暴跌,扫描全能王背后公司坐上“过山车”

股价四天涨五倍&#xff0c;遇到回调跌一半&#xff0c;扫描全能王母公司——合合信息&#xff0c;一上市就坐上了“过山车”。 合合信息其实早在2021年就向科创板申请上市&#xff0c;并在2023年成功过会&#xff0c;但直到9月13日才开启申购&#xff0c;IPO之路一走就是三年…

springboot-网站开发-thymeleaf引擎报错找不到指定的页面模板文件

springboot-网站开发-thymeleaf引擎报错找不到指定的页面模板文件&#xff01; 这种错误的情况&#xff0c;发生&#xff0c;一般都是因为&#xff0c;我们自己的html模板文件&#xff0c;存档位置并不是在默认的templates下面。而是我们自己新建的一个子目录里面。然后&#x…

又被Transformer秀到了!结合小样本学习发A会!

在有限的数据资源下&#xff0c;为了训练出高性能的机器学习模型&#xff0c;我们常会考虑Transformer小样本学习。 这是因为Transformer能从有限的数据中提取更多有用的信息&#xff0c;这样与小样本学习结合&#xff0c;可以更有效的帮助我们提高模型的性能&#xff0c;加速…

Vue84 vue3项目结构分析

打开main.js文件&#xff0c;发现和vue2不同 //引入的不再是Vue构造函数了&#xff0c;引入的是一个名为createApp的工厂函数 import { createApp } from vue import App from ./App.vue//创建应用实例对象——app(类似于之前Vue2中的vm&#xff0c;但app比vm更“轻”) const …

Chrome(谷歌)浏览器 数据JSON格式美化 2024显示插件安装和使用

文章目录 目录 文章目录 安装流程 小结 概要安装流程技术细节小结 概要 没有美化的格式浏览器展示 美化之后效果图 安装流程 下载地址 https://github.com/gildas-lormeau/JSONVue 点击下载 下载成功&#xff0c;如图所示 解压文件 添加成功&#xff0c;如图所示 通过浏览器…

Python测试框架--Allure

严格意义上讲 Allure 不算是测试框架&#xff0c;但是它是生成漂亮测试报告的开源工具&#xff0c;搭配 Pytest 测试框架食用更搭。 也就是说 Allure 是在 Pytest 执行完生成的测试数据的基础上&#xff0c;对测试数据进行处理统计&#xff0c;生成格式统一、美观的测试报告。 …

C语言函数栈帧的创建与销毁(32)

文章目录 前言一、什么是函数栈帧&#xff1f;二、理解函数栈帧能解决什么问题&#xff1f;三、函数栈帧的创建和销毁解析什么是栈&#xff1f;认识相关寄存器和汇编指令 四、解析函数栈帧的创建和销毁预备知识函数的调用堆栈准备环境转到反汇编函数栈帧的创建函数栈帧的销毁 五…

FreeRTOS学习总结

背景&#xff1a;在裸机开发上&#xff0c;有时候我们需要等待某个信号或者需要延迟时&#xff0c;CPU的运算是白白浪费掉了的&#xff0c;CPU的利用率并不高&#xff0c;我们希望当一个函数在等待的时候&#xff0c;可以去执行其他内容&#xff0c;提高CPU的效率&#xff0c;同…