Spaces:
Building
Building
# Copyright (c) Meta Platforms, Inc. and affiliates. | |
# This source code is licensed under the MIT license found in the | |
# LICENSE file in the root directory of this source tree. | |
import numpy as np | |
from animated_drawings.model.arap import ARAP, plot_mesh | |
def test_single_triangle_mesh(): | |
show_plots = False # Make true if you'd like to see mesh viz during test run | |
vertices = np.array([ | |
[2.0, 2.0], | |
[3.0, 3.0], | |
[4.0, 2.0] | |
]) | |
triangles = np.array([ | |
[0, 1, 2] | |
], np.int32) | |
pins_xy = np.array([[2.0, 2.0], [4.0, 2.0]]) | |
if show_plots: | |
plot_mesh(vertices, triangles, pins_xy) | |
arap = ARAP(pins_xy, triangles=triangles, vertices=vertices) | |
pins_xy = np.array([[-5.0, 0.0], [5.0, 0.0]]) | |
v = arap.solve(pins_xy) | |
if show_plots: | |
plot_mesh(v, triangles, pins_xy) | |
assert np.isclose(v, np.array([ | |
[-5.0, 0.0], | |
[0.0, 1.0], | |
[5.0, 0.0] | |
])).all() | |
def test_two_triangle_mesh(): | |
show_plots = False # Make true if you'd like to see mesh viz during test run | |
vertices = np.array([ | |
[1.0, 0.0], | |
[1.0, 1.0], | |
[2.0, 1.0], | |
[2.0, 0.0], | |
]) | |
triangles = np.array([ | |
[0, 1, 2], | |
[0, 2, 3], | |
], np.int32) | |
pins_xy = np.array([[1.0, 0.0], [2.0, 0.0]]) | |
new = ARAP(pins_xy, triangles=triangles, vertices=vertices) | |
if show_plots: | |
plot_mesh(vertices, triangles, pins_xy) | |
pins_xy = np.array([[1.0, 0.0], [1.7, 0.7]]) | |
v = new.solve(pins_xy) | |
if show_plots: | |
plot_mesh(v, triangles, pins_xy) | |
assert np.isclose(v, np.array([ | |
[9.99999989e-01, -1.13708135e-08], | |
[2.91471856e-01, 7.05685418e-01], | |
[9.97157285e-01, 1.41137085e+00], | |
[1.70000001e+00, 7.00000011e-01] | |
])).all() | |
def test_four_triangle_mesh(): | |
show_plots = False # Make true if you'd like to see mesh viz during test run | |
vertices = np.array([ | |
[0.0, 0.0], | |
[0.0, 1.0], | |
[1.0, 1.0], | |
[1.0, 0.0], | |
[2.0, 1.0], | |
[2.0, 0.0], | |
[0.0, 2.0], | |
[1.0, 2.0], | |
[2.0, 2.0], | |
]) | |
triangles = np.array([ | |
[0, 1, 2], | |
[0, 2, 3], | |
[3, 2, 4], | |
[3, 4, 5], | |
[1, 6, 7], | |
[1, 7, 2], | |
[2, 7, 8], | |
[2, 8, 4] | |
], np.int32) | |
pins_xy = np.array([[0.0, 0.0], [0.0, 2.0], [2.0, 0.0]]) | |
if show_plots: | |
plot_mesh(vertices, triangles, pins_xy) | |
new = ARAP(pins_xy, triangles=triangles, vertices=vertices) | |
new_pins_xy = np.array([[0.0, 0.0], [0.0, 3.0], [6.0, 0.0]]) | |
v = new.solve(new_pins_xy) | |
if show_plots: | |
plot_mesh(v, triangles, new_pins_xy) | |
assert np.isclose(v, np.array([ | |
[3.19325865e-06, 1.08194488e-06], | |
[6.78428061e-01, 1.37166545e+00], | |
[2.14606263e+00, 1.19790398e+00], | |
[2.81917351e+00, 1.12790606e-02], | |
[3.95163838e+00, 1.34725960e+00], | |
[5.99999596e+00, 5.51801260e-07], | |
[8.44193478e-07, 2.99999837e+00], | |
[1.46633111e+00, 2.60720416e+00], | |
[2.82413859e+00, 2.62209072e+00] | |
])).all() | |