Skip to content

Commit

Permalink
Merge remote-tracking branch 'handley-lab/master' into logscale
Browse files Browse the repository at this point in the history
  • Loading branch information
AdamOrmondroyd committed Oct 3, 2023
2 parents f2cdd7b + 434d97e commit a5f69cb
Show file tree
Hide file tree
Showing 5 changed files with 40 additions and 26 deletions.
20 changes: 9 additions & 11 deletions anesthetic/plot.py
Original file line number Diff line number Diff line change
Expand Up @@ -800,7 +800,7 @@ def fastkde_plot_1d(ax, data, *args, **kwargs):
density = kwargs.pop('density', False)

cmap = kwargs.pop('cmap', None)
color = kwargs.pop('color', (next(ax._get_lines.prop_cycler)['color']
color = kwargs.pop('color', (ax._get_lines.get_next_color()
if cmap is None
else plt.get_cmap(cmap)(0.68)))
facecolor = kwargs.pop('facecolor', False)
Expand Down Expand Up @@ -920,7 +920,7 @@ def kde_plot_1d(ax, data, *args, **kwargs):
density = kwargs.pop('density', False)

cmap = kwargs.pop('cmap', None)
color = kwargs.pop('color', (next(ax._get_lines.prop_cycler)['color']
color = kwargs.pop('color', (ax._get_lines.get_next_color()
if cmap is None
else plt.get_cmap(cmap)(0.68)))
facecolor = kwargs.pop('facecolor', False)
Expand Down Expand Up @@ -1013,7 +1013,7 @@ def hist_plot_1d(ax, data, *args, **kwargs):
density = kwargs.get('density', False)

cmap = kwargs.pop('cmap', None)
color = kwargs.pop('color', (next(ax._get_lines.prop_cycler)['color']
color = kwargs.pop('color', (ax._get_lines.get_next_color()
if cmap is None
else plt.get_cmap(cmap)(0.68)))

Expand Down Expand Up @@ -1117,7 +1117,7 @@ def fastkde_contour_plot_2d(ax, data_x, data_y, *args, **kwargs):
zorder = kwargs.pop('zorder', 1)
levels = kwargs.pop('levels', [0.95, 0.68])

color = kwargs.pop('color', next(ax._get_lines.prop_cycler)['color'])
color = kwargs.pop('color', ax._get_lines.get_next_color())
facecolor = kwargs.pop('facecolor', True)
edgecolor = kwargs.pop('edgecolor', None)
cmap = kwargs.pop('cmap', None)
Expand Down Expand Up @@ -1149,8 +1149,7 @@ def fastkde_contour_plot_2d(ax, data_x, data_y, *args, **kwargs):
contf = ax.contourf(x[i], y[j], pdf[np.ix_(j, i)], levels, cmap=cmap,
zorder=zorder, vmin=0, vmax=pdf.max(),
*args, **kwargs)
for c in contf.collections:
c.set_cmap(cmap)
contf.set_cmap(cmap)
ax.add_patch(plt.Rectangle((0, 0), 0, 0, lw=2, label=label,
fc=cmap(0.999), ec=cmap(0.32)))
cmap = None
Expand Down Expand Up @@ -1244,7 +1243,7 @@ def kde_contour_plot_2d(ax, data_x, data_y, *args, **kwargs):
zorder = kwargs.pop('zorder', 1)
levels = kwargs.pop('levels', [0.95, 0.68])

color = kwargs.pop('color', next(ax._get_lines.prop_cycler)['color'])
color = kwargs.pop('color', ax._get_lines.get_next_color())
facecolor = kwargs.pop('facecolor', True)
edgecolor = kwargs.pop('edgecolor', None)
cmap = kwargs.pop('cmap', None)
Expand Down Expand Up @@ -1285,8 +1284,7 @@ def kde_contour_plot_2d(ax, data_x, data_y, *args, **kwargs):
linewidths = kwargs.pop('linewidths', 0.5)
contf = ax.contourf(X, Y, P, levels=levels, cmap=cmap, zorder=zorder,
vmin=0, vmax=P.max(), *args, **kwargs)
for c in contf.collections:
c.set_cmap(cmap)
contf.set_cmap(cmap)
ax.add_patch(plt.Rectangle((0, 0), 0, 0, lw=2, label=label,
fc=cmap(0.999), ec=cmap(0.32)))
cmap = None
Expand Down Expand Up @@ -1352,7 +1350,7 @@ def hist_plot_2d(ax, data_x, data_y, *args, **kwargs):
label = kwargs.pop('label', None)
levels = kwargs.pop('levels', None)

color = kwargs.pop('color', next(ax._get_lines.prop_cycler)['color'])
color = kwargs.pop('color', ax._get_lines.get_next_color())
cmap = kwargs.pop('cmap', basic_cmap(color))

q = kwargs.pop('q', 5)
Expand Down Expand Up @@ -1439,7 +1437,7 @@ def scatter_plot_2d(ax, data_x, data_y, *args, **kwargs):

markersize = kwargs.pop('markersize', 1)
cmap = kwargs.pop('cmap', None)
color = kwargs.pop('color', (next(ax._get_lines.prop_cycler)['color']
color = kwargs.pop('color', (ax._get_lines.get_next_color()
if cmap is None else cmap(0.68)))

kwargs.pop('q', None)
Expand Down
2 changes: 2 additions & 0 deletions anesthetic/plotting/_matplotlib/core.py
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,8 @@ def __init__(self, data, x, y, C=None, **kwargs) -> None:
C = '__weights'
data[C] = data.get_weights()
kwargs['reduce_C_function'] = np.sum
if 'mincnt' not in kwargs:
kwargs['mincnt'] = np.finfo(np.float64).tiny
super().__init__(data, x, y, C=C, **kwargs)


Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ dependencies = [
"scipy",
"numpy",
"pandas>=2.0.0",
"matplotlib>=3.6.1,<3.8.0",
"matplotlib>=3.6.1",
]
classifiers = [
"Programming Language :: Python :: 3",
Expand Down
34 changes: 24 additions & 10 deletions tests/test_plot.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
import anesthetic.examples._matplotlib_agg # noqa: F401
from packaging import version
import pytest
import numpy as np
import matplotlib
import matplotlib.pyplot as plt
import matplotlib.gridspec as gs
from anesthetic.plot import (make_1d_axes, make_2d_axes, kde_plot_1d,
Expand Down Expand Up @@ -612,8 +614,12 @@ def test_contour_plot_2d(contour_plot_2d):
cf1, ct1 = contour_plot_2d(ax, data_x, data_y, facecolor='C2')
cf2, ct2 = contour_plot_2d(ax, data_x, data_y, fc='None', cmap=cmap)
# filled `contourf` and unfilled `contour` colors are the same:
assert cf1.tcolors[0] == ct2.tcolors[0]
assert cf1.tcolors[1] == ct2.tcolors[1]
# tcolors deprecated in matplotlib 3.8
cf1_tcolors = [tuple(rgba) for rgba in cf1.to_rgba(cf1.cvalues, cf1.alpha)]
ct2_tcolors = [tuple(rgba) for rgba in ct2.to_rgba(ct2.cvalues, ct2.alpha)]

assert cf1_tcolors[0] == ct2_tcolors[0]
assert cf1_tcolors[1] == ct2_tcolors[1]
cf, ct = contour_plot_2d(ax, data_x, data_y, edgecolor='C0')
assert ct.colors == 'C0'
cf, ct = contour_plot_2d(ax, data_x, data_y, ec='C0', cmap=plt.cm.Reds)
Expand Down Expand Up @@ -698,14 +704,22 @@ def test_contour_plot_2d_levels(contour_plot_2d, levels):
contour_plot_2d(ax2, x, y, levels=levels, cmap=cmap, fc=None)

# assert that color between filled and unfilled contours matches
# first level
color1 = ax1.collections[0].get_facecolor() # filled face color
color2 = ax2.collections[0].get_edgecolor() # unfilled line color
assert_array_equal(color1, color2)
# last level
color1 = ax1.collections[len(levels)-1].get_facecolor()
color2 = ax2.collections[len(levels)-1].get_edgecolor()
assert_array_equal(color1, color2)
if version.parse(matplotlib.__version__) >= version.parse('3.8.0'):
color1 = ax1.collections[0].get_facecolor() # filled face color
color2 = ax2.collections[0].get_edgecolor() # unfilled line color
# first level
assert_array_equal(color1[0], color2[0])
# last level
assert_array_equal(color1[len(levels)-1], color2[len(levels)-1])
else:
# first level
color1 = ax1.collections[0].get_facecolor() # filled face color
color2 = ax2.collections[0].get_edgecolor() # unfilled line color
assert_array_equal(color1, color2)
# last level
color1 = ax1.collections[len(levels)-1].get_facecolor()
color2 = ax2.collections[len(levels)-1].get_edgecolor()
assert_array_equal(color1, color2)


def test_scatter_plot_2d():
Expand Down
8 changes: 4 additions & 4 deletions tests/test_samples.py
Original file line number Diff line number Diff line change
Expand Up @@ -1394,7 +1394,7 @@ def test_samples_dot_plot():
assert len(axes) == 2

axes = samples.plot.kde_2d('x0', 'x1')
assert len(axes.collections) == 5
assert len(axes.collections) > 0
assert axes.get_xlabel() == '$x_0$'
assert axes.get_ylabel() == '$x_1$'
axes = samples.plot.hist_2d('x1', 'x0')
Expand All @@ -1417,7 +1417,7 @@ def test_samples_dot_plot():
assert axes.get_xlim()[1] < 0.3

axes = samples.drop_labels().plot.kde_2d('x0', 'x1')
assert len(axes.collections) == 5
assert len(axes.collections) > 0
assert axes.get_xlabel() == 'x0'
assert axes.get_ylabel() == 'x1'
axes = samples.drop_labels().plot.hist_2d('x1', 'x0')
Expand All @@ -1432,12 +1432,12 @@ def test_samples_dot_plot():
axes = samples.plot.fastkde_2d('x0', 'x1')
assert axes.get_xlabel() == '$x_0$'
assert axes.get_ylabel() == '$x_1$'
assert len(axes.collections) == 5
assert len(axes.collections) > 0
plt.close("all")
axes = samples.drop_labels().plot.fastkde_2d('x0', 'x1')
assert axes.get_xlabel() == 'x0'
assert axes.get_ylabel() == 'x1'
assert len(axes.collections) == 5
assert len(axes.collections) > 0
plt.close("all")
axes = samples.x0.plot.fastkde_1d()
assert len(axes.lines) == 1
Expand Down

0 comments on commit a5f69cb

Please sign in to comment.