-
Notifications
You must be signed in to change notification settings - Fork 328
/
compute_edge_face_ring.py
46 lines (35 loc) · 1.29 KB
/
compute_edge_face_ring.py
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
import numpy as np
from scipy import sparse
def compute_edge_face_ring(faces):
"""
compute_edge_face_ring - compute faces adjacent to each edge
e2f = compute_edge_face_ring(faces);
e2f(i,j) and e2f(j,i) are the number of the two faces adjacent to
edge (i,j).
Copyright (c) 2007 Gabriel Peyre
"""
n = np.max(faces)+1
m = np.shape(faces)[1]
i = np.hstack((faces[0,:],faces[1,:],faces[2,:]))
j = np.hstack((faces[1,:],faces[2,:],faces[0,:]))
s = np.hstack((np.arange(0,m),np.arange(0,m),np.arange(0,m)))
# first without duplicate
tmp,I = np.unique(i + (np.max(i) + 1)*j, return_index=True)
# remaining items
J = np.setdiff1d(np.arange(0,len(s)),I)
# flip the duplicates
i1 = np.hstack((i[I],j[J]))
j1 = np.hstack((j[I],i[J]))
s = np.hstack((s[I],s[J]))
# remove doublons
tmp,I = np.unique(i1 + (np.max(i1) + 1)*j1, return_index=True)
i1 = i1[I]
j1 = j1[I]
s = s[I]
A = sparse.coo_matrix((s+1,(i1,j1)),shape=(n,n)) #s+1 b/c indices from zero in python
# add missing points
B = A.toarray()
I = np.where(np.ravel(np.transpose(B)) !=0)[0]
J = np.where(np.ravel(B)[I] == 0)[0]
np.ravel(B)[I[J]] = -1
return sparse.coo_matrix(B)