0

0

Numpy 实现二维网格化点云均值统计(无显式循环)

聖光之護

聖光之護

发布时间:2026-03-18 15:39:21

|

927人浏览过

|

来源于php中文网

原创

Numpy 实现二维网格化点云均值统计(无显式循环)

本文介绍如何使用 NumPy 的 np.histogram2d 高效实现大规模 3D 点云在二维图像平面上的网格划分与每格内第三维(如灰度、深度等)的均值聚合,完全避免 Python for 循环,性能提升可达 10 倍以上。

本文介绍如何使用 numpy 的 `np.histogram2d` 高效实现大规模 3d 点云在二维图像平面上的网格划分与每格内第三维(如灰度、深度等)的均值聚合,完全避免 python for 循环,性能提升可达 10 倍以上。

在计算机视觉、点云处理或科学计算中,常需将散乱的 3D 点(如 (x, y, value))按二维空间划分为规则网格,并对每个网格单元内所有点的第三维属性(如强度、温度、深度值)求均值。传统做法依赖嵌套 for 循环或布尔索引 + 列表推导,虽逻辑清晰但效率低下,尤其在百万级点规模下成为瓶颈。

幸运的是,NumPy 提供了专为该类“加权二维直方图统计”设计的函数:np.histogram2d。它不仅能统计落入各 bin 的点数(即频次),还可通过 weights 参数对每个点赋予权重(此处即 z 值),从而一步完成加权和计数的并行计算——这正是计算均值所需的两个核心量。

✅ 核心实现(全向量化,零 Python 循环)

import numpy as np

# 示例数据:100 万个 (x, y, z) 点,x∈[0,2), y∈[0,5), z∈[0,1)
points_range = np.array([2.0, 5.0, 1.0])
points = np.random.random((1_000_000, 3)) * points_range

# 定义网格分辨率
x_steps, y_steps = 15, 15
x_bins = np.linspace(0, points_range[0], x_steps + 1)  # x 轴分界点,长度 x_steps+1
y_bins = np.linspace(0, points_range[1], y_steps + 1)  # y 轴分界点,长度 y_steps+1
edges = (x_bins, y_bins)

# 第一步:计算每个网格内 z 值的加权和(weights=points[:,2])
sums, _, _ = np.histogram2d(
    points[:, 0], points[:, 1],
    bins=edges,
    weights=points[:, 2]
)

# 第二步:计算每个网格内的点数量(即频次)
counts, _, _ = np.histogram2d(
    points[:, 0], points[:, 1],
    bins=edges
)

# 第三步:安全求均值(避免除零)→ 使用 np.where
means = np.where(counts > 0, sums / counts, 0.0)

✅ 输出 means 是形状为 (x_steps, y_steps) 的二维数组,means[i, j] 即第 i 列、第 j 行(对应 x 区间 [i·Δx, (i+1)·Δx), y 区间 [j·Δy, (j+1)·Δy))内所有点 z 值的算术平均。

百灵大模型
百灵大模型

蚂蚁集团自研的多模态AI大模型系列

下载

⚠️ 关键注意事项

  • 坐标范围必须匹配 edges:np.histogram2d 默认丢弃超出 edges 范围的点(即 x < 0 或 x ≥ points_range[0] 等)。确保你的 points[:, :2] 已归一化或裁剪至 [0, points_range[0]) × [0, points_range[1]) 区间;否则需预处理或设置 range= 参数。
  • bin 边界是左闭右开:[edge[i], edge[i+1]),与原始循环逻辑完全一致,无需额外偏移。
  • 内存友好:histogram2d 内部基于 C 实现,时间复杂度 O(N),空间复杂度 O(X×Y),远优于布尔索引(后者会临时生成大小为 N×X×Y 的掩码)。
  • 扩展性强:若需其他聚合(如最大值、标准差),可结合 scipy.ndimage 的 map_coordinates 或使用 numpy_indexed 库;但均值场景下 histogram2d 是最简洁、最高效的标准解。

? 性能对比(10M 点,15×15 网格)

方法 耗时(秒) 特点
原始双层 for 循环 ~37.8 可读性高,性能最差
优化版单循环 ~14.9 减少 Python 开销
混合布尔索引 ~16.5 向量化部分操作,仍含循环
histogram2d 全向量化 ~1.14 ✅ 推荐:极致性能 + 简洁代码

✅ 总结

用 np.histogram2d(..., weights=z_values) 替代手动循环或布尔索引,是解决“按二维区间聚合第三维属性”问题的标准 NumPy 范式。它兼具高性能、高可读性与强鲁棒性,是数据科学与工程实践中值得熟练掌握的核心技巧。只需三行核心代码,即可将耗时数十秒的操作压缩至 1 秒内,真正体现向量化计算的力量。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

779

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

695

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

784

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

890

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1564

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

598

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

591

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

759

2023.08.11

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

3

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号