从工作空间->配置空间映射:
将具有一定范围大小的robot映射为质点,让障碍物进行膨胀。
data:image/s3,"s3://crabby-images/d98dc/d98dcefedb57ebce2189f09c6de2ea8a620dd679" alt=""
将无人机看成圆盘或者圆球,以半径大小将障碍物进行膨胀,然后将无人机看成质点。
data:image/s3,"s3://crabby-images/1e7f5/1e7f5395d52449d8d9137dcb874ad9189e75393b" alt=""
图搜索定义:
图搜索主要逻辑: data:image/s3,"s3://crabby-images/338f3/338f35b9b1bb0a62646701dc65bfc2e6f59e5d8c" alt=""
深度优先搜索DFS:像堆栈
广度优先搜索BFS:像队列 data:image/s3,"s3://crabby-images/19ef6/19ef661a3dd768ed7de9d99622aefe6eb529b712" alt=""
BFS相比DFS是想找到最优的,而DFS不是为了找最优:data:image/s3,"s3://crabby-images/3ad14/3ad14af10ac5cb0e2a7fe74eb93d4d38a4a9d6f6" alt=""
贪婪BFS:
data:image/s3,"s3://crabby-images/ee1c9/ee1c9f1e86330eee752e57fc112ae386675f9ca5" alt=""
有障碍后不一定最优:
data:image/s3,"s3://crabby-images/0ee5c/0ee5c06d31a148ea068043ab081b9c4a435b21d6" alt=""
Dijkstra 算法:
data:image/s3,"s3://crabby-images/c3958/c3958d87f27a9aac56b1b2d089eea94aaa15273f" alt=""
A*算法:
算法是否取到最优性:
data:image/s3,"s3://crabby-images/6b8a4/6b8a427293a5b154dd3df3809e7f94a5a6b1596c" alt=""
权重对A*算法的影响:
data:image/s3,"s3://crabby-images/093eb/093eb9d33097b8e68db49f290975c88b2f081980" alt=""
C++中有利于A*算法的std数据结构参考:
data:image/s3,"s3://crabby-images/46a2f/46a2f1b79e27da5d109aaac71b4968dc6d587296" alt=""
最佳的启发函数:对角启发
data:image/s3,"s3://crabby-images/d919c/d919c08e262f13dc06068d33e876c640ac3f7b10" alt=""
Jump Point Search(跳点搜索算法): data:image/s3,"s3://crabby-images/866f2/866f2f8dec570c7c1d810a55fe8fb9e33d7a4b0c" alt=""
当前节点x与父节点到达下一个节点进行比较:
data:image/s3,"s3://crabby-images/9db47/9db47be80373d7dd9b1f44e64ad7ba5797c48c3c" alt=""
跳跃规则:
data:image/s3,"s3://crabby-images/74255/742555a5fc21d784d8c4e1ff949e79e270c64e43" alt=""
data:image/s3,"s3://crabby-images/71130/711306716b26f56e45abea1066cf5344271d5c1a" alt=""
[注意]:但是JPS会将没有障碍物的区域全部进行查询,不太节省时间,空旷的地方太多的时候,该算法会比A*算法更慢。