python之点云数据读取与可视化

news2025/1/10 11:40:45

1、前言

      将文件中点云数据进行读取进来,并进行数据处理,将处理后的点云数据进行可视化显示,是非常常见的操作。本博客介绍如何将文本形式的点云数据读取进来,并进行可视化展示。

2、点云可视化

      点云可视化即将点云数据在三维空间中进行可视化,用于展示算法效果。按照点显示的界面,分为单一窗口可视化、多窗口可视化。

2.1 单一窗口可视化

       将点云数据读取进来,使用可视化三方库matplotlib,代码如下:

      其中下面两句,防止汉字乱码

    plt.rcParams['font.sans-serif'] = ['SimHei']  # 使用黑体
    plt.rcParams['axes.unicode_minus'] = False  # 正确显示负号

import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['SimHei']  # 使用黑体
plt.rcParams['axes.unicode_minus'] = False  # 正确显示负号

with open('E:\\testdata01.txt', 'r') as file:
    # 初始化一个列表来存储所有的点
    points = []

    # 逐行读取数据
    for line in file:
        # 去除行尾的换行符并分割字符串
        x, y, z, L = line.strip().split()
        # 将字符串转换为浮点数
        x = float(x)
        y = float(y)
        # 将点添加到列表中
        points.append((x, y))

plt.scatter(*zip(*points), marker='o', color='blue',s=5)#设置点的大小、颜色
plt.title("点云1可视化")
plt.xlabel("x轴")
plt.ylabel("y轴")

         点云可视化结果如下:

单窗口可视化

2.2 多窗口可视化

      有时候,为了方便,需要将不同点云,在不同窗口中同时显示,即多个窗口显示结果,那么只要执行命令figure()即可。如下所示,将同一点云,在两个窗口中进行显示,但对点云大小、颜色进行了不同设置。

import matplotlib.pyplot as plt
import numpy as np
from scipy.spatial import KDTree
plt.rcParams['font.sans-serif'] = ['SimHei']  # 使用黑体
plt.rcParams['axes.unicode_minus'] = False  # 正确显示负号

with open('E:\\testdata01.txt', 'r') as file:
    # 初始化一个列表来存储所有的点
    points = []

    # 逐行读取数据
    for line in file:
        # 去除行尾的换行符并分割字符串
        x, y, z, L = line.strip().split()
        # 将字符串转换为浮点数
        x = float(x)
        y = float(y)
        # 将点添加到列表中
        points.append((x, y))

plt.scatter(*zip(*points), marker='o', color='blue',s=5)
plt.title("点云1可视化")
plt.xlabel("x轴")
plt.ylabel("y轴")

plt.figure()
plt.scatter(*zip(*points), marker='o', color='red',s=5)
plt.title("点云2可视化")
plt.xlabel("x轴")
plt.ylabel("y轴")
plt.show()

      在两幅图中,左边图点颜色为蓝色,右边图为红色点;左边点明显大于右边。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1811636.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

GIGE 协议摘录 —— GVSP 协议(三)

系列文章目录 GIGE 学习笔记 GIGE 协议摘录 —— 设备发现(一) GIGE 协议摘录 —— GVCP 协议(二) GIGE 协议摘录 —— GVSP 协议(三) GIGE 协议摘录 —— 引导寄存器(四) GIGE 协议…

[图解]建模相关的基础知识-08

1 00:00:01,650 --> 00:00:04,950 如果说,A乘BB乘A的话 2 00:00:06,350 --> 00:00:07,140 意味着什么 3 00:00:07,560 --> 00:00:08,420 A就等于B了 4 00:00:09,500 --> 00:00:10,680 只有两个相等 5 00:00:10,690 --> 00:00:13,360 它们的笛卡尔…

回收站照片永久删除找回?教你六个简单恢复方法

误删回收站照片怎么恢复?在使用电脑的时候,经常会遇到一些重要的文件被误删,并在删除之后又执行了清空回收站的操作。对于熟知电脑操作的用户都知道,如果说清空了回收站,恢复的难度相对来讲要大出很多。 那么&#xf…

【Java】解决Java报错:FileNotFoundException

文章目录 引言1. 错误详解2. 常见的出错场景2.1 文件路径错误2.2 文件名拼写错误2.3 文件权限问题2.4 文件路径未正确拼接 3. 解决方案3.1 检查文件路径3.2 使用相对路径和类路径3.3 检查文件权限3.4 使用文件选择器 4. 预防措施4.1 使用配置文件4.2 使用日志记录4.3 使用单元测…

Java--Math类和Random类

