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

PointPillars:数据预处理

在 PointPillars 算法中,将点云划分为点柱(Pillars)是核心步骤之一,用于将稀疏点云数据转换为规则的张量表示,方便后续 2D 卷积操作。以下是点云划分为点柱的具体方法和实现步骤:


1. 点云划分为网格

将 3D 空间划分为规则的网格,形成柱状区域(Pillars)。

操作步骤:
  1. 定义网格范围和分辨率

    • 确定点云的空间范围,例如:
      X min , X max , Y min , Y max , Z min , Z max X_{\text{min}}, X_{\text{max}}, Y_{\text{min}}, Y_{\text{max}}, Z_{\text{min}}, Z_{\text{max}} Xmin,Xmax,Ymin,Ymax,Zmin,Zmax
    • 设置网格分辨率(Pillar 尺寸):
      Δ X , Δ Y \Delta X, \Delta Y ΔX,ΔY
      例如,每个 Pillar 的大小为 0.16 × 0.16 m 0.16 \times 0.16 \, \text{m} 0.16×0.16m
  2. 计算网格索引

    • 对每个点 ( x , y , z ) (x, y, z) (x,y,z),计算其在网格中的索引:
      u = ⌊ x − X min Δ X ⌋ , v = ⌊ y − Y min Δ Y ⌋ u = \lfloor \frac{x - X_{\text{min}}}{\Delta X} \rfloor, \quad v = \lfloor \frac{y - Y_{\text{min}}}{\Delta Y} \rfloor u=ΔXxXmin,v=ΔYyYmin
    • u , v u, v u,v 分别是点在 X X X Y Y Y 方向上的网格索引。

2. 构建 Pillar 数据结构

每个 Pillar 中包含若干点的特征(点云数据是稀疏的,因此部分 Pillar 可能没有点)。

操作步骤:
  1. 点分组

    • 将所有点根据其网格索引分配到对应的 Pillar 中。
    • 例如,第 ( u , v ) (u, v) (u,v) 个 Pillar 包含所有满足条件的点:
      P pillar ( u , v ) = { ( x , y , z , i ) ∣ 点的索引为  ( u , v ) } P_{\text{pillar}}(u, v) = \{ (x, y, z, i) \mid \text{点的索引为 } (u, v) \} Ppillar(u,v)={(x,y,z,i)点的索引为 (u,v)}
  2. 固定点数量

    • 为了适配神经网络,每个 Pillar 中的点数量固定为 N max N_{\text{max}} Nmax
      • 如果点数超过 N max N_{\text{max}} Nmax,随机采样。
      • 如果点数不足 N max N_{\text{max}} Nmax,用零点填充。
  3. 特征提取
    对每个点提取以下特征:

    • ( x , y , z , i ) (x, y, z, i) (x,y,z,i):点的原始坐标和反射强度。
    • 相对坐标(相对于 Pillar 中心的偏移量):
      Δ x = x − x pillar center , Δ y = y − y pillar center \Delta x = x - x_{\text{pillar center}}, \quad \Delta y = y - y_{\text{pillar center}} Δx=xxpillar center,Δy=yypillar center
  4. 形成固定维度的张量

    • 对每个 Pillar,构造 N max × D N_{\text{max}} \times D Nmax×D 的特征矩阵,其中 D D D 是特征维度(例如,原始坐标 + 相对坐标 + 强度)。

3. BEV (Bird’s Eye View) 特征图

将所有 Pillar 的特征投影到 BEV 平面,形成伪影像特征图。

操作步骤:
  1. 初始化 BEV 特征图

    • 创建一个固定大小的张量 ( H , W , C ) (H, W, C) (H,W,C),对应网格的高度、宽度和通道数。
      • H = X max − X min Δ X H = \frac{X_{\text{max}} - X_{\text{min}}}{\Delta X} H=ΔXXmaxXmin
      • W = Y max − Y min Δ Y W = \frac{Y_{\text{max}} - Y_{\text{min}}}{\Delta Y} W=ΔYYmaxYmin
  2. 填充特征图

    • 对于每个 Pillar,将其特征向量映射到特定网格单元的通道维度中。
  3. 零填充

    • 如果某些网格单元没有对应的 Pillar,用零填充。

代码实现示例

以下是一个简单的 Python 实现框架:

