机器学习之利用k-means算法对点云数据进行目标分割,提取其中的建筑物、房屋等

本文主要是介绍机器学习之利用k-means算法对点云数据进行目标分割,提取其中的建筑物、房屋等,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原始点云数据在CloudCompare的显示如下:

  利用k-means算法提取出其中的建筑物、房屋等,我这里的代码是根据k-means算法的原理编写的代码,这样有助于大家对k-means算法的运行原理有一个深层次的了解,当然也可以直接调用sklearn里的算法,但是那样的话对于将来发展是不利的,毕竟知道算法的原理并根据原理编写代码学到的知识还是更多一些的。

代码如下:

#Author ZTY
import csv
import numpy as np
def kmean(x,k,maxtimes):m,n = np.shape(x)# 建立一个比数据集多一列的零矩阵,多的一列用来存放标签dataset = np.zeros([m,n+1])dataset[:,:-1] = x#根据要聚类的数量,初始化相应数量的中心点,可以随机选择n个,也可以选前n个作为初始点#middle = dataset[np.random.randint(m,size=k),:]middle = dataset[0:3,:]#为选定的中心点赋予标签middle[:,-1] = range(1,k+1)times = 0oldmiddle = None#迭代更新中心点时,判断何时停止while not shouldstop(oldmiddle,middle,times,maxtimes):print('times:',times)print('dataset:',dataset)print('middle:',middle)oldmiddle = np.copy(middle)times = times + 1#根据中心点,更新其他各个点的标签update(dataset,middle)#获取新的中心点middle = getmiddles(dataset,k)return datasetdef shouldstop(oldmiddle,middle,times,maxtimes):if times > maxtimes:return Truereturn np.array_equal(oldmiddle,middle)def update(dataset,middle):m,n =dataset.shapefor i in range(0,m):dataset[i,-1] = getLabelFromCloestCentroid(dataset[i,:-1],middle)#找出各个点距离最近的中心点,将中心点的标签赋予当前点
def getLabelFromCloestCentroid(datasetRow,middle):label = middle[0,-1]minDist = np.linalg.norm(datasetRow - middle[0,:-1])#np.linalg.norm(a-b)用来计算a,b两点之间的距离,a.b如果是list,必须要np.array(a)进行格式转换for i in range(1,middle.shape[0]):dist = np.linalg.norm(datasetRow - middle[i,:-1])if dist < minDist:minDist = distlabel = middle[i,-1]print('minDist',minDist)print('label',label)return labeldef getmiddles(datatset,k):result = np.zeros((k,datatset.shape[1]))for i in range(1,k+1):oneCluster = datatset[datatset[:,-1]==i,:-1]result[i-1,:-1] = np.mean(oneCluster,axis=0)result[i-1,-1] = ireturn resultfile = open(r'全部点云数据.csv','r')
reader = csv.reader(file)
reader = list(reader)
m,n = np.shape(reader)
for i in range(0,m):for j in range(0,3):#转换数据类型reader[i][j] = float(reader[i][j])
m,n = np.shape(reader)
list1 = np.zeros([m,2])
for i in range(0,m):for j in range(2,4):#获取数据的z指与强度值list1[i][j-2] = reader[i][j]# x = np.vstack((a,b,c,d))
result = kmean(list1,3,10)
print('result:',result[0])
print(reader[0])
reader0 = np.zeros([m,5])
for i in range(0,m):for j in range(0,4):reader0[i][j] = reader[i][j]
for i in range(0,m):reader0[i][-1] = int(result[i][-1])
print(reader0)w1=open("1.txt","w")
w2=open("2.txt","w")
w3=open("3.txt","w")
w4=open("4.txt","w")for i in range(m):if(reader0[i][-1]==1):w1.write("%s %s %s %s\n"%(reader0[i][0],reader0[i][1],reader0[i][2],reader0[i][3]))if(reader0[i][-1]==2):w2.write("%s %s %s %s\n" % (reader0[i][0], reader0[i][1], reader0[i][2],reader0[i][3]))if (reader0[i][-1] ==3):w3.write("%s %s %s %s\n" % (reader0[i][0], reader0[i][1], reader0[i][2],reader0[i][3]))if (reader0[i][-1] == 4):w4.write("%s %s %s %s\n" % (reader0[i][0], reader0[i][1], reader0[i][2],reader0[i][3]))

  以上代码将k值设置为4,也就是将点云聚成4类。输出为4个txt数据,加载进软件,效果图如下,分别是提取的道路,建筑物:

还是利用上述代码,将道路数据放进代码,将K设置为2,可以将道路数据聚类为两类,提取出道路的主干和边界:

PS:附上数据链接  https://download.csdn.net/download/qq_39343904/10863193

 

 

这篇关于机器学习之利用k-means算法对点云数据进行目标分割,提取其中的建筑物、房屋等的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/523270

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十