matlab练习程序(点云下采样)
生活随笔
收集整理的這篇文章主要介紹了
matlab练习程序(点云下采样)
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
點(diǎn)云處理有時(shí)因?yàn)閿?shù)據(jù)量太大,我們需要對(duì)其進(jìn)行下采樣。
這里的方法是先將點(diǎn)云填入固定大小的三維網(wǎng)格中,然后每個(gè)網(wǎng)格中選一個(gè)點(diǎn)生成新的點(diǎn)云。
新點(diǎn)云即為下采樣后的點(diǎn)云。
這里使用斯坦福兔子作為測(cè)試點(diǎn)云。
小兔子pcd下載地址。
原始點(diǎn)云:
采樣后點(diǎn)云:
matlab代碼如下:
clear all; close all; clc;pc = pcread('rabbit.pcd'); pcshow(pc);pc_point = pc.Location; xlimit = pc.XLimits; ylimit = pc.YLimits; zlimit = pc.ZLimits;cellsize = 0.005; %定義網(wǎng)格大小 %設(shè)置網(wǎng)格數(shù)量 W = floor((xlimit(2) - xlimit(1))/cellsize)+1; H = floor((ylimit(2) - ylimit(1))/cellsize)+1; D = floor((zlimit(2) - zlimit(1))/cellsize)+1;%向網(wǎng)格里填數(shù) voxel = cell(W,H,D); for i =1:length(pc_point)I = floor((pc_point(i,1)-xlimit(1))/cellsize)+1;J = floor((pc_point(i,2)-ylimit(1))/cellsize)+1;K = floor((pc_point(i,3)-zlimit(1))/cellsize)+1;voxel{I,J,K} = [voxel{I,J,K};pc_point(i,:)]; end%以網(wǎng)格中第一個(gè)點(diǎn)對(duì)原點(diǎn)云進(jìn)行下采樣 pointre =[]; for i=1:Wfor j=1:Hfor k=1:Dif isempty(voxel{i,j,k})==0pointre=[pointre;voxel{i,j,k}(1,:)];endendend end pcre = pointCloud(pointre);figure; pcshow(pcre);總結(jié)
以上是生活随笔為你收集整理的matlab练习程序(点云下采样)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Matlab 2015a 中 point
- 下一篇: matlab练习程序(点云表面法向量)