路径跟踪算法---Pure Pursuit实现


前言

Pure Pursuit是一种基于几何追踪的路径跟踪算法,使车辆或者机器人沿着预定轨迹进行运动,控制方法简单,无需过多考虑运动学和动力学模型,广泛应用于车辆和移动机器人领域,实现路径跟踪。


一、Pure Pursuit原理介绍

网上已有很多介绍Pure Pursuit算法原理的文章,读者可以自行了解,本节也给出简单的原理介绍,仅作为参考。
Pure Pursuit算法提出“预瞄点”的概念,通过计算角速度控制机器人从当前位置移动到机器人前方预瞄点,当前位置到预瞄点的距离称为预瞄距离。
在这里插入图片描述
如图所示,θ 为机器人转向角,L表示机器人的轴距,R为转向半径,Ld代表预瞄距离,也叫前视距离,α为机器后轴与目标点g连成的向量 与车偏航角之间的夹角。

  t a n θ = L / R = L ∗ K   θ = t a n − 1 ( L / R ) = t a n − 1 L ∗ K \ tanθ = L / R = L * K \\\ \\ θ = tan^{-1} (L/R) = tan^{-1} L*K  tanθ=L/R=LK θ=tan1(L/R)=tan1LK
K代表曲率。
根据正弦定理:
  L d / s i n ( 2 α ) = R / s i n ( Π / 2 − α )   L d / 2 s i n α c o s α = R / c o s α   L d / s i n α = 2 R \ Ld/sin(2α) = R/ sin(Π/2 - α) \\\ \\ Ld / 2sinαcosα = R / cosα \\\ \\ Ld / sinα = 2R  Ld/sin(2α)=R/sin(Π/2α) Ld/2sinαcosα=R/cosα Ld/sinα=2R

可计算出曲率K以及机器人转角θ:
  K = 1 / R = 2 s i n α / L d   θ = t a n − 1 L ∗ 2 s i n α / L d \ K = 1 / R = 2sinα/Ld \\\ \\ θ = tan^{-1} L * 2sinα/Ld  K=1/R=2sinα/Ld θ=tan1L2sinα/Ld

二、代码实现

   思路 :通过计算机器人当前位置与目标轨迹的距离,从而找到轨迹上距机器人最小距离目标点的索引,从最小距离的索引开始遍历路径点和预瞄点的距离,若该距离大于预瞄距离,计算机器人当前位置和该路径点的距离和夹角,发布运动控制指令。

根据自己的机器人,定义预瞄距离和轴距

#define PREVIEW_DIS 0.8  //预瞄距离
#define Ld 0.35  //轴距

定义容器,将所有路径点和机器人当前位置的距离保存到容器

std::vector<double> bestPoints_;
    for(int i = 0; i<r_x_.size(); i++)
    {
        float path_x = r_x_[i];
        float path_y = r_y_[i];
        // 遍历所有路径点和当前位置的距离,保存到容器中
        float lad = sqrt(pow(path_x - currentPositionX, 2) +
                        pow(path_y - currentPositionY, 2));
        bestPoints_.push_back(lad);
    }  

查找最小距离以及该距离对应路径点的索引

 //找到数组中最小距离
 auto smallest = min_element(bestPoints_.begin(), bestPoints_.end());
 //找到最小距离的索引
 int index = distance(bestPoints_.begin(),smallest); 

从最小距离的索引开始,遍历之后的路径点与预瞄点的距离,距离比实际预瞄距离大,获取索引
注意考虑到速度的缘故,实际预瞄距离和定义的预瞄距离不符

 int temp_index = 0;    
 //从最小距离的位置开始,遍历路径点 到 实际前视距离的距离
 for(int i = index ; i<r_x_.size(); i++)
 {
     float dis = sqrt(pow(r_y_[index] - r_y_[i], 2) + pow(r_x_[index] - r_x_[i], 2));
     if(dis < preview_dis)
     {
         temp_index = i;
     }
     else
         break;
 }
 index = temp_index;

计算前一步获取索引点与机器人当前位置的距离Ld和偏转角α,进一步求取θ,作为机器人角速度发布。

 float alpha = atan2(r_y_[index] - currentPositionY, r_x_[index] - currentPositionX) - calRPY_[2];
  // 当前点和目标点的距离dl
  float dl = sqrt(pow(r_y_[index] - currentPositionY, 2) +
                  pow(r_x_[index] - currentPositionX, 2));
  // 发布小车运动指令及运动轨迹
  if( dl>0.05 )
  {
      float theta = atan(2 * Ld * sin(alpha) / dl);
      cmdVelPub(0.5,theta); 
   }

效果

放一张效果图,纯路径跟踪算法转弯处会偏离设定的路径,效果不如pid算法好,当然也可能和设计的预瞄距离大小有关。

在这里插入图片描述

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【资源说明】 基于Matlab实现跟踪(Pure Pursuit)算法源码+项目说明.zip 基于Matlab实现跟踪(Pure Pursuit)算法 在参考资料1的基础上修正部分错误,优化代码,演示纯跟踪算法。 ![图片](./imgs/1.png) ## 纯跟踪算法本质 参考人类驾驶员的行为,以车的后轴为基点,通过控制前轮的偏角delta,使车辆沿一条经过预瞄点的**圆弧**行驶,跟踪效果将由ld决定,如何设计ld也是算法的改进方向之一。 预瞄点的引入使得控制更加平顺,普通PID控制跟踪的是离车辆最近的轨迹点,而纯跟踪跟踪的是预瞄点。 纯跟踪本质是一个**P控制器**,对车辆进行**横向控制**,代码示例中的横向误差如图所示: ![横向误差](./imgs/2.png) 可见横向误差不收敛于0,即横向控制存在静态误差,加入积分控制后,横向误差如图所示: ![横向误差](./imgs/3.png) (加入积分控制,静态误差减小,超调量增大,为减小超调量,可引入微分控制) 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值