From 671572ffad941c66b9090a0c9b397c00113903a1 Mon Sep 17 00:00:00 2001 From: Co Quach <43968221+daico007@users.noreply.github.com> Date: Tue, 29 Nov 2022 14:12:58 -0600 Subject: [PATCH] Fix bug related to `get_boundingbox()` (#1059) * Increase comparison tolerance when determining missing_dimension in get_bounbindingbox() * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> --- mbuild/compound.py | 5 +++-- mbuild/tests/test_compound.py | 15 ++++++++++----- 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/mbuild/compound.py b/mbuild/compound.py index e6e2001cd..c43799198 100644 --- a/mbuild/compound.py +++ b/mbuild/compound.py @@ -1450,7 +1450,8 @@ def get_boundingbox(self, pad_box=None): has_dimension = [True, True, True] if not is_one_particle: missing_dimensions = np.all( - np.isclose(self.xyz, self.xyz[0, :]), axis=0 + np.isclose(self.xyz, self.xyz[0, :], atol=1e-2), + axis=0, ) for i, truthy in enumerate(missing_dimensions): has_dimension[i] = not truthy @@ -1468,7 +1469,7 @@ def get_boundingbox(self, pad_box=None): # handle any missing dimensions (planar molecules) for i, dim in enumerate(has_dimension): if not dim: - vecs[i][i] = 1.0 + vecs[i][i] = 0.1 if pad_box is not None: if isinstance(pad_box, (int, float, str, Sequence)): diff --git a/mbuild/tests/test_compound.py b/mbuild/tests/test_compound.py index 5e955e906..4cff0e943 100644 --- a/mbuild/tests/test_compound.py +++ b/mbuild/tests/test_compound.py @@ -1789,12 +1789,14 @@ def test_get_boundingbox_extrema(self): h2.pos = [0.07590747, -0.00182889, -0.00211742] container = mb.Compound([h1, h2]) distances = container.maxs - container.mins - with pytest.raises( - MBuildError, match=r"The vectors to define the box are co\-linear\," - ): - container.get_boundingbox() + # Behavior changed due to new co-linear tolerance define in Compound.get_boundingbox() + assert container.get_boundingbox() + distance_list = [val for val in distances] - distance_list = [val + 1.0 for val in distance_list] + for i in range(len(distance_list)): + if np.isclose(distance_list[i], 0, atol=1e-2): + distance_list[i] = 0.1 + distance_list = [val + 1 for val in distance_list] np.testing.assert_almost_equal( container.get_boundingbox(pad_box=1.0).lengths, distance_list, @@ -1802,6 +1804,9 @@ def test_get_boundingbox_extrema(self): ) distance_list = [val for val in distances] + for i in range(len(distance_list)): + if np.isclose(distance_list[i], 0, atol=1e-2): + distance_list[i] = 0.1 distance_list[0] = distance_list[0] + 1.0 distance_list[1] = distance_list[1] + 2.0 distance_list[2] = distance_list[2] + 3.0