Skip to content

Commit

Permalink
bugfix in cotcurv laplacian loss. closes #551 (#553)
Browse files Browse the repository at this point in the history
Summary: Pull Request resolved: #553

Reviewed By: theschnitz

Differential Revision: D26257591

Pulled By: gkioxari

fbshipit-source-id: 899a3f733a77361e8572b0900a34b55764ff08f2
  • Loading branch information
shubham-goel authored and facebook-github-bot committed Feb 11, 2021
1 parent 17468e2 commit e13e63a
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 4 deletions.
3 changes: 2 additions & 1 deletion pytorch3d/loss/mesh_laplacian_smoothing.py
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,7 @@ def mesh_laplacian_smoothing(meshes, method: str = "uniform"):
idx = norm_w > 0
norm_w[idx] = 1.0 / norm_w[idx]
else:
L_sum = torch.sparse.sum(L, dim=1).to_dense().view(-1, 1)
norm_w = 0.25 * inv_areas
else:
raise ValueError("Method should be one of {uniform, cot, cotcurv}")
Expand All @@ -117,7 +118,7 @@ def mesh_laplacian_smoothing(meshes, method: str = "uniform"):
elif method == "cot":
loss = L.mm(verts_packed) * norm_w - verts_packed
elif method == "cotcurv":
loss = (L.mm(verts_packed) - verts_packed) * norm_w
loss = (L.mm(verts_packed) - L_sum * verts_packed) * norm_w
loss = loss.norm(dim=1)

loss = loss * weights
Expand Down
7 changes: 4 additions & 3 deletions tests/test_mesh_laplacian_smoothing.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,11 +89,12 @@ def laplacian_smoothing_naive_cot(meshes, method: str = "cot"):
inv_areas[idx] = 1.0 / inv_areas[idx]

norm_w = L.sum(dim=1, keepdims=True)
L_sum = norm_w.clone()
idx = norm_w > 0
norm_w[idx] = 1.0 / norm_w[idx]

if method == "cotcurv":
loss = (L.mm(verts_packed) - verts_packed) * inv_areas * 0.25
loss = (L.mm(verts_packed) - L_sum * verts_packed) * inv_areas * 0.25
loss = loss.norm(dim=1)
else:
loss = L.mm(verts_packed) * norm_w - verts_packed
Expand Down Expand Up @@ -147,7 +148,7 @@ def test_laplacian_smoothing_uniform(self):

def test_laplacian_smoothing_cot(self):
"""
Test Laplacian Smoothing with uniform weights.
Test Laplacian Smoothing with cot weights.
"""
meshes = TestLaplacianSmoothing.init_meshes(10, 100, 300)

Expand All @@ -161,7 +162,7 @@ def test_laplacian_smoothing_cot(self):

def test_laplacian_smoothing_cotcurv(self):
"""
Test Laplacian Smoothing with uniform weights.
Test Laplacian Smoothing with cotcurv weights.
"""
meshes = TestLaplacianSmoothing.init_meshes(10, 100, 300)

Expand Down

0 comments on commit e13e63a

Please sign in to comment.