-
Notifications
You must be signed in to change notification settings - Fork 592
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
faster trimesh.proximity.closest_point for large query point sets #1116
Comments
added an issue on the rtree repo Toblerity/rtree#178 |
Agreed, vectorizing |
tried https://pypi.org/project/pysdf/ that is amazingly fast.
pysdf does not return the nearest face index for each point but could probably be modified to do that, in which case it could maybe be used a a dependency to accelerate trimesh's function |
Whoa that is awesome! Yeah possibly some packaging work to do to get that included as a dep but really impressive results. |
I figured the distance computed by pysdf is actually approximate as, according to the readme it computes "only distance to faces adjacent to nearest neighbors". For each point it searches for the nearest vertex and then enumerate only the adjacent faces as face candidates for the nearest face. |
The module python-prtree has been recently improved to implements a rtree on 3d data . The code is in C++ with pybind11 binding that provide a vectorized interface . It could be good alternative to Toblerity/rtree. |
@mikedh Do you plan to implement/add https://github.com/atksh/python_prtree or a similar solution to trimesh? It would be very nice to use this function to analyze huge 3D point clouds. Unfortunately, my programming skills are not good enough to implement it myself. |
@kickd0wn If you are still looking for something faster you can use
|
One more suggestion, with open3d: import open3d as o3d
scene = o3d.t.geometry.RaycastingScene()
scene.add_triangles(o3d.t.geometry.TriangleMesh.from_legacy(mesh.as_open3d))
ret_dict = scene.compute_closest_points(o3d.core.Tensor.from_numpy(coords.astype(np.float32))) |
Oh nice, also should we update |
Thank you for this amazing library.
I would like to compute the distance of a large number of point to a relatively simple mesh.
I am using
trimesh.proximity.closest_point
, but unfortunately it is quit slow : it takes 30 second when querying 500000 points on my machine.One major bottleneck seem to be the line
candidates = [list(rtree.intersection(b)) for b in bounds]
inproximity.py
.I believe this could run much faster if the loop was implemented in
c++
. Ideally rtree.intersection would accept a list of boxes and implement the loop in c++ and return the list of list of candidates (similarly toscipy.spatial.KDTree.query_ball_point
), but that does not seem supported by rtree.Here is the code I use to get some timings
I get this timings
trimesh.proximity.closest_point wit 1000 points took 0.11966729164123535 seconds
trimesh.proximity.closest_point wit 10000 points took 0.6350014209747314 seconds
trimesh.proximity.closest_point wit 100000 points took 6.338748455047607 seconds
trimesh.proximity.closest_point wit 500000 points took 32.05847191810608 seconds
It would be great if we could list the potential ways we could accelerate the function. I looked at alternative libararies available from python to do the nearest points query but did not find a good alternative yet.
The text was updated successfully, but these errors were encountered: