readme.md 2.62 KB
Newer Older
ashawkey's avatar
init  
ashawkey committed
1
2
3
4
5
6
# cuBVH

A CUDA Mesh BVH acceleration toolkit.

### Install

ashawkey's avatar
ashawkey committed
7
```bash
ashawkey's avatar
ashawkey committed
8
9
10
pip install git+https://github.com/ashawkey/cubvh

# or locally
ashawkey's avatar
ashawkey committed
11
git clone --recursive https://github.com/ashawkey/cubvh
ashawkey's avatar
init  
ashawkey committed
12
13
14
cd cubvh
pip install .
```
ashawkey's avatar
ashawkey committed
15
It will take several minutes to build the CUDA dependency.
ashawkey's avatar
init  
ashawkey committed
16

kiui's avatar
kiui committed
17
#### Trouble Shooting
18
19
20
21
22
23
24
25
**`fatal error: eigen/matrix.h: No such file or directory`**

This is a known issue for `torch==2.1.0` and `torch==2.1.1` (https://github.com/pytorch/pytorch/issues/112841). 
To patch up these two versions, clone this repository, and copy `patch/eigen` to your pytorch include directory:
```bash
# for example, if you are using anaconda (assume base env)
cp -r patch/eigen ~/anaconda3/lib/python3.9/site-packages/torch/include/pybind11/
```
kiui's avatar
kiui committed
26

ashawkey's avatar
ashawkey committed
27
28
29
30
31
32
**`fatal error: Eigen/Dense: No such file or directory`**

Please make sure [`eigen >= 3.3`](https://eigen.tuxfamily.org/index.php?title=Main_Page) is installed. 
We have included it as a submodule in this repository, but you can also install it in your system include path.
(For example, ubuntu systems can use `sudo apt install libeigen3-dev`.)

ashawkey's avatar
init  
ashawkey committed
33
34
35
36
37
38
### Usage

```python
import numpy as np
import trimesh
import torch
ashawkey's avatar
ashawkey committed
39

ashawkey's avatar
init  
ashawkey committed
40
41
import cubvh

ashawkey's avatar
ashawkey committed
42
### build BVH from mesh
ashawkey's avatar
init  
ashawkey committed
43
mesh = trimesh.load('example.ply')
ashawkey's avatar
ashawkey committed
44
# NOTE: you need to normalize the mesh first, since the max distance is hard-coded to 10.
ashawkey's avatar
init  
ashawkey committed
45
46
BVH = cubvh.cuBVH(mesh.vertices, mesh.faces) # build with numpy.ndarray/torch.Tensor

ashawkey's avatar
ashawkey committed
47
### query ray-mesh intersection
ashawkey's avatar
init  
ashawkey committed
48
rays_o, rays_d = get_ray(pose, intrinsics, H, W) # [N, 3], [N, 3], query with torch.Tensor (cuda)
ashawkey's avatar
ashawkey committed
49
intersections, face_id, depth = BVH.ray_trace(rays_o, rays_d) # [N, 3], [N,], [N,]
ashawkey's avatar
init  
ashawkey committed
50

ashawkey's avatar
ashawkey committed
51
### query unsigned distance
ashawkey's avatar
init  
ashawkey committed
52
points # [N, 3]
ashawkey's avatar
ashawkey committed
53
# uvw is the barycentric corrdinates of the closest point on the closest face (None if `return_uvw` is False).
ashawkey's avatar
init  
ashawkey committed
54
distances, face_id, uvw = BVH.unsigned_distance(points, return_uvw=True) # [N], [N], [N, 3]
ashawkey's avatar
ashawkey committed
55

ashawkey's avatar
ashawkey committed
56
### query signed distance (INNER is NEGATIVE!)
ashawkey's avatar
ashawkey committed
57
58
59
60
# for watertight meshes (default)
distances, face_id, uvw = BVH.signed_distance(points, return_uvw=True, mode='watertight') # [N], [N], [N, 3]
# for non-watertight meshes:
distances, face_id, uvw = BVH.signed_distance(points, return_uvw=True, mode='raystab') # [N], [N], [N, 3]
ashawkey's avatar
init  
ashawkey committed
61
62
63
```


ashawkey's avatar
ashawkey committed
64
65
66
67
68
69
70
71
72
73
Example for a mesh normal renderer by `ray_trace`:

```bash
python test/renderer.py # default, show a dodecahedron
python test/renderer.py --mesh example.ply # show any mesh file
```

https://user-images.githubusercontent.com/25863658/183238748-7ac82808-6cd3-4bb6-867a-9c22f8e3f7dd.mp4


ashawkey's avatar
init  
ashawkey committed
74
75
76
### Acknowledgement

* Credits to [Thomas Müller](https://tom94.net/)'s amazing [tiny-cuda-nn](https://github.com/NVlabs/tiny-cuda-nn) and [instant-ngp](https://github.com/NVlabs/instant-ngp)!