格灵深瞳C++软件开发面试(一)

全程1小时40分钟
一、项目上的问题
1、介绍项目
2、项目上为什么用双PID做纵向控制,横向上用mpc控制
    A:PID不需要知道模型,直接用就行,横向比较复杂
3、横向上为什么不能用PID MPC用的什么求解器
    A:因为横向需要转弯比较复杂 求解器用的OSQP
4、PID参数怎么调
    A:先调P,再调I,最后调D
5、D有什么作用?
    A:修正调节I的动态响应
6、积分饱和有什么作用
    A:防止误差过大,输出过大
7、路径规划怎么规划的,为什么要用改进A*
    A:激光雷达构建地图实现全局路径规划,ARA*算法首先改用曼哈顿距离、其次动态调整启发函数的权值,不同场景下权值不一样
8、为什么不把车辆的爬坡当成代价算进去?
    A:我们分场景进行ARA*的构建,没有考虑这种方法,后面可以试一下
9、你们应该需要局部规划,A*会一直重构建路径,导致一个场景结束得等一会才能继续,采用局部的RRT、RRT*、D*可能会解决你们这个问题
    A:嗯嗯额嗯,谢谢您的建议
10、为什么用B样条
    A:拐弯轨迹可能出现拐点,导致曲率突变
11、还有什么轨迹生成的方法?
    A:人工势场法、我了解Apollo的Lattice\EM planner都可以

#暑期实习#
全部评论
双九爷吗?
点赞 回复 分享
发布于 2023-07-25 23:39 四川
佬,有内推码吗
点赞 回复 分享
发布于 2023-09-30 18:51 辽宁

相关推荐

2024-12-24 15:23
腾讯_开发(实习员工)
现在面试过程中经常会遇到一些智力题,说实话这些题没见过根本没法在有限的时间内做出来,因此准备把面试过程中遇到的一些智力题记录下来形成一个专栏,今日智力题是经典的赛马问题。问题描述:25匹马,有5个赛道,选出速度最快的前3匹马,最少应该用几次比赛呢?答案:7次详细解答如下:Step1: 首先把25匹马分成5组,A组 B组 C组 D组 E组,然后每个组下有5匹马,比如a1 a2 a3 a4 a5 / b1 b2 b3 b4 b5这样子。每个组在组内进行比赛,比如首先进行A组内部的比赛,然后得到A组中前三名的马是 a1 a2 a3。同样的对其余各组也这么组内比较,分别得到每个组的前三名,最终剩下的选手是 a1 a2 a3 | b1 b2 b3 | c1 c2 c3 | d1 d2 d3 | e1 e2 e3此阶段需要进行5次赛跑。Step2: 我们把每个小组第一名 a1 b1 c1 d1 e1拿出来比较一次,假设这次成绩是 a1 > b1 > c1 > d1 >e1(成绩靠前的名次好),由于我们要选出所有25个马的前三名,那么d1 e1那小组中就可以全部淘汰了。并且a1一定是25个马中最快的那个马,因此现在我们需要选出第二 三名,在只剩余的两个名额,我们只需要从 a2 a3 b1 b2 c1中选(因为只剩下2个名额了,所以b3被淘汰了,又因为b1 > c1所以c组最多能竞争第三名,所以c2 c3淘汰了)。因此这一轮经过1次比较。Step3:我们在step2中剩下了 a2 a3 b1 b2 c1这5个马,因此只需要再比较1次,就可以选出整体中的二三名了。综上所述:总共需要7次比赛。#牛客激励计划##ai智能作图#
点赞 评论 收藏
分享
评论
7
21
分享

创作者周榜

更多
牛客网
牛客企业服务