From a17e605d6094d7635e4d840f88422962cc2d0bea Mon Sep 17 00:00:00 2001 From: Michael Waskom Date: Fri, 1 May 2020 11:47:52 -0400 Subject: [PATCH] Add explicit warning in swarmplot about gutters (#2045) Currently set to warn when > 2% of the points overlap; with a little playing around, this seemed like where the distribution started to get obscured. But it is ad hoc. --- doc/releases/v0.11.0.txt | 5 +++++ seaborn/categorical.py | 9 +++++++++ seaborn/tests/test_categorical.py | 11 ++++++++--- 3 files changed, 22 insertions(+), 3 deletions(-) create mode 100644 doc/releases/v0.11.0.txt diff --git a/doc/releases/v0.11.0.txt b/doc/releases/v0.11.0.txt new file mode 100644 index 0000000000..e3393c9a1d --- /dev/null +++ b/doc/releases/v0.11.0.txt @@ -0,0 +1,5 @@ + +v0.11.0 (Unreleased) +-------------------- + +- Added an explicit warning in :func:`swarmplot` when more than 2% of the points are overlap in the "gutters" of the swarm. diff --git a/seaborn/categorical.py b/seaborn/categorical.py index 9fabe1e402..0c97d44676 100644 --- a/seaborn/categorical.py +++ b/seaborn/categorical.py @@ -1315,6 +1315,15 @@ def add_gutters(self, points, center, width): off_high = points > high_gutter if off_high.any(): points[off_high] = high_gutter + + gutter_prop = (off_high + off_low).sum() / len(points) + if gutter_prop > .02: + msg = ( + "{:.1%} of the points cannot be placed; you may want " + "to decrease the size of the markers or use stripplot." + ).format(gutter_prop) + warnings.warn(msg, UserWarning) + return points def swarm_points(self, ax, points, center, width, s, **kws): diff --git a/seaborn/tests/test_categorical.py b/seaborn/tests/test_categorical.py index 4d87654683..cb3423a092 100644 --- a/seaborn/tests/test_categorical.py +++ b/seaborn/tests/test_categorical.py @@ -1780,10 +1780,15 @@ def test_beeswarm(self): def test_add_gutters(self): p = cat._SwarmPlotter(**self.default_kws) + + points = np.zeros(10) + assert np.array_equal(points, p.add_gutters(points, 0, 1)) + points = np.array([0, -1, .4, .8]) - points = p.add_gutters(points, 0, 1) - npt.assert_array_equal(points, - np.array([0, -.5, .4, .5])) + msg = r"50.0% of the points cannot be placed.+$" + with pytest.warns(UserWarning, match=msg): + new_points = p.add_gutters(points, 0, 1) + assert np.array_equal(new_points, np.array([0, -.5, .4, .5])) def test_swarmplot_vertical(self):