当前位置: 首页 > news >正文

路径规划之启发式算法之一:A-Star(A*)算法

A*算法是一种启发式搜索算法,常用于解决路径规划问题。

一、A*算法的定义与原理

        A*算法是一种用于在图形或网格中查找最短路径的算法。它在搜索过程中综合考虑了每个节点的实际距离(g值)和预估距离(h值),以找到最优路径。具体来说,算法通过评价各个节点的代价值(f值),其中f值等于g值加上h值,来获取下一需要拓展的最佳节点,直至到达最终目标点位置。

        改进A算法是在传统A算法的基础上进行优化,以提高路径搜索的效率和准确性。改进的主要方向包括启发函数的选择与优化、搜索邻域的优化、双向搜索算法(双向A*)、对open list列表进行数据结构优化,以及曲线平滑化处理。

二、特点与优势

        1. 启发式搜索:A*算法利用启发信息(即预估距离h值)来指导搜索过程,从而提高了搜索效率。

        2. 环境适应性强:该算法对环境反应迅速,能够根据不同场景和约束条件进行路径规划。

        3. 路径直接:A*算法搜索路径直接,不易陷入局部最优解。

三、核心公式

        A*算法的核心在于其估价函数,该函数由两部分组成:实际代价g(n)和启发式估计代价h(n)。总的代价消耗f(n)是这两者的和,表示为:

f(n)=g(n)+h(n)

        其中:

        f(n) 表示节点的综合优先级,在选择节点时考虑该节点的综合优先级;

        g(n) 表示起始点到当前节点的代价值;

        h(n) 表示当前节点到目标点的代价估计值,也就是预估函数。

四、算法流程

       1.  A*算法的实现通常包括以下步骤:

        (1)初始化:创建开放列表(open list)和封闭列表(close list),并将起点加入开放列表。

        (2)搜索:从开放列表中选择f值最小的节点进行搜索。更新该节点的g值和h值,并检查其邻居节点。如果邻居节点在开放列表或封闭列表中,则更新其g值(如果通过当前节点到达该邻居节点的路径更短)。如果邻居节点不在任何列表中,则将其加入开放列表,并设置其父节点为当前节点。

        (3)更新列表:将已搜索过的节点从开放列表中移除,并加入封闭列表。

        (4)终止条件:如果目标节点在开放列表中,则找到最优路径并终止搜索。否则,继续搜索直到开放列表为空或达到其他终止条件。

        2. 改进A*算法的流程如下:

       (1)初始化:初始化open_set(开放列表)和close_set(关闭列表),将起点加入open_set中,并设置优先级为0(优先级最高)。

        (2)循环选择:如果open_set不为空,则从open_set中选取优先级最高的节点n。

        (3)目标检查:如果节点n为终点,则从终点开始逐步追踪parent节点,一直达到起点;返回找到的结果路径,算法结束。

        (4)节点扩展:如果节点n不是终点,则将节点n从open_set中删除,并加入close_set中;遍历节点n所有的邻近节点。

        (5)邻近节点检查:对于每个邻近节点m,如果m在close_set中,则跳过;如果m不在open_set中,则设置节点m的parent为节点n,计算节点m的优先级,并将节点m加入open_set中。

        (6)循环结束:重复步骤2-5,直到找到终点或open_set为空。

五、应用领域

        A*算法被广泛应用于各种路径规划问题,包括但不限于:

        (1)计算机图形学:在图形图像处理中,A*算法常用于搜索最优路径。

        (2)自动导航:A*算法可用于导航系统,规划机器人或车辆的移动路径。

        (3)网络规划:A*算法可用于网络规划和路由规划,如规划互联网数据包的最优路径。

        (4)游戏开发:A*算法常用于游戏开发,用于寻找游戏人物或NPC(非玩家角色)移动的最优路径。

六、注意事项与局限性

        (1)启发函数的选择:启发函数h(n)的选择对A*算法的性能和结果有很大影响。如果h(n)的值过小,算法将遍历更多的节点,导致搜索速度变慢;如果h(n)的值过大,则可能无法找到最短路径。因此,需要根据具体应用场景选择合适的启发函数。

        (2)计算复杂度:A*算法的计算复杂度较高,特别是在节点数量较多或障碍物复杂的情况下。因此,在实际应用中需要权衡搜索效率和计算复杂度之间的关系。

        (3)实时性要求:对于实时性要求较高的应用场景(如自动驾驶、无人机导航等),A*算法可能需要进行优化或与其他算法结合使用以满足实时性要求。