1.Math类简介 1.Math类中提供了大量用于数学运算的相关方法。 2.Math类是使用final修饰的终结类,不能产生子类 3.Math类中的方法都是static修饰的静态方法,可以通过类名.方法名直接调用 2.Math常用方法 1.abs(int):求绝对值(int,long,floa…

5.1 系统模块划分探讨

一.指导思想 系统模块划分是指将一个系统按照功能或业务进行划分,以便于组织和管理系统的开发、维护和扩展。 一般来说,系统模块划分可以根据业务功能、技术层次和逻辑关系等方面进行。 二.理解业务领域 分析业务需求 要分析…

Java的一些补充性介绍

目录 什么是JDK,JRE 快速入门 学习路线: 如何快速掌握技术或知识点: IDEA 常用快捷键 IDEA创建项目、模块、包、类 模板/自定义模板 包 包的命名:​编辑 常用的包 如引入包 断点调试(debug)​编辑 多线程:…

西南交通大学【操作系统实验1】

实验目的 通过本实验了解Linux系统的组织和行为,观察各种存储系统状态信息的内核变量熟悉这些结构和信息 实验内容 理解Linux操作系统以及./proc文件熟悉codeblocks,学习Linux下c程序调试技术根据给定的程序观察cpuinfo/version/stat/uptime编程实现对…

泛微证券行业数据中心方案:打造多样化的数据收集、汇总、分析、决策一体化报表

证券企业在日常办公、业务开展时,涉及了诸多数据需求,而且数据来源于多部门、多个系统。需要对数据获取、汇总、展现进行高效、可视化的操作,高效利用数据价值,助力企业运营更高效、风险更可控。 泛微基于证券行业数字经营分析的需…

【Qt 学习笔记】Qt窗口 | 对话框 | 模态与非模态对话框的创建

博客主页:Duck Bro 博客主页系列专栏:Qt 专栏关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ Qt窗口 | 对话框 | 创建模态及非模态对话框 文章编号:Qt 学…

12个Console命令,让js调试更简单

Console 对象用于 JavaScript 调试。JavaScript 原生中默认是没有 Console 对象,这是宿主对象(也就是浏览器)提供的内置对象。 用于访问调试控制台, 在不同的浏览器里效果可能不同。 Console 对象常见的两个用途: 显示网页代码运…

SAP STO跨公司间转储含POD交货操作简介

STO跨公司间转储含POD交货这个业务常见于集团性的公司, 1、同一个集团下A公司和B公司都是独立的,A公司向B公司进行采购。B公司会有一张交货单,然后基于交货单进行过账,收货,开票等操作。 2、当同一个公司下不同工厂间…

微信支付,微信平台证书如何下载,如何获取平台证书 wxpay如何初次获取平台证书 java初次生成平台证书, java生成微信platform.pem

1. 场景:使用ijpay,调用获取平台证书失败。 属于初次获取平台证书。 注:做返回校验使用,不校验好像也没事,但是支付无小事,强烈建议获取平台证书,校验后做回调相关处理!!…

【iOS】YYModel源码阅读笔记

文章目录 前言一、JSON转换库对比二、YYModel性能优化三、YYModel的使用四、架构分析YYClassInfo 剖析 五、流程剖析转换前准备工作 – 将JSON统一成NSDictionary将NSDictionary 转换为Model对象提取Model信息使用NSDictionary的数据填充Model 总结 前言 先前写了JSONModel的源…

学习了解 JSON Schema

在数字时代,数据的快速增长要求开发者掌握有效的管理和验证技术。JSON(JavaScript Object Notation) 是一种流行的轻量级数据交换格式,在网络编程中有广泛应用。为了应对复杂数据的挑战,JSON Schema 诞生,提…

C++九州控制地址结构else 陈述

else如同英文字义,九州qa98錪cc否则的意思,通常放在if的后面,若if的条件为真,就执行if底下大括弧围起来的程式区块,若为假,就执行else底下大括弧围起来的程式区块。 形式如下: 这个概念用于二选…

PostgreSQL Schema管理基础

Postgresql schema是什么、为什么它们很重要以及如何使用schema(模式)使您的数据库实现更加健壮和可维护?本文将介绍 Postgresql 中schema的基础知识,并通过一些基本示例向您展示如何创建它们。未来的文章将深入探讨如何保护和使用实际应用程序schema的示…

[linux]基于Ubuntu24.04原内核6.8.0升级到6.9.0

物理机操作系统: 虚拟机操作系统: Ubuntu 24.04 下载地址: https://mirror.nju.edu.cn/ubuntu-releases/24.04/ubuntu-24.04-desktop-amd64.iso VM版本信息: 内核源代码来源: https://ftp.sjtu.edu.cn/sites/ftp.kern…

Open vSwitch 守护进程的 upcall 处理(re)

一、upcall 消息的类型 在 Open vSwitch 的数据包转发流程中,如果数据包在内核空间无法完全处理(比如匹配不到流表项),就会发生 upcall 调用,将数据包从内核空间的 Datapath 模块传输至用户空间的 ovs-vswitchd 守护进…

Mybatis源码解读

MyBatis是我们工作中常见的ORM持久层框架,对于MyBatis并不能仅仅局限于会使用的阶段,更需要了解它的工作原理,想要了解原理,源码是必须要读的,这篇文章是我个人在阅读MyBatis的源码过程中的一些简单的总结,…