import numpy as npdef create_pillars(point_cloud, grid_size, pillar_size, max_points_per_pillar):"""将点云划分为点柱 (Pillars) 并提取特征。Args:point_cloud: (N, 4) 点云数据,包含 (x, y, z, intensity)grid_size: [x_min, x_max, y_min, y_max]pillar_size: [pillar_x_size, pillar_y_size]max_points_per_pillar: 每个 Pillar 的最大点数Returns:pillars: (num_pillars, max_points_per_pillar, feature_dim)"""x_min, x_max, y_min, y_max = grid_sizepillar_x_size, pillar_y_size = pillar_size# 筛选点云范围内的点mask = (point_cloud[:, 0] >= x_min) & (point_cloud[:, 0] < x_max) & \(point_cloud[:, 1] >= y_min) & (point_cloud[:, 1] < y_max)points = point_cloud[mask]# 计算网格索引x_indices = np.floor((points[:, 0] - x_min) / pillar_x_size).astype(int)y_indices = np.floor((points[:, 1] - y_min) / pillar_y_size).astype(int)# 按索引分组点num_pillars = (x_max - x_min) // pillar_x_size * (y_max - y_min) // pillar_y_sizepillars = np.zeros((num_pillars, max_points_per_pillar, 7))  # [x, y, z, intensity, delta_x, delta_y, delta_z]for i, (x_idx, y_idx) in enumerate(zip(x_indices, y_indices)):pillar_idx = x_idx * y_max + y_idx  # Pillar 的一维索引if len(pillars[pillar_idx]) < max_points_per_pillar:delta_x = points[i, 0] - (x_idx * pillar_x_size + pillar_x_size / 2)delta_y = points[i, 1] - (y_idx * pillar_y_size + pillar_y_size / 2)pillars[pillar_idx].append([*points[i, :4], delta_x, delta_y, points[i, 2]])return pillars

实践优化

  1. GPU 加速:使用 CUDA 或 TensorFlow/PyTorch 操作处理点云。
  2. 稀疏优化:利用稀疏张量库减少计算成本。
  3. 并行化:在点划分和特征提取阶段进行并行处理。

相关文章:

PointPillars:数据预处理

在 PointPillars 算法中&#xff0c;将点云划分为点柱&#xff08;Pillars&#xff09;是核心步骤之一&#xff0c;用于将稀疏点云数据转换为规则的张量表示&#xff0c;方便后续 2D 卷积操作。以下是点云划分为点柱的具体方法和实现步骤&#xff1a; 1. 点云划分为网格 将 3D…...

node.js的异步工作之---回调函数与回调地狱

回调函数&#xff1a;在 Node.js 中&#xff0c;很多 API 都是异步的&#xff0c;通常通过回调函数来处理操作完成后的结果。这种回调模式虽然非常高效&#xff0c;但会导致代码逐渐变得难以维护&#xff0c;尤其是当有多个异步操作嵌套时&#xff08;即回调地狱&#xff09;。…...

Mac Android studio 升级LadyBug 版本,所产生的bug

当Build 出现&#xff0c;这样的文字以后&#xff1a; Your build is currently configured to use incompatible Java 21.0.3 and Gradle 7.3.3. Cannot sync the project. We recommend upgrading to Gradle version 8.9. The minimum compatible Gradle version is 8.5. …...

stm32 hex文件烧写

STM32的HEX文件烧写是将编译后的程序代码&#xff08;以HEX格式存储&#xff09;下载到STM32单片机中的过程。以下是对STM32 HEX文件烧写的详细解释&#xff1a; 一、HEX文件简介 HEX文件&#xff0c;即Intel HEX文件&#xff0c;是一种由文本行组成的ASCII文件&#xff0c;每…...

【编译原理】编译原理知识点汇总·属性文法和语法制导翻译

&#x1f308; 个人主页&#xff1a;十二月的猫-CSDN博客 &#x1f525; 系列专栏&#xff1a; &#x1f3c0;编译原理_十二月的猫的博客-CSDN博客 &#x1f4aa;&#x1f3fb; 十二月的寒冬阻挡不了春天的脚步&#xff0c;十二点的黑夜遮蔽不住黎明的曙光 目录 1. 前言 2. …...

【unity c#】深入理解string,以及不同方式构造类与反射的性能测试(基于BenchmarkDotNet)

出这篇文章的主要一个原因就是ai回答的性能差异和实际测试完全不同&#xff0c;比如说是先获取构造函数再构造比Activator.CreateInstance(type)快&#xff0c;实际却相反 对测试结果的评价基于5.0&#xff0c;因为找不到unity6确切使用的net版本&#xff0c;根据c#9推测是net5…...

VSCode 插件开发实战(八):创建和管理任务 Task

前言 VSCode 的扩展能力使得开发者能够根据个人需求定制工作环境&#xff0c;自定义插件和任务管理是 VSCode 强大功能的一部分&#xff0c;通过这些功能&#xff0c;开发者可以自动化常见工作流&#xff0c;简化日常开发任务&#xff0c;提高整体开发效率。本文将详细介绍如何…...

