Remove points from a mesh

I have a mesh of points intersecting a cone, and i want to remove all the points inside the conic surface and near to the limits of it. I can check whether the point is on the inside of the circumference slice of the cone for a given height but, this will take me a lot of time since the mesh has a lot of points. I was wondering if there is a better and faster way to do it.
Thank you.
coonno.PNG

 Accepted Answer

Adam Danz
Adam Danz on 4 Feb 2019
Edited: Adam Danz on 4 Feb 2019
If you know the parameters of the circle that encompasses the area you'd like to remove (ie, the center coordinates and the radius), you could just calculate the distance of all points to the circle's center and then eliminate all dots whose distance is less than the radius. This would work if all of the dots are on the same plane as the circle's center which appears to be the case.
Here's an example where x and y are the coordinates of your dots. c is the (x,y) center of your circle and r is the radius.
% create data
x = rand(1000,1);
y = rand(1000,1);
c = [.5, .5]; %[x,y] center of circle
r = 0.2; %radius
% Calculate distance to circle center
d = sqrt((x - c(1)).^2 + (y - c(2)).^2);
% find dots on/in circle
inCircleIdx = d <= r;
% remove dots on/in circle
x(inCircleIdx) = [];
y(inCircleIdx) = [];

3 Comments

Yes, thank you, that is a good idea. But the mesh is not always a plane, it can be a cube, sphere... So in that case it will be more complicated and will take me more time. I dont know if you have any other idea for when the mesh is different. Thank you.
For a 3D mesh, what are you aiming to remove? Everything to the left of the blue manifold?
There are several ways to determine if a point in 3D space is within a convex 3D object.
This file exchange submition inhull() combines matlab's delaunayn() with tsearchn() into one function. I haven't used the FEX but here's an example using the function separately.
% xyz are the coordinates of your cone manifold
T = delaunayn(xyz);
% xyzTestPoints are the coordinates you're testing
isIn = ~isnan(tsearchn(xyz,T,xyzTestPoints));
% isIn is a logical vector of points inside the 3D object

Sign in to comment.

More Answers (0)

Categories

Find more on Computational Geometry in Help Center and File Exchange

Asked:

on 4 Feb 2019

Commented:

on 4 Feb 2019

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!