无人驾驶五 使用pure pursuit实现无人车轨迹追踪(python)

https://blog.youkuaiyun.com/adamshan/article/details/80555174

 

# coding=utf-8

import numpy as np
import math
import matplotlib.pyplot as plt

k = 0.1  # 前视距离系数
Lfc = 2.0  # 前视距离
Kp = 1.0  # 速度P控制器系数
dt = 0.1  # 时间间隔,单位:s
L = 2.9  # 车辆轴距,单位:m

class VehicleState:

    def __init__(self, x=0.0, y=0.0, yaw=0.0, v=0.0):
        self.x = x
        self.y = y
        self.yaw = yaw
        self.v = v


def update(state, a, delta):

    state.x = state.x + state.v * math.cos(state.yaw) * dt
    state.y = state.y + state.v * math.sin(state.yaw) * dt
    state.yaw = state.yaw + state.v / L * math.tan(delta) * dt
    state.v = state.v + a * dt

    return state

def PControl(target, current):
    a = Kp * (target - current)

    return a


def pure_pursuit_control(state, cx, cy, pind):

    ind = calc_target_index(state, cx, cy)

    if pind >= ind:
        ind = pind

    if ind < len(cx):
        tx = cx[ind]
        ty = cy[ind]
    else:
        tx = cx[-1]
        ty = cy[-1]
        ind = len(cx) - 1

    alpha = math.atan2(ty - state.y, tx - state.x) - state.yaw

    if state.v < 0:  # back
        alpha = math.pi - alpha

    Lf = k * state.v + Lfc

    delta = math.atan2(2.0 * L * math.sin(alpha) / Lf, 1.0)

    return delta, ind


def calc_target_index(state, cx, cy):
    # 搜索最临近的路点
    dx = [state.x - icx for icx in cx]
    dy = [state.y - icy for icy in cy]
    d = [abs(math.sqrt(idx ** 2 + idy ** 2)) for (idx, idy) in zip(dx, dy)]
    ind = d.index(min(d))
    L = 0.0

    Lf = k * state.v + Lfc

    while Lf > L and (ind + 1) < len(cx):
        dx = cx[ind + 1] - cx[ind]
        dy = cx[ind + 1] - cx[ind]
        L += math.sqrt(dx ** 2 + dy ** 2)
        ind += 1

    return ind


def main():
    #  设置目标路点
    cx = np.arange(0, 50, 1)
    cy = [math.sin(ix / 5.0) * ix / 2.0 for ix in cx]

    target_speed = 10.0 / 3.6  # [m/s]

    T = 100.0  # 最大模拟时间

    # 设置车辆的出事状态
    state = VehicleState(x=-0.0, y=-3.0, yaw=0.0, v=0.0)

    lastIndex = len(cx) - 1
    time = 0.0
    x = [state.x]
    y = [state.y]
    yaw = [state.yaw]
    v = [state.v]
    t = [0.0]
    target_ind = calc_target_index(state, cx, cy)

    while T >= time and lastIndex > target_ind:
        ai = PControl(target_speed, state.v)
        di, target_ind = pure_pursuit_control(state, cx, cy, target_ind)
        state = update(state, ai, di)

        time = time + dt

        x.append(state.x)
        y.append(state.y)
        yaw.append(state.yaw)
        v.append(state.v)
        t.append(time)

        plt.cla()
        plt.plot(cx, cy, ".r", label="course")
        plt.plot(x, y, "-b", label="trajectory")
        plt.plot(cx[target_ind], cy[target_ind], "go", label="target")
        plt.axis("equal")
        plt.grid(True)
        plt.title("Speed[km/h]:" + str(state.v * 3.6)[:4])
        plt.pause(0.001)

if __name__ == '__main__':
    main()

 

无人驾驶路径跟踪算法是指通过一系列路径点来规划和跟踪无人车的运动轨迹。这些路径点包含了空间位置信息、姿态信息、速度、加速度等。路径跟踪的目标是使无人车按照规划好的路径点进行运动,并尽可能准确地跟踪这些路径点。 在路径跟踪算法中,有两种主流的方法:基于几何追踪的方法和基于模型预测的方法。基于几何追踪的方法主要是通过计算车辆与路径点之间的几何关系,来控制车辆的运动。这种方法通常使用预瞄距离来约束车辆的前视范围,并根据转弯大小进行适当的减速。另一种方法是基于模型预测的方法,它使用车辆的动力学模型来预测车辆的未来状态,并根据预测结果进行控制。 在实际应用中,路径跟踪算法还需要考虑一些难点。例如,预瞄距离的选择需要根据具体情况进行调整,较大的前视距离可以使轨迹跟踪更加平滑,而较小的前视距离可以使跟踪更加精确,但容易引起震荡。此外,在拐弯处需要根据转弯大小进行适当的减速,并且需要确定第一个索引点的位置。 路径跟踪算法可以使用不同的编程语言和工具进行实现,如MATLAB、Simulink和Python。这些工具可以帮助开发人员进行算法验证和仿真实验,以确保算法的正确性和性能。 总之,无人驾驶路径跟踪算法是通过一系列路径点来规划和控制无人车的运动轨迹,其中包括基于几何追踪和基于模型预测的方法。在实际应用中,还需要考虑一些难点和具体实现工具。 #### 引用[.reference_title] - *1* [无人驾驶轨迹跟踪之纯轨迹跟踪Pure Pursuit)](https://blog.youkuaiyun.com/weixin_39549161/article/details/88712443)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [无人驾驶车辆控制(三):纯跟踪算法(Pure Pursuit)](https://blog.youkuaiyun.com/yuzistu_优快云/article/details/108684191)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值