在 Node.js 中正确处理 `async/await` 及数组迭代

在使用 Node.js 开发应用程序时&#xff0c;我们常常需要处理异步操作。例如&#xff0c;当我们从数据库获取数据、调用外部API或执行文件读取时&#xff0c;这些操作都可能需要一些时间才能完成。在这种情况下&#xff0c;我们通常会使用 async/await 语法来简化异步编程的复杂…...

本科阶段最后一次竞赛Vlog——2024年智能车大赛智慧医疗组准备全过程——13使用Resnet-Bin

本科阶段最后一次竞赛Vlog——2024年智能车大赛智慧医疗组准备全过程——13使用Resnet-Bin ​ 根据前面的内容&#xff0c;目前已经可以获取到resnet的bin模型 1 .Resnet的bin测试 ​ 这里给大家一个测试视频里面黑线的demo&#xff0c;大家可以用来测试自己的黑线识别精度 …...

FFmpeg第三话:FFmpeg 视频解码详解

FFmpeg 探索之旅 一、FFmpeg 简介与环境搭建 二、FFmpeg 主要结构体剖析 三、FFmpeg 视频解码详解 FFmpeg第三话&#xff1a;FFmpeg 视频解码详解 FFmpeg 探索之旅前言一、视频解码基础二、FFmpeg 关键 API 深度剖析&#xff08;一&#xff09;avformat_open_input()&#xff…...

解决 vue3 中 echarts图表在el-dialog中显示问题

原因&#xff1a; 第一次点开不显示图表&#xff0c;第二次点开虽然显示图表&#xff0c;但是图表挤在一起&#xff0c;页面检查发现宽高只有100px,但是明明已经设置样式宽高100% 这可能是由于 el-dialog 还没有完全渲染完成&#xff0c;而你的 echarts 组件已经开始尝试渲染图…...

C++ OpenGL学习笔记(4、绘制贴图纹理)

相关链接&#xff1a; C OpenGL学习笔记&#xff08;1、Hello World空窗口程序&#xff09; C OpenGL学习笔记&#xff08;2、绘制橙色三角形绘制、绿色随时间变化的三角形绘制&#xff09; C OpenGL学习笔记&#xff08;3、绘制彩色三角形、绘制彩色矩形&#xff09; 通过前面…...

关于我的Java考试被老师挂掉的这件事......

目录 1.事情起源 2.问题出现 3.最后的考试结果 4.问题如何解决的 5.此件事情引发我的思考 1.事情起源 现在是2024-12-25中午的13:08分&#xff0c;我于今天上虞结束了这个学期的Java课程的学习&#xff0c;上午的课程内容就是开始&#xff0c;使用MVC实现对于题目要求的这…...

Websocket客户端从Openai Realtime api Sever只收到部分数据问题分析

目录 背景 分析 解决方案 背景 正常情况下&#xff0c;会从Openai Realtime api Sever收到正常的json数据,但是当返回音频数据时&#xff0c;总会返回非json数据。这是什么问题呢&#xff1f; 分析 期望的完整响应数据如下&#xff1a; {"session": {"inp…...

Unity 6 中的新增功能

Unity 6 是 Unity 的最新版本。 一、编辑器和工作流程 Unity 6 中引入的更改 在 Linux 上实现了将文件和资源从 Unity 拖放到外部应用程序的功能。将 Asset Manager for Unity 包添加到 Package Manager > Services > Content Management 部分中。此包允许用户轻松浏览…...

[ComfyUI]颜色提取插件,Flux专属,让出图更加可控

一、介绍​ 今天介绍这个好玩的插件 ComfyUI APQNodes&#xff0c;默认的Flux模型是无法理解准确的颜色代码。​ 而这个插件可以帮我忙将输入的十六进制颜色代码转换为 FLUX.1 Dev 已知的最相似的颜色名称&#xff08;来自预先测试的 155 个颜色名称&#xff09;。​ ​ 所以就…...

【magic-dash】01:magic-dash创建单页面应用及二次开发

文章目录 一、magic-dash是什么1.1 安装1.2 使用1.2.1 查看内置项目模板1.2.2 生成指定项目模板1.2.3 查看当前magic-dash版本1.2.4 查看命令说明1.2.5 内置模板列表二、创建虚拟环境并安装magic-dash三、magic-dash单页工具应用开发3.1 创建单页面项目3.1.1 使用命令行创建单页…...

ChatGPT等大语言模型与水文水资源、水环境领域的深度融合