七、优化策略

        (1)启发函数的选择与优化:预估函数的选择对A*算法的性能有很大影响。如果h(n)的值过小,算法将遍历更多的节点,导致搜索速度变慢;如果h(n)的值过大,则可能无法找到最短路径。可以为启发函数增加权重系数,节点比较时启发函数的优化。

        (2)搜索邻域的优化:舍弃邻域法和扩展邻域法可以减少搜索范围,提高搜索效率。

        (3)*双向搜索算法(双向A)**:从起点和终点同时进行搜索,提高计算速度。

        (4)数据结构优化:对open list列表进行数据结构优化,如使用二叉堆等,以提高算法的执行效。

        (5)曲线平滑化:采用贝塞尔曲线等方法进行路径平滑化处理,提高路径的平滑度。

相关文章:

路径规划之启发式算法之一:A-Star(A*)算法

A*算法是一种启发式搜索算法,常用于解决路径规划问题。 一、A*算法的定义与原理 A*算法是一种用于在图形或网格中查找最短路径的算法。它在搜索过程中综合考虑了每个节点的实际距离(g值)和预估距离(h值),以…...

Android复习代码1-4章

public class RudioButton extends AppCompatActivity {Overrideprotected void onCreate(Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_rudio_button);// 找到RadioGroup和TextView的实例RadioGroup radioGrou…...

【问题】webdriver.Chrome()设置参数executable_path报不存在

场景1: 标红报错unresolved reference executable_path 场景2: 执行报错TypeError: __init__() got an unexpected keyword argument executable_path 原因: 上述两种场景是因为selenium4开始不再支持某些初始化参数。比如executable_path 解决: 方案…...

win10系统安装docker-desktop

1、开启Hyper-v ———————————————— Hyper-V 是微软提供的一种虚拟化技术,它允许你在同一台物理计算机上运行多个独立的操作系统实例。这种技术主要用于开发、测试、以及服务器虚拟化等领域。 —————————————————————— &#…...

小程序-基于java+SpringBoot+Vue的乡村研学旅行平台设计与实现

项目运行 1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA; 3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可 4.硬件环境&#xff1a…...

组件A底部栏(position: fixed )事件使用$emit更新内容失败bug解决

今天遇到一个很离奇的bug,记录一下 问题:在组件内底部栏使用$emit触发按钮事件但打印出来的值是初始化的值,更新的值被重置导致更新失败 原因:组件内底部使用了 position: fixed; 固定, 导致组件内插槽 this 与 保存按…...

数据结构——排序第三幕(深究快排(非递归实现)、快排的优化、内省排序,排序总结)超详细!!!!

文章目录 前言一、非递归实现快排二、快排的优化版本三、内省排序四、排序算法复杂度以及稳定性的分析总结 前言 继上一篇博客基于递归的方式学习了快速排序和归并排序 今天我们来深究快速排序,使用栈的数据结构非递归实现快排,优化快排(三路…...

C++的类功能整合

1. 类的基本概念 类是面向对象编程的核心&#xff0c;它封装了数据和操作数据的函数。 #include <iostream> using namespace std;class MyClass { public:int publicData;void publicFunction() {cout << "Public function" << endl;}private:i…...

《String类》

目录 一、定义与概述 二、创建字符串对象 2.1 直接赋值 2.2 使用构造函数 三、字符串的不可变性 四、常用方法 4.1 String对象的比较 4.1.1 比较是否引用同一个对象 4.1.2 boolean equals(Object anObject)方法&#xff1a;按照字典序比较 4.1.3 int compareTo(Strin…...

【docker】docker的起源与容器的由来、docker容器的隔离机制

Docker 的起源与容器的由来 1. 虚拟机的局限&#xff1a;容器的需求萌芽 在 Docker 出现之前&#xff0c;开发和部署软件主要依赖虚拟机&#xff08;VMs&#xff09;&#xff1a; 虚拟机通过模拟硬件运行操作系统&#xff0c;每个应用程序可以运行在自己的独立环境中。虽然虚…...

Window 安装 Nginx

参考链接 Windows 环境nginx安装使用及目录结构详解_windows 安装nginx-CSDN博客 Nginx 安装及配置教程&#xff08;Windows&#xff09;【安装】_nginx下载安装-CSDN博客 安装 1&#xff09;下载 nginx: download 2&#xff09;解压 3&#xff09;启动 3.1&#xff09;方…...

replace (regexp|substr, newSubstr|function)替换字符串中的指定部分

replace 方法用于替换字符串中的指定部分。它可以接受一个子字符串或正则表达式作为第一个参数&#xff0c;第二个参数是替换的内容。 用法示例 基本替换 let str "Hello, world!"; let newStr str.replace("world", "everyone"); console.lo…...

【ROS2】Ubuntu22.04安装ROS humble

一. ROS简介 1.1 什么是ROS ROS 是一个适用于机器人的开源的元操作系统。它提供了操作系统应有的服务&#xff0c;包括硬件抽象&#xff0c;底层设备控制&#xff0c;常用函数的实现&#xff0c;进程间消息传递&#xff0c;以及包管理。ROS的核心思想就是将机器人的软件功能做…...

cesium 3Dtiles变量

原本有一个变亮的属性luminanceAtZenith&#xff0c;但是新版本的cesium没有这个属性了。于是 let lightColor 3.0result._customShader new this.ffCesium.Cesium.CustomShader({fragmentShaderText:void fragmentMain(FragmentInput fsInput, inout czm_modelMaterial mate…...

配置泛微e9后端开发环境

配置泛微e9的后端开发环境 1.安装jdk1.8&#xff08;请自行安装并设置环境变量&#xff09; 2.将服务器上的WEARVER文件夹拷贝到开发环境下(其中要包含ecology和Resin目录) 3.通过idea创建一个基础Java项目,将jdk设置为1.8 4.添加依赖,需要将3个文件夹的所有jar包添加到项目中…...

【Stable Diffusion】安装教程

目录 一、python 安装教程 二、windows cuda安装教程 三、Stable Diffusion下载 四、Stable Diffusion部署&#xff08;重点&#xff09; 一、python 安装教程 &#xff08;1&#xff09;第一步下载 打开python下载页面&#xff0c;找到python3.10.9&#xff0c;点击右边…...

USB Type-C一线通扩展屏:多场景应用,重塑高效办公与极致娱乐体验

在追求高效与便捷的时代&#xff0c;启明智显USB Type-C一线通扩展屏方案正以其独特的优势&#xff0c;成为众多职场人士、娱乐爱好者和游戏玩家的首选。这款扩展屏不仅具备卓越的性能和广泛的兼容性&#xff0c;更能在多个应用场景中发挥出其独特的价值。 USB2.0显卡&#xff…...

【力扣】541.反转字符串2

问题描述 思路解析 每当字符达到2*k的时候&#xff0c;判断&#xff0c;同时若剩余字符>k,只对前k个进行判断&#xff08;这是重点&#xff09;因为字符串是不可变变量&#xff0c;所以将其转化为字符串数组&#xff0c;最后才将结果重新转变为字符串 字符串->字符数组 …...

什么是防抖与节流

防抖&#xff08;Debouncing&#xff09;与节流&#xff08;Throttling&#xff09; 在前端开发中&#xff0c;尤其是在处理用户输入、窗口调整大小、滚动事件等高频率触发的事件时&#xff0c;防抖和节流是两种常用的技术手段。它们可以帮助我们优化性能&#xff0c;减少不必…...

springboot vue 开源 会员收银系统 (12)购物车关联服务人员 订单计算提成

前言 完整版演示 http://120.26.95.195/ 开发版演示 http://120.26.95.195:8889/ 在之前的开发进程中&#xff0c;我们完成订单的挂单和取单功能&#xff0c;今天我们完成购物车关联服务人员&#xff0c;用户计算门店服务人员的提成。 1.商品关联服务人员 服务人员可以选择 一…...

FFmpeg 推流给 FreeSWITCH

FFmpeg 推流&#xff0c;貌似不难&#xff0c;网上有很多资料, 接到一个任务&#xff0c;推流给 FreeSWITCH&#xff0c;最开始以为很容易&#xff0c; 实则不然&#xff0c;FreeSWITCH uuid_debug_media <uuid>&#xff0c; 一直没人任何反应 仔细一查&#xff0c;Fr…...

.npmrc文件的用途

.npmrc 文件是 npm&#xff08;Node.js 的包管理工具&#xff09;用于配置项目或用户的设置文件。它可以存储与 npm 相关的配置信息&#xff0c;如注册表地址、认证信息、代理设置、安装路径等。.npmrc 文件可以出现在不同的地方&#xff0c;具有不同的作用范围&#xff0c;通常…...

C++游戏开发入门:如何从零开始实现自己的游戏项目?

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///C爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日分享关于C游戏开发的相关内容&#xff01; 关于【…...

Redis设计与实现第16章 -- Sentinel 总结1(初始化、主从服务器获取信息、发送信息、接收信息)

Sentinel是Redis的高可用解决方案&#xff1a;由一个或多个Sentinel实例组成的Sentinel系统可以监视任意多个主服务器&#xff0c;以及这些主服务器属下的所有从服务器&#xff0c;被监视的主服务器进入下线状态时&#xff0c;自动将下线主服务器属下的某个从服务器升级为新的主…...

Windows10+VirtualBox+Ubuntu:安装虚拟机VirtualBox,虚拟机中安装Ubuntu

一、需求 在Windows10系统中&#xff0c;安装虚拟机VirtualBox&#xff0c;VirtualBox中安装Ubuntu桌面版。 二、环境准备 系统环境 Windows10 内存&#xff1a;8G 虚拟化 虚拟机的运行&#xff0c;如果需要Windows系统开启虚拟化&#xff0c;可以通过BIOS设置。 “虚拟…...

Torchtune在AMD GPU上的使用指南:利用多GPU能力进行LLM微调与扩展

Torchtune on AMD GPUs How-To Guide: Fine-tuning and Scaling LLMs with Multi-GPU Power — ROCm Blogs 这篇博客提供了一份详细的使用Torchtune在AMD GPU上微调和扩展大型语言模型&#xff08;LLM&#xff09;的指南。Torchtune 是一个PyTorch库&#xff0c;旨在让您轻松地…...

C底层 函数栈帧

文章目录 一&#xff0c;什么是寄存器 二&#xff0c;栈和帧 前言 我们在学习c语言程序的时候&#xff0c;是不是有很多的疑问&#xff0c;如 1&#xff0c;为什么形参不可以改变实参 2&#xff0c;为什么我们编写程序的时候会出现烫烫烫......这个乱码 3&#xff0c;那些局…...

【模块一】kubernetes容器编排进阶业务容器化案例

Kubernetes 实战案例 Kubernetes实战案例-规划(基于nerdctl buildkitdcontainerd构建容器镜像) 业务容器化优势&#xff1a; ① 提高资源利用率、节约部署IT成本。 ② 提高部署效率&#xff0c;基于kubernetes实现微服务的快速部署与交付、容器的批量调度与秒级启动。 ③…...

可视化建模以及UML期末复习篇----相关软件安装

作为一个过来人&#xff0c;我的建议是别过来。 一、可视化建模 <1>定义: 官方&#xff1a;一种使用图形符号来表示系统结构和行为的建模技术。 我&#xff1a;其实说白了就是把工作流程用图形画出来。懂不&#xff1f; <2>作用: 提高理解和分析复杂系统的能力。促…...

Appflyer记录卸载事件

Appflyer官方文档 1.原理 1.AppsFlyer每天向Firebase Cloud Messaging&#xff08;FCM&#xff09;和 Apple Push Notification Services&#xff08;APNS&#xff09;发送一次API请求。 2.然后FCM和APNS会发送一条静默推送消息&#xff0c;用于判断用户设备上是否仍装有相关应…...

阿里云wordpress优化/合肥今日头条最新消息

游标声明 不占内存打开 申请内存 多行多列获取 每次取一行&#xff0c;关闭隐式游标的属性:SQL%ROWCOUNT 成功操作的行的数量SQL%FOUND 发现复合条件的行返回TRUESQL%NOTFOUND 没有发现复合条件的行回TRUESQL%ISOPEN 游标打开状态(boolean)练习 1…...

什么好的主题做网站/品牌运营管理公司

sqrt() 方法返回数字x的平方根。以下是 sqrt() 方法的语法:&#xff08;推荐学习&#xff1a;Python视频教程&#xff09;import math math.sqrt( x ) 注意&#xff1a;sqrt()是不能直接访问的&#xff0c;需要导入 math 模块&#xff0c;通过静态对象调用该方法。 参数 x -- 数…...

安徽网站建设电话/哈尔滨网站推广

一、实验器件 1、TPYBoard v102 1块 2、TPYBoard v202 1块 3、Nokia 5110LCD显示屏 1块 4、DHT11温湿度传感器 1个 5、micro USB 数据线 2根 6、面包板 1块 7、杜邦线 若干 &#xff08;该套件组合某宝可以买到&#xff09; 二、实验步骤 TPYBoard v102连接DHT11&#xff0c;采…...

wordpress的登陆地址修改密码/网站制作费用一览表

1&#xff09;、C#中重写窗口过程不用再调用SetWindowLong API了&#xff0c;直接overide一个WndProc就可以了。 2&#xff09;、Windows API中的HDC可以通过Graphics.FromHdc()转换为(创建出)System.Drawing.Graphics&#xff0c;然后就可以用.NET Framework &#xff08;GID?…...

公司做网站怎么做账/制作链接的app的软件

SQL*PLUS维护系统变量,也称SET变量,利用它可为SQL*PLUS交互建立一个特殊的环境,如:设置NUMBER数据的显示宽度;设置每页的行数;设置列的宽度等。可用SET命令改变这些系统变量,也可用SHOW命令列出它们.show 系统变量如&#xff1a;SQL> show linesizelinesize 1000使用set命令…...

为什么做域名跳转网站样式不见了/seo优化 搜 盈seo公司

字符串格式符&#xff1a; 符 号 描述 %c 格式化字符及其ASCII码 %s 格式化字符串 %d 格式化整数 %u 格式化无符号整型 %o 格式化无符号八进制数 %x 格式化无符号十六进制数 %X 格式化无符号十六进制数&#xff08;大写&#xff09; %f 格式化浮点数&#xff…...