MATLAB 도움말 센터
Find points in or on surface of geometric model
Since R2024a
indices = findPointsInModel(model,ptCloud)
indices = findPointsInModel(model,ptCloud) finds the points in the point cloud ptCloud that are located inside or on the surface of the geometric shape specified by model, and returns their linear indices.
indices
model
ptCloud
example
collapse all
Load a MAT file containing point cloud data into the workspace.
load("object3d.mat")
Visualize the point cloud.
figure pcshow(ptCloud)
Define a region of interest (ROI) in the point cloud in which to detect a cylinder model.
roi = [0.4 0.7; -0.1 0.2; 0 0.4]; sampleIndices = findPointsInROI(ptCloud,roi);
Set a maximum point-to-cylinder distance of 5 mm for cylinder fitting and the orientation constraint.
maxDistance = 0.005; referenceVector = [0 0 1];
Detect a cylinder in the point cloud.
model = pcfitcylinder(ptCloud,maxDistance,referenceVector, ... SampleIndices=sampleIndices);
Create a synthetic point cloud that is evenly distributed and covers the region of interest.
gridStep = 0.005; [x,y,z] = meshgrid(roi(1,1):gridStep:roi(1,2),roi(2,1):gridStep:roi(2,2), ... roi(3,1):gridStep:roi(3,2)); syntheticPtCloud = pointCloud([x(:) y(:) z(:)],Color=[0.7 0.7 0.8]);
Find the points in the synthetic point cloud that are in the cylinder.
idx = findPointsInModel(model,syntheticPtCloud); cylinderPtCloud = select(syntheticPtCloud,idx);
Visualize the resulting point cloud, with the synthetic points in the cylinder modeling the object on the table.
figure pcshow(cylinderPtCloud) hold on pcshow(ptCloud)
Load a MAT file containing a point cloud into the workspace.
Define a region of interest (ROI) in the point cloud in which to detect a sphere model.
roi = [0.2 0.55; 0.2 0.5; 0 0.5]; sampleIndices = findPointsInROI(ptCloud,roi);
Set a maximum point-to-sphere distance of 5mm for sphere fitting.
maxDistance = 0.005;
Detect the sphere in the point cloud.
[model,inlierIdx] = pcfitsphere(ptCloud,maxDistance,SampleIndices=sampleIndices);
Find one of the colors in the detected sphere, to use for the synthetic point cloud.
inlierPtCloud = select(ptCloud,inlierIdx); color = median(inlierPtCloud.Color);
gridStep = 0.005; [x,y,z] = meshgrid(roi(1,1):gridStep:roi(1,2),roi(2,1):gridStep:roi(2,2), ... roi(3,1):gridStep:roi(3,2)); syntheticPtCloud = pointCloud([x(:) y(:) z(:)],Color=color);
Find the points in the synthetic point cloud that are in the sphere.
idx = findPointsInModel(model,syntheticPtCloud); spherePtCloud = select(syntheticPtCloud,idx);
Visualize the resulting point cloud, with the synthetic points in the sphere modeling the object on the table.
figure pcshow(spherePtCloud) hold on pcshow(ptCloud)
cylinderModel
sphereModel
Parametric model, specified as a cylinderModel or sphereModel object.
pointCloud
Point cloud in the sensor coordinate system, specified as a pointCloud object.
Linear indices of the point cloud points that are located inside or on the surface of the model, returned as a column vector.
Introduced in R2024a
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
웹사이트 선택
번역된 콘텐츠를 보고 지역별 이벤트와 혜택을 살펴보려면 웹사이트를 선택하십시오. 현재 계신 지역에 따라 다음 웹사이트를 권장합니다:
또한 다음 목록에서 웹사이트를 선택하실 수도 있습니다.
사이트 성능 최적화 방법
최고의 사이트 성능을 위해 중국 사이트(중국어 또는 영어)를 선택하십시오. 현재 계신 지역에서는 다른 국가의 MathWorks 사이트 방문이 최적화되지 않았습니다.
미주
유럽
아시아 태평양
지역별 지사에 문의