Spaces:
Runtime error
Runtime error
File size: 2,438 Bytes
da48dbe 487ee6d da48dbe |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
cimport cython
from cython.view cimport array as cvarray
from libc.math cimport ceil, floor
cdef extern from "tribox2.h":
int triBoxOverlap(float boxcenter[3], float boxhalfsize[3],
float tri0[3], float tri1[3], float tri2[3])
@cython.boundscheck(False) # Deactivate bounds checking
@cython.wraparound(False) # Deactivate negative indexing.
cpdef int voxelize_mesh_(bint[:, :, :] occ, float[:, :, ::1] faces):
assert(faces.shape[1] == 3)
assert(faces.shape[2] == 3)
n_faces = faces.shape[0]
cdef int i
for i in range(n_faces):
voxelize_triangle_(occ, faces[i])
@cython.boundscheck(False) # Deactivate bounds checking
@cython.wraparound(False) # Deactivate negative indexing.
cpdef int voxelize_triangle_(bint[:, :, :] occupancies, float[:, ::1] triverts):
cdef int bbox_min[3]
cdef int bbox_max[3]
cdef int i, j, k
cdef float boxhalfsize[3]
cdef float boxcenter[3]
cdef bint intersection
boxhalfsize[:] = (0.5, 0.5, 0.5)
for i in range(3):
bbox_min[i] = <int> (
min(triverts[0, i], triverts[1, i], triverts[2, i])
)
bbox_min[i] = min(max(bbox_min[i], 0), occupancies.shape[i] - 1)
for i in range(3):
bbox_max[i] = <int> (
max(triverts[0, i], triverts[1, i], triverts[2, i])
)
bbox_max[i] = min(max(bbox_max[i], 0), occupancies.shape[i] - 1)
for i in range(bbox_min[0], bbox_max[0] + 1):
for j in range(bbox_min[1], bbox_max[1] + 1):
for k in range(bbox_min[2], bbox_max[2] + 1):
boxcenter[:] = (i + 0.5, j + 0.5, k + 0.5)
intersection = triBoxOverlap(&boxcenter[0], &boxhalfsize[0],
&triverts[0, 0], &triverts[1, 0], &triverts[2, 0])
occupancies[i, j, k] |= intersection
@cython.boundscheck(False) # Deactivate bounds checking
@cython.wraparound(False) # Deactivate negative indexing.
cdef int test_triangle_aabb(float[::1] boxcenter, float[::1] boxhalfsize, float[:, ::1] triverts):
assert(boxcenter.shape[0] == 3)
assert(boxhalfsize.shape[0] == 3)
assert(triverts.shape[0] == triverts.shape[1] == 3)
# print(triverts)
# Call functions
cdef int result = triBoxOverlap(&boxcenter[0], &boxhalfsize[0],
&triverts[0, 0], &triverts[1, 0], &triverts[2, 0])
return result
|