new file https 找不到路径_开源了!机器人技术常用的路径规划算法(含动画演示)...

【导语】:一个实现了机器人技术中常用的路径规划算法的开源库,还有动图直观演示运行过程。该库公开时间不长,在 GitHub 已有 1200+ Star。

简介

在机器人研究领域,给定某一特定任务之后,如何规划机器人的运动方式至关重要。PathPlanning 是使用 Python 实现的存储库,实现了机器人技术中常用的路径规划算法。开发者还为每个算法设计了动画来演示运行过程,相当直观清晰。

项目地址:

https://github.com/zhm-real/PathPlanning

这个项目的贡献者目前是 4 位国内开发者。

目录结构

PathPlanning 库实现的路径规划算法包括基于搜索和基于采样的规划算法,目录结构如下:

76218e53280e19db15cb63b0da3b64e7.png

下面我们直接通过开发者设计的动图了解各个算法的运行过程:

基于搜索的路径规划算法

(1)最佳路径优先搜索算法

caf27d9080aea5310acdf5c1f5d42540.gif

"""
Best-First Searching
@author: huiming zhou
"""

import os
import sys
import math
import heapq

sys.path.append(os.path.dirname(os.path.abspath(__file__)) +
                "/../../Search_based_Planning/")

from Search_2D import plotting, env
from Search_2D.Astar import AStar


class BestFirst(AStar):
    """BestFirst set the heuristics as the priority 
    """
    def searching(self):
        """
        Breadth-first Searching.
        :return: path, visited order
        """

        self.PARENT[self.s_start] = self.s_start
        self.g[self.s_start] = 0
        self.g[self.s_goal] = math.inf
        heapq.heappush(self.OPEN,
                       (self.heuristic(self.s_start), self.s_start))

        while self.OPEN:
            _, s = heapq.heappop(self.OPEN)
            self.CLOSED.append(s)

            if s == self.s_goal:
                break

            for s_n in self.get_neighbor(s):
                new_cost = self.g[s] + self.cost(s, s_n)

                if s_n not in self.g:
                    self.g[s_n] = math.inf

                if new_cost # conditions for updating Cost
                    self.g[s_n] = new_cost
                    self.PARENT[s_n] = s

                    # best first set the heuristics as the priority 
                    heapq.heappush(self.OPEN, (self.heuristic(s_n), s_n))

        return self.extract_path(self.PARENT), self.CLOSED


def main():
    s_start = (5, 5)
    s_goal = (45, 25)

    BF = BestFirst(s_start, s_goal, 'euclidean')
    plot = plotting.Plotting(s_start, s_goal)

    path, visited = BF.searching()
    plot.animation(path, visited, "Best-first Searching")  # animation


if __name__ == '__main__':
    main()

(2)Dijkstra搜索算法

9a0548944cf72955ded1b7243957f705.gif

(3)A*搜索算法

fff7fb173e4b68b873b22279acd655fb.gif

(4)双向A* 搜索算法

2e9a53c53902640d655f0a7cc77fdf30.gif

(5)重复 A*搜索算法

f56072647c358e882982e2e4bd7aebff.gif

(6)ARA* 搜索算法

a7890a6422b17fd6169c93801dde5b3d.gif

(7)LRTA* 搜索算法

18f7fde420396f324a97da3bf711ed5a.gif

(8)RTAA* 搜索算法

6ce573c1de203d21730339fe0e181f36.gif

(9)D* 搜索算法

4e799f0dc7bba13454db7a8cc95f44c5.gif

(10)终身规划 A* 搜索算法

a1961727f94aa8cb8639505286252bbc.gif

(11)Anytime D* 搜索算法:变动较小

71fb9254e86c93dd4e517056943fccc2.gif

(12)Anytime D* 搜索算法:变动较大

4d646c3104f90203bfcb88903d78f38d.gif

基于采样的路径规划算法

(1)RRT 算法

d95ad91e2dbe43ee84eb8bdcb4550c07.gif

(2)目标偏好 RRT 算法

f8d6fb3332fa492d07d0aac3f7abc6d4.gif

(3)RRT_CONNECT 算法

cc9c99ab6198357d5489de580d02ed4b.gif

(4)Extended_RRT 算法

e50498a03330e7d5aca9c1d42243470a.gif

(5)动态 RRT 算法

e09d144d0d07dcd614f433f9081541b9.gif

(6)N = 10000 时,rrt * 算法

be1e2bd3e6c3a05169159a7ecf9678c0.png

(7)N = 1000 时,rrt*-Smart 算法

2dba971a9152b8fb6a69e64f69ba49dd.gif

(8)FMT* 算法

9f00d5baa8bd71d8793a197b43421c88.gif

(9)N =1000 时,Informed rrt * 算法

73a814f8238d4683f2234f3188968aed.gif

(10)BIT* 算法

5151bd7941d98a22671677e3317bcd91.gif

以上是开发者设计的动画,是不是很直观生动呢?对路径规划算法感兴趣的童鞋可以到项目主页详细了解。

- EOF - 

更多优秀开源项目(点击下方图片可跳转)

34272baa40b0826b3a7abf7c69b0e4dc.png

fbb8438a9a10b4a1f6da9669818b8bef.png

885ae6bf05a0f966259c1dca732a2ae4.png

如果觉得本文介绍的开源项目不错,欢迎转发推荐给更多人。

f5d769c659ac66700918f9aa8e8eff21.png

分享、点赞和在看

支持我们分享更多优秀开源项目,谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值