人工智能D* Lite 算法-动态障碍物处理、多步预测和启发式函数优化
在智能驾驶领域,D* Lite 算法是一种高效的动态路径规划算法,适用于处理环境变化时的路径重规划问题。以下将为你展示 D* Lite 算法的高级用法,包含动态障碍物处理、多步预测和启发式函数优化等方面的代码实现。
代码实现
import heapq
import math# 地图类,用于管理地图信息和更新
class Map:def __init__(self, grid):self.grid = gridself.rows = len(grid)self.cols = len(grid[0])def get_neighbors(self, node):x, y = nodeneighbors = []for dx, dy in [(0, 1), (0, -1), (1, 0), (-1, 0), (1, 1), (1, -1), (-1, 1), (-1, -1)]:new_x, new_y = x + dx, y + dyif 0 <= new_x < self.rows and 0 <= new_y < self.cols and self.grid[new_x][new_y] == 0:neighbors.append((new_x, new_y))return neighborsdef update_cell(self, x, y, new_value):self.grid[x][y] = new_valuedef is_obstacle(self, node):x, y = nodereturn self.grid[x][y] == 1# 节点类,用于存储节点信息
class Node:def __init__(self, x, y):self.x = xself.y = yself.g = float('inf')self.rhs = float('inf')self.key = [float('inf'), float('inf')]def __lt__(self, other):return self.key < other.key# 优化的启发式函数:考虑对角线移动的欧几里得距离
def heuristic(a, b):dx = abs(a[0] - b[0])dy = abs(a[1] - b[1])return math.sqrt(dx**2 + dy**2)# 计算节点的键值
def calculate_key(node, s_start, k_m):node.key = [min(node.g, node.rhs) + heuristic((node.x, node.y), s_start) + k_m,min(node.g, node.rhs)]return node# 初始化 D* Lite 算法
def initialize(s_start, s_goal):U = []nodes = {}for i in range(map_obj.rows):for j in range(map_obj.cols):node = Node(i, j)nodes[(i, j)] = nodes_goal_node = nodes[s_goal]s_goal_node.rhs = 0s_goal_node = calculate_key(s_goal_node, s_start, 0)heapq.heappush(U, s_goal_node)return U, nodes# 更新节点的 rhs 值
def update_vertex(U, node, s_start, k_m):if node.g != node.rhs:node = calculate_key(node, s_start, k_m)for i, n in enumerate(U):if n.x == node.x and n.y == node.y:U[i] = nodeheapq.heapify(U)breakelse:heapq.heappush(U, node)else:for i, n in enumerate(U):if n.x == node.x and n.y == node.y:U.pop(i)heapq.heapify(U)break# 计算最短路径
def compute_shortest_path(U, s_start, nodes, k_m):while U and (U[0].key < calculate_key(nodes[s_start], s_start, k_m) ornodes[s_start].rhs > nodes[s_start].g):u = heapq.heappop(U)if u.g > u.rhs:u.g = u.rhselse:u.g = float('inf')update_vertex(U, u, s_start, k_m)for neighbor in map_obj.get_neighbors((u.x, u.y)):neighbor_node = nodes[neighbor]if neighbor != s_start:cost = 1if abs(u.x - neighbor[0]) + abs(u.y - neighbor[1]) == 2:cost = math.sqrt(2) # 对角线移动代价neighbor_node.rhs = min(neighbor_node.rhs,u.g + cost)update_vertex(U, neighbor_node, s_start, k_m)# 动态障碍物处理和多步预测
def handle_dynamic_obstacles(U, nodes, s_start, s_goal, k_m, dynamic_obstacles):for obstacle in dynamic_obstacles:obstacle_node = nodes[obstacle]map_obj.update_cell(obstacle[0], obstacle[1], 1)for neighbor in map_obj.get_neighbors(obstacle):neighbor_node = nodes[neighbor]neighbor_node.rhs = float('inf')update_vertex(U, neighbor_node, s_start, k_m)compute_shortest_path(U, s_start, nodes, k_m)# 路径规划函数
def d_star_lite(s_start, s_goal, dynamic_obstacles=[]):U, nodes = initialize(s_start, s_goal)k_m = 0compute_shortest_path(U, s_start, nodes, k_m)path = []current = s_startwhile current != s_goal:path.append(current)neighbors = map_obj.get_neighbors(current)min_rhs = float('inf')next_node = Nonefor neighbor in neighbors:neighbor_node = nodes[neighbor]if neighbor_node.rhs < min_rhs:min_rhs = neighbor_node.rhsnext_node = neighborif next_node is None:print("未找到可行路径!")return []current = next_nodepath.append(s_goal)# 处理动态障碍物if dynamic_obstacles:handle_dynamic_obstacles(U, nodes, s_start, s_goal, k_m, dynamic_obstacles)path = []current = s_startwhile current != s_goal:path.append(current)neighbors = map_obj.get_neighbors(current)min_rhs = float('inf')next_node = Nonefor neighbor in neighbors:neighbor_node = nodes[neighbor]if neighbor_node.rhs < min_rhs:min_rhs = neighbor_node.rhsnext_node = neighborif next_node is None:print("未找到可行路径!")return []current = next_nodepath.append(s_goal)return path# 示例地图
map_grid = [[0, 0, 0, 0, 0],[0, 1, 1, 0, 0],[0, 0, 0, 0, 0],[0, 0, 1, 1, 0],[0, 0, 0, 0, 0]
]
map_obj = Map(map_grid)# 起点和终点
s_start = (0, 0)
s_goal = (4, 4)# 初始路径规划
path = d_star_lite(s_start, s_goal)
if path:print("初始规划的路径:", path)# 模拟动态障碍物出现
dynamic_obstacles = [(2, 2)]
path = d_star_lite(s_start, s_goal, dynamic_obstacles)
if path:print("出现动态障碍物后重新规划的路径:", path)
代码解释
1. 地图类(Map)
get_neighbors:不仅考虑上下左右移动,还考虑了对角线移动,扩大了节点的搜索范围。is_obstacle:判断节点是否为障碍物。
2. 节点类(Node)
- 存储节点的坐标、
g值(从起点到该节点的实际代价)、rhs值(到该节点的最短路径的估计代价)和键值key。
3. 启发式函数(heuristic)
- 采用考虑对角线移动的欧几里得距离作为启发式函数,更准确地估计节点到目标节点的代价。
4. D* Lite 算法核心函数
initialize:初始化算法,创建节点字典和优先队列U,将目标节点加入队列。calculate_key:计算节点的键值,用于优先队列的排序。update_vertex:更新节点的rhs值,并根据情况更新优先队列。compute_shortest_path:计算最短路径,不断更新节点的g和rhs值,直到找到最短路径或队列为空。
5. 动态障碍物处理和多步预测
handle_dynamic_obstacles:处理动态障碍物的出现,更新受影响节点的rhs值,并重新计算最短路径。
6. 路径规划函数(d_star_lite)
- 主路径规划函数,先进行初始路径规划,若存在动态障碍物,则调用
handle_dynamic_obstacles重新规划路径。
注意事项
- 代码中的动态障碍物处理是简单模拟,实际应用中需要结合传感器数据实时更新障碍物信息。
- 启发式函数和移动代价的计算可以根据具体场景进行调整,以提高路径规划的效率和准确性。
- 代码中未考虑车辆的运动学约束,实际智能驾驶中需要进一步考虑车辆的转弯半径、速度限制等因素。
相关文章:
人工智能D* Lite 算法-动态障碍物处理、多步预测和启发式函数优化
在智能驾驶领域,D* Lite 算法是一种高效的动态路径规划算法,适用于处理环境变化时的路径重规划问题。以下将为你展示 D* Lite 算法的高级用法,包含动态障碍物处理、多步预测和启发式函数优化等方面的代码实现。 代码实现 import heapq impo…...
C#常用集合优缺点对比
先上结论: 在C#中,链表、一维数组、字典、List<T>和ArrayList是常见的数据集合类型,它们各有优缺点,适用于不同的场景。以下是它们的比较: 1. 一维数组 (T[]) 优点: 性能高:数组在内存中…...
多线程下jdk1.7的头插法导致的死循环问题
20250208 多线程下jdk1.7的头插法导致的死循环问题 多线程下jdk1.7的头插法导致的死循环问题 【新版Java面试专题视频教程,java八股文面试全套真题深度详解(含大厂高频面试真题)】 jdk1.7在hashmap扩容时使用的是头插法,所以扩容…...
MySQL的深度分页如何优化?
大家好,我是锋哥。今天分享关于【MySQL的深度分页如何优化?】面试题。希望对大家有帮助; MySQL的深度分页如何优化? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 MySQL在处理深度分页(即查询页数较大时,通常是查询…...
uniapp中使用uCharts折线图X轴数据间隔显示
1、先看官网 https://www.ucharts.cn/ 2、设置代码 "xAxisDemo3":function(val, index, opts){if(index % 2 0){return val}else {return }}, 再在数据中引入设置好样式...
VMware下Linux和macOS安装VSCode一些总结
本文介绍VMware下Linux和macOS安装VSCode的一些内容,包括VSCode编译器显示中文以及安装.NET环境和Python环境。 VSCode下载地址:Download Visual Studio Code - Mac, Linux, Windows 一.Linux系统下 1.安装中文包 按 Ctrl Shift P 打开命令面板。输…...
公司配置内网穿透方法笔记
一、目的 公司内部有局域网,局域网上有ftp服务器,有windows桌面服务器; 在内网环境下,是可以访问ftp服务器以及用远程桌面登录windows桌面服务器的; 现在想居家办公时,也能访问到公司内网的ftp服务器和win…...
【Windows/C++/yolo开发部署02:正确方法】将自定义实例分割模型导出为 ONNX 格式
【完整项目下载地址】: 【TensorRT部署YOLO项目:实例分割+目标检测】+【C++和python两种方式】+【支持linux和windows】资源-CSDN文库 目录 写在前面 环境准备 安装必要的库 下载模型并开始转换 解决依赖问题 安装 ONNX 降级 Protobuf 最终转换 总结 写在前面 在…...
国产编辑器EverEdit - 编辑辅助功能介绍
1 编辑辅助功能 1.1 各编辑辅助选项说明 1.1.1 行号 打开该选项时,在编辑器主窗口左侧显示行号,如下图所示: 1.1.2 文档地图 打开该选项时,在编辑器主窗口右侧靠近垂直滚动条的地方显示代码的缩略图,如下图所示&…...
Jupyter Notebook自动保存失败等问题的解决
一、未生成配置文件 需要在命令行中,执行下面的命令自动生成配置文件 jupyter notebook --generate-config 执行后会在 C:\Users\用户名\.jupyter目录中生成文件 jupyter_notebook_config.py 二、在网页端打开Jupyter Notebook后文件保存失败;运行代码…...
Shapefile格式文件解析和显示
Java实现GIS SHP文件格式的解析和显示,JDK19下编译,awt图形系统显示。 SHP文件对应的属性存储在DBF格式数据库中,解析见:DBASE DBF数据库文件解析_数据库文件在线解析-CSDN博客 解析SHP文件代码: public static Shap…...
大语言模型需要的可观测性数据的关联方式
可观测性数据的关联方式及其优缺点 随着现代分布式架构和微服务的普及,可观测性(Observability)已经成为确保系统健康、排查故障、优化性能的重要组成部分。有效的可观测性数据关联方式不仅能够帮助我们实时监控系统的运行状态,还…...
wordpressAI工具,已接入Deepseek 支持自动生成文章、生成图片、生成长尾关键词、前端AI窗口互动、批量采集等
基于关键词或现有内容生成SEO优化的文章,支持多种AI服务(如OpenAI、百度文心一言、智谱AI等),并提供定时任务、内容采集、关键词生成等功能。 核心功能 文章生成 关键词生成:根据输入的关键词生成高质量文章。 内容…...
解构赋值在 TypeScript 中的妙用:以 Babylon.js 的 loadModel 函数为例
在现代 JavaScript 和 TypeScript 开发中,解构赋值(Destructuring Assignment)是一种非常实用的特性,它能够让代码更加简洁、易读且高效。今天,我们就通过一个实际的例子——在 Babylon.js 中加载 3D 模型的 loadMod…...
mysql8安装时提示-缺少Microsoft Visual C++ 2019 x64 redistributable
MySQL8.0安装包mysql-8.0.1-winx64进行安装,提示:This application requires Visual Studio 2019 x64Redistributable, Please install the Redistributable then runthis installer again。出现这个错误是因为我们电脑缺少Microsoft Visual C 这个程序&…...
物品匹配问题-25寒假牛客C
登录—专业IT笔试面试备考平台_牛客网 这道题看似是在考察位运算,实则考察的是n个物品,每个物品有ai个,最多能够得到多少个物品的配对.观察题目可以得到,只有100,111,010,001(第一位是ci,第二位是ai,第三位是bi)需要进行操作,其它都是已经满足条件的对,可以假设对其中两个不同…...
学习数据结构(6)单链表OJ上
1.移除链表元素 解法一:(我的做法)在遍历的同时移除,代码写法比较复杂 解法二:创建新的链表,遍历原链表,将非val的节点尾插到新链表,注意,如果原链表结尾是val节点需要将…...
03/29 使用 海康SDK 对接时使用的 MysqlUtils
前言 最近朋友的需求, 是需要使用 海康sdk 连接海康设备, 进行数据的获取, 比如 进出车辆, 进出人员 这一部分是 资源比较贫瘠时的一个 Mysql 工具类 测试用例 public class MysqlUtils {public static String MYSQL_HOST "192.168.31.9";public static int MY…...
全志A133 android10 thermal温控策略配置调试
一,功能介绍 Thermal简称热控制系统,其功能是通过temperature sensor(温度传感器)测量当前CPU、GPU等设备的温度值,然后根据此温度值,影响CPU、GPU等设备的调频策略,对CPU、GPU等设备的最大频率…...
知识图谱智能应用系统:数据存储架构与流程解析
在当今数字化时代,知识图谱作为一种强大的知识表示和管理工具,正逐渐成为企业、科研机构以及各类智能应用的核心技术。知识图谱通过将数据转化为结构化的知识网络,不仅能够高效地存储和管理海量信息,还能通过复杂的查询和推理,为用户提供深度的知识洞察。然而,构建一个高…...
mac下生成.icns图标
笔记原因: 今日需要在mac下开发涉及图标文件的使用及icons文件的生成,所以记录一下。 网络上都是一堆命令行需要打印太麻烦了,写一个一键脚本。 步骤一 将需要生成的png格式文件重命名为“pic.png” mv xxxx.png pic.png 步骤二 下载我…...
Dev-cpp C语言编写和调用dll
Dev-cpp新建DLL项目。 dllmain.cpp #include "dll.h" #include <windows.h>int add(int a, int b) { return a b; } dll.h #ifndef _DLL_H_ #define _DLL_H_extern "C" __declspec(dllexport) int add(int a, int b);#endif 调用DLL&#…...
IDEA编写SpringBoot项目时使用Lombok报错“找不到符号”的原因和解决
目录 概述|背景 报错解析 解决方法 IDEA配置解决 Pom配置插件解决 概述|背景 报错发生背景:在SpringBoot项目中引入Lombok依赖并使用后出现"找不到符号"的问题。 本文讨论在上述背景下发生的报错原因和解决办法,如果仅为了解决BUG不论原…...
差速驱动机器人MPC算法实现-C++
差速驱动机器人,其运动学模型需要考虑线速度和角速度。MPC(模型预测控制)需要建立预测模型,并在每个控制周期内求解优化问题。 差速驱动机器人的运动学方程通常包括位置(x, y)和航向角θ,线速度…...
将仓库A分支同步到仓库B分支,并且同步commit提交
一、 问题 有一仓库A 和 一仓库B, 需要将仓库A分支a1所有提交同步推送到仓库B分支b1上 二、 解决 2.1、 首先需要仓库A、仓库B的权限, 2.2、将仓库A clone到本地, 进入A目录,并且切换到a1分支 cd A ## A 为A仓库clone到本地代…...
kafka生产者之发送模式与ACK
文章目录 Kafka的发送模式Kafka的ack机制发送模式与ack的关联重试次数总结 在Kafka中,发送模式与ack机制紧密相关,它们共同影响着消息发送的可靠性和性能。 Kafka的发送模式 发后即忘(Fire and Forget):生产者发送消息…...
C++字符串相关内容
字符串 字符串,本质上是一个接一个字符的一组字符。字母、数字、符号等。 const char* 字符串名 字符后面会有一个空终止符,为0。 字符串从指针的内存地址开始,然后继续下去,直到它碰到0,然后意识到字符串终止了。 …...
Windows Docker笔记-Docker拉取镜像
通过在前面的章节《安装docker》中,了解并安装成功了Docker,本章讲述如何使用Docker拉取镜像。 使用Docker,主要是想要创建并运行Docker容器,而容器又要根据Docker镜像来创建,那么首当其冲,必须要先有一个…...
穷举vs暴搜vs深搜vs回溯vs剪枝系列一>黄金矿工
目录 决策树:代码设计代码: 决策树: 代码设计 代码: class Solution {boolean[][] vis;int ret,m,n;public int getMaximumGold(int[][] grid) {m grid.length;n grid[0].length;vis new boolean[m][n]; for(int i 0; i <…...
07苍穹外卖之redis缓存商品、购物车(redis案例缓存实现)
课程内容 缓存菜品 缓存套餐 添加购物车 查看购物车 清空购物车 功能实现:缓存商品、购物车 效果图: 1. 缓存菜品 1.1 问题说明 用户端小程序展示的菜品数据都是通过查询数据库获得,如果用户端访问量比较大,数据库访问压…...
