(八)锥桶赛道路径规划

2023-10-18 00:30
文章标签 规划 路径 赛道 锥桶

本文主要是介绍(八)锥桶赛道路径规划,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、参考资料

  1. 三角剖分:https://blogs.mathworks.com/student-lounge/2022/10/03/path-planning-for-formula-student-driverless-cars-using-delaunay-triangulation/

  1. 贝塞尔曲线https://muzing.top/posts/6610880/

2、任务需求

在赛道进行路径规划,赛道两侧分别是红蓝锥桶,这里采用的参考资料2中的算法。

  1. PanoSim仿真中采用「目标级雷达」,直接返回目标相对于自己的相对位置,但是相机下的位置不是真实世界下的位置

  1. 同样的我们也缺乏真实的路宽,在一侧没有的时候不能移动d/2

因此如果建立在拥有真实的坐标基础上,同时车身自带定位与建图的情况下,可以直接套用算法,目前采用的方案仅仅针对两侧都有锥桶,通过分别计算两侧贝塞尔曲线然后相加。

3、测试思路

原作者文档中解释非常清楚,这里仅仅做一些小小改动

3.1 贝塞尔曲线

    red = get_traffic_cone_matrix(np.array(test_data[i]), 3)  # 左侧锥桶位置矩阵blue = get_traffic_cone_matrix(np.array(test_data[i]), 2)  # 右侧锥桶位置矩阵red_bezier = get_bezier_curve(red,25)blue_bezier = get_bezier_curve(blue, 25)#local_path = local_path_fitting(red, blue, translation_dis=1.5)  # 规划出的局部路径矩阵# 左上角为原点plt.xlim(0, 1920)plt.ylim(0, 1080)plt.gca().invert_yaxis()plt.plot(red[:, 0], red[:, 1], "o-", color="r")plt.plot(blue[:, 0], blue[:, 1], "o-", color="b")#plt.plot(local_path[:, 1] * -1, local_path[:, 0], color="k", linestyle="--")x = (red_bezier + blue_bezier[::-1])/2

这里采用了,左右两侧分别计算25个点的平均值,可以理解为中线。由于锥桶的顺序至关重要,原作者做了x方向排序,我们相加的取平均的的时候需要对一侧取反 x = (red_bezier + blue_bezier[::-1])/2,这样才能保证结果正确。

为了和原始图片保持一致,这里更改了画图原点,xy的方向。

3.2过滤点

没有采用原作者的fiter,因为相机存在畸变,实际测试中效果表现不好。因此自己尝试了两种方案。

3.2.1过滤置信度低的点

首先通过置信度进行筛选锥桶,可以看到原图的左边有很多蓝色锥桶,但是置信度低直接使用会影响结果。

将上图的坐标点抽出来单独画图,可以看出这样是无法进行规划的。

这里对yolov5 detect.py做一点小改动,在write results的时候,原来是保存归一化后的结果符合yolo数据格式。我们虚妄同时保存锥桶框最下沿中点的位置,x1,y1,x2,y2是框的两个对角点。

xx=(x1+x2)/2

yy=max(y1,y2);

因此又新开了一个txt_path2的txt,保存我们需要的最下沿中点的x,y坐标。最后将保存的点放到作者的test_data.py下

#               #Write resultsfor *xyxy, conf, cls in reversed(det):if save_txt:  # Write to filexywh = (xyxy2xywh(torch.tensor(xyxy).view(1, 4)) / gn).view(-1).tolist()  # normalized xywhline = (cls, *xywh, conf) if save_conf else (cls, *xywh)  # label formatwith open(f'{txt_path}.txt', 'a') as f:f.write(('%g ' * len(line)).rstrip() % line + '\n')x1,y1,x2,y2 = xyxyxx=(x1+x2)/2yy=max(y1,y2);line2 = (cls,xx,yy)txt_path2 = txt_path + "_"with open(f'{txt_path2}.txt', 'a') as f2:f2.write(('%g ' * len(line2)).rstrip() % line2 + '\n')

3.2.2过滤远的的点

由于左边第一列红色实际上不是当前赛道,是U型弯回来的时候左侧锥桶,因此采用距离的方法,筛掉,当然这个距离目前是自己定的,因为看起来想个圆形,所以采用(960,1300)为圆心1400000为距离剔除远的点。

traffic_cone = traffic_cone[np.lexsort(traffic_cone[:, ::-1].T)]  # 按x坐标排序cone= []for i in range(n):x=traffic_cone[i]xx=(x[0] - 960) ** 2 + (x[1] - 1600) ** 2if (x[0]-960)**2 + (x[1]-1300)**2 <= 1400000:cone.append(x)#clean_traffic_cone = filter_traffic_cone(traffic_cone)  # 剔除异常的锥桶return np.array(cone)

效果如下

4、实验结果

由于python画图不是16:9(1920,1080)的图像显示,因此通过ppt拉伸进行对比。ppt这个设置透明色会让路径多一些白点,只能凑活看一下。

这里规划线明显在左侧,应该向左打方向~

5、存在问题

5.1当一侧没有的时候就不可以了,因为没有路宽,也不知道相机内参外参无法投影(留坑后期填)

解决方法:定位建图,丢失一侧主要发生在转弯过程,如果已经转完了证明之前早就观察到了,通过建图数据进行规划。

5.2 筛选点

目前的方案都比较粗糙,如果有实际点的位置和自身状态进行筛选更好,比如根据当前的转向预测个范围在筛选。

欢迎技术交流和探讨~

这篇关于(八)锥桶赛道路径规划的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/228967

相关文章

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

Python中Windows和macOS文件路径格式不一致的解决方法

《Python中Windows和macOS文件路径格式不一致的解决方法》在Python中,Windows和macOS的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文... 目录方法 1:使用 os.path 模块方法 2:使用 pathlib 模块(推荐)方法 3:统一使

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod

MySQL9.0默认路径安装下重置root密码

《MySQL9.0默认路径安装下重置root密码》本文主要介绍了MySQL9.0默认路径安装下重置root密码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录问题描述环境描述解决方法正常模式下修改密码报错原因问题描述mysqlChina编程采用默认安装路径,

python获取当前文件和目录路径的方法详解

《python获取当前文件和目录路径的方法详解》:本文主要介绍Python中获取当前文件路径和目录的方法,包括使用__file__关键字、os.path.abspath、os.path.realp... 目录1、获取当前文件路径2、获取当前文件所在目录3、os.path.abspath和os.path.re

hdu2544(单源最短路径)

模板题: //题意:求1到n的最短路径,模板题#include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#i

动态规划---打家劫舍

题目: 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。 思路: 动态规划五部曲: 1.确定dp数组及含义 dp数组是一维数组,dp[i]代表

poj 1734 (floyd求最小环并打印路径)

题意: 求图中的一个最小环,并打印路径。 解析: ans 保存最小环长度。 一直wa,最后终于找到原因,inf开太大爆掉了。。。 虽然0x3f3f3f3f用memset好用,但是还是有局限性。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#incl

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同