CASL 根据轮速计算行驶轨迹的曲率

该段代码主要涉及车辆曲率的计算和滤波处理。通过对左右车轮速度的处理,计算车辆行驶的曲率,并通过低通滤波器对结果进行平滑,以减少噪声影响。在车速低于10kph时,不计算曲率。滤波器参数可根据采样周期和截止频率调整,同时处理结果超过阈值时,会根据左右速度差异判断方向。
摘要由CSDN通过智能技术生成
function curveFromWhlSpd (var sigWhlSpdReRiSts,var sigWhlSpdReRiMovDir,var sigWhlSpdReRi,var sigWhlSpdReLeSts,var sigWhlSpdReLeMovDir,var sigWhlSpdReLe)
{
  double WhlSpdReRi_mps;
  double WhlSpdReLe_mps;

  double whlBase=1.672;//m
  
  if (sigWhlSpdReLeSts==0)
  {
    if (sigWhlSpdReLeMovDir ==1)
    {
      WhlSpdReLe_mps=sigWhlSpdReLe/3.6;
    }
    else if(sigWhlSpdReLeMovDir==2)
    {
      WhlSpdReLe_mps=-sigWhlSpdReLe/3.6;
    }
    else
    {
      WhlSpdReLe_mps=0;
    }
  }
  else
  {
    WhlSpdReLe_mps=0;
  }

  if (sigWhlSpdReRiSts==0)
  {
    if (sigWhlSpdReRiMovDir ==1)
    {
      WhlSpdReRi_mps=sigWhlSpdReRi/3.6;
    }
    else if(sigWhlSpdReRiMovDir==2)
    {
      WhlSpdReRi_mps=-sigWhlSpdReRi/3.6;
    }
    else
    {
      WhlSpdReRi_mps=0;
    }
  }
  else
  {
    WhlSpdReRi_mps=0;
  }

  if ((WhlSpdReLe_mps+WhlSpdReRi_mps)*0.5*3.6 <10)
  {
    return 0;//车速小于10kph,不计算曲率
  }

  if (abs(WhlSpdReLe_mps+WhlSpdReRi_mps) < 0.0001)
  {
    return 0;
  }
  else
  {
    //return WhlSpdReRi_mps+WhlSpdReLe_mps;
    return 2*(WhlSpdReRi_mps-WhlSpdReLe_mps)/(WhlSpdReLe_mps+WhlSpdReRi_mps)/whlBase*0.98;
  }
  
}

计算结果可以使用以下函数进行滤波处理:

function LowPassFilterNew_DrvR (var sigDrvRFromWhlSpd)
{
  double LastValue = 0;
  double result = 0;
  double pi = 3.141592653589;
  double deltaT = 0;
  //!
  double fc = 0.2; //cutoff frequency (Grenzfrequenz)
  double alpha = 0;
  Long CallCounter = 0;

  double sigDrvRFromWhlSpd_absValue;

  double lftCnt;
  double rgtCnt;

  sigDrvRFromWhlSpd_absValue = abs(sigDrvRFromWhlSpd);

  CallCounter++;
  if (CallCounter >= 2)
  {
    deltaT = time(sigDrvRFromWhlSpd) - time(sigDrvRFromWhlSpd[-1]);
    alpha = 1/(1/2/pi/deltaT/fc + 1);
    result = alpha * sigDrvRFromWhlSpd_absValue + (1 - alpha) * LastValue;
  }
  else
  {
    cancel;  //No return value
  }

  LastValue = result;

  if (result > 1000)
  {
    if (sigDrvRFromWhlSpd<0)
    {
      lftCnt --;
      rgtCnt ++;
    }
    else
    {
      lftCnt --;
      rgtCnt ++;
    }
  }
  else
  {
    lftCnt = 0;
    rgtCnt = 0;
  }

  lftCnt = min(max(0,lftCnt),15);
  rgtCnt = min(max(0,rgtCnt),15);

  if (result > 750)
  {
    if (lftCnt > rgtCnt)
    {
      return result;
    }
    else
    {
      return -result;
    }
  }
  else
  {
    if (sigDrvRFromWhlSpd < 0)
    {
      return -result;
    }
    else
    {
      return result;
    }
  }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

团圆吧

1 分钱,求鼓励。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值