聚焦GPT等大语言模型与水文水资源领域的深度融合&#xff0c;通过系统化内容与实践案例&#xff0c;讲解如何高效完成时间序列分析、空间数据处理、水文模型优化以及智能科学写作等任务。同时&#xff0c;展示AI在高级机器学习模型开发、资源优化算法编程与模型微调中的最新应用…...

机器学习连载

1 机器学习基础知识 机器学习&#xff08;Machine learning&#xff09;是人工智能的子集&#xff0c;是实现人工智能的一种途径&#xff0c;但并不是唯一的途径。它是一门专门研究计算机怎样模拟或实现人类的学习行为&#xff0c;以获取新的知识或技能&#xff0c;重新组织已…...

linux查看天气预报

wttr.in 是一个简单且功能强大的命令行天气查询工具&#xff0c;实现了命令行下查看天气的炫酷效果。 开源地址&#xff1a;GitHub - chubin/wttr.in: :partly_sunny: The right way to check the weather 一. 什么是 wttr.in&#xff1f; wttr.in 是一个基于 Web 的命令行天…...

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…...

day52 ResNet18 CBAM

在深度学习的旅程中&#xff0c;我们不断探索如何提升模型的性能。今天&#xff0c;我将分享我在 ResNet18 模型中插入 CBAM&#xff08;Convolutional Block Attention Module&#xff09;模块&#xff0c;并采用分阶段微调策略的实践过程。通过这个过程&#xff0c;我不仅提升…...

DAY 47

三、通道注意力 3.1 通道注意力的定义 # 新增&#xff1a;通道注意力模块&#xff08;SE模块&#xff09; class ChannelAttention(nn.Module):"""通道注意力模块(Squeeze-and-Excitation)"""def __init__(self, in_channels, reduction_rat…...

Java多线程实现之Callable接口深度解析

Java多线程实现之Callable接口深度解析 一、Callable接口概述1.1 接口定义1.2 与Runnable接口的对比1.3 Future接口与FutureTask类 二、Callable接口的基本使用方法2.1 传统方式实现Callable接口2.2 使用Lambda表达式简化Callable实现2.3 使用FutureTask类执行Callable任务 三、…...

2025 后端自学UNIAPP【项目实战:旅游项目】6、我的收藏页面

代码框架视图 1、先添加一个获取收藏景点的列表请求 【在文件my_api.js文件中添加】 // 引入公共的请求封装 import http from ./my_http.js// 登录接口&#xff08;适配服务端返回 Token&#xff09; export const login async (code, avatar) > {const res await http…...

CocosCreator 之 JavaScript/TypeScript和Java的相互交互

引擎版本&#xff1a; 3.8.1 语言&#xff1a; JavaScript/TypeScript、C、Java 环境&#xff1a;Window 参考&#xff1a;Java原生反射机制 您好&#xff0c;我是鹤九日&#xff01; 回顾 在上篇文章中&#xff1a;CocosCreator Android项目接入UnityAds 广告SDK。 我们简单讲…...

新能源汽车智慧充电桩管理方案:新能源充电桩散热问题及消防安全监管方案

随着新能源汽车的快速普及&#xff0c;充电桩作为核心配套设施&#xff0c;其安全性与可靠性备受关注。然而&#xff0c;在高温、高负荷运行环境下&#xff0c;充电桩的散热问题与消防安全隐患日益凸显&#xff0c;成为制约行业发展的关键瓶颈。 如何通过智慧化管理手段优化散…...

TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案

一、TRS收益互换的本质与业务逻辑 &#xff08;一&#xff09;概念解析 TRS&#xff08;Total Return Swap&#xff09;收益互换是一种金融衍生工具&#xff0c;指交易双方约定在未来一定期限内&#xff0c;基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...

mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包

文章目录 现象&#xff1a;mysql已经安装&#xff0c;但是通过rpm -q 没有找mysql相关的已安装包遇到 rpm 命令找不到已经安装的 MySQL 包时&#xff0c;可能是因为以下几个原因&#xff1a;1.MySQL 不是通过 RPM 包安装的2.RPM 数据库损坏3.使用了不同的包名或路径4.使用其他包…...

Mac下Android Studio扫描根目录卡死问题记录

环境信息 操作系统: macOS 15.5 (Apple M2芯片)Android Studio版本: Meerkat Feature Drop | 2024.3.2 Patch 1 (Build #AI-243.26053.27.2432.13536105, 2025年5月22日构建) 问题现象 在项目开发过程中&#xff0c;提示一个依赖外部头文件的cpp源文件需要同步&#xff0c;点…...