Skip to content

Commit de6ed81

Browse files
author
Tom Augspurger
committed
Merge pull request #6956 from anomrake/plotting
BUG: fix handling of color argument for variety of plotting functions
2 parents eb3b677 + 1980c7a commit de6ed81

File tree

4 files changed

+141
-73
lines changed

4 files changed

+141
-73
lines changed

doc/source/release.rst

+12
Original file line numberDiff line numberDiff line change
@@ -229,6 +229,14 @@ Deprecations
229229
returned if possible, otherwise a copy will be made. Previously the user could think that ``copy=False`` would
230230
ALWAYS return a view. (:issue:`6894`)
231231

232+
- The :func:`parallel_coordinates` function now takes argument ``color``
233+
instead of ``colors``. A ``FutureWarning`` is raised to alert that
234+
the old ``colors`` argument will not be supported in a future release
235+
236+
- The :func:`parallel_coordinates` and :func:`andrews_curves` functions now take
237+
positional argument ``frame`` instead of ``data``. A ``FutureWarning`` is
238+
raised if the old ``data`` argument is used by name.
239+
232240
Prior Version Deprecations/Changes
233241
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
234242

@@ -462,6 +470,10 @@ Bug Fixes
462470
- Bug in timeseries-with-frequency plot cursor display (:issue:`5453`)
463471
- Bug surfaced in groupby.plot when using a ``Float64Index`` (:issue:`7025`)
464472
- Stopped tests from failing if options data isn't able to be downloaded from Yahoo (:issue:`7034`)
473+
- Bug in ``parallel_coordinates`` and ``radviz`` where reordering of class column
474+
caused possible color/class mismatch
475+
- Bug in ``radviz`` and ``andrews_curves`` where multiple values of 'color'
476+
were being passed to plotting method
465477

466478
pandas 0.13.1
467479
-------------

doc/source/v0.14.0.txt

+8
Original file line numberDiff line numberDiff line change
@@ -382,6 +382,14 @@ Plotting
382382

383383
Because of the default `align` value changes, coordinates of bar plots are now located on integer values (0.0, 1.0, 2.0 ...). This is intended to make bar plot be located on the same coodinates as line plot. However, bar plot may differs unexpectedly when you manually adjust the bar location or drawing area, such as using `set_xlim`, `set_ylim`, etc. In this cases, please modify your script to meet with new coordinates.
384384

385+
- The :func:`parallel_coordinates` function now takes argument ``color``
386+
instead of ``colors``. A ``FutureWarning`` is raised to alert that
387+
the old ``colors`` argument will not be supported in a future release
388+
389+
- The :func:`parallel_coordinates` and :func:`andrews_curves` functions now take
390+
positional argument ``frame`` instead of ``data``. A ``FutureWarning`` is
391+
raised if the old ``data`` argument is used by name.
392+
385393
.. _whatsnew_0140.prior_deprecations:
386394

387395
Prior Version Deprecations/Changes

pandas/tests/test_graphics.py

+52-7
Original file line numberDiff line numberDiff line change
@@ -1220,11 +1220,29 @@ def scat2(x, y, by=None, ax=None, figsize=None):
12201220
def test_andrews_curves(self):
12211221
from pandas import read_csv
12221222
from pandas.tools.plotting import andrews_curves
1223-
1223+
from matplotlib import cm
1224+
12241225
path = os.path.join(curpath(), 'data', 'iris.csv')
12251226
df = read_csv(path)
12261227

12271228
_check_plot_works(andrews_curves, df, 'Name')
1229+
_check_plot_works(andrews_curves, df, 'Name',
1230+
color=('#556270', '#4ECDC4', '#C7F464'))
1231+
_check_plot_works(andrews_curves, df, 'Name',
1232+
color=['dodgerblue', 'aquamarine', 'seagreen'])
1233+
_check_plot_works(andrews_curves, df, 'Name', colormap=cm.jet)
1234+
1235+
colors = ['b', 'g', 'r']
1236+
df = DataFrame({"A": [1, 2, 3],
1237+
"B": [1, 2, 3],
1238+
"C": [1, 2, 3],
1239+
"Name": colors})
1240+
ax = andrews_curves(df, 'Name', color=colors)
1241+
legend_colors = [l.get_color() for l in ax.legend().get_lines()]
1242+
self.assertEqual(colors, legend_colors)
1243+
1244+
with tm.assert_produces_warning(FutureWarning):
1245+
andrews_curves(data=df, class_column='Name')
12281246

12291247
@slow
12301248
def test_parallel_coordinates(self):
@@ -1235,20 +1253,31 @@ def test_parallel_coordinates(self):
12351253
df = read_csv(path)
12361254
_check_plot_works(parallel_coordinates, df, 'Name')
12371255
_check_plot_works(parallel_coordinates, df, 'Name',
1238-
colors=('#556270', '#4ECDC4', '#C7F464'))
1239-
_check_plot_works(parallel_coordinates, df, 'Name',
1240-
colors=['dodgerblue', 'aquamarine', 'seagreen'])
1256+
color=('#556270', '#4ECDC4', '#C7F464'))
12411257
_check_plot_works(parallel_coordinates, df, 'Name',
1242-
colors=('#556270', '#4ECDC4', '#C7F464'))
1243-
_check_plot_works(parallel_coordinates, df, 'Name',
1244-
colors=['dodgerblue', 'aquamarine', 'seagreen'])
1258+
color=['dodgerblue', 'aquamarine', 'seagreen'])
12451259
_check_plot_works(parallel_coordinates, df, 'Name', colormap=cm.jet)
12461260

12471261
df = read_csv(path, header=None, skiprows=1, names=[1, 2, 4, 8,
12481262
'Name'])
12491263
_check_plot_works(parallel_coordinates, df, 'Name', use_columns=True)
12501264
_check_plot_works(parallel_coordinates, df, 'Name',
12511265
xticks=[1, 5, 25, 125])
1266+
1267+
colors = ['b', 'g', 'r']
1268+
df = DataFrame({"A": [1, 2, 3],
1269+
"B": [1, 2, 3],
1270+
"C": [1, 2, 3],
1271+
"Name": colors})
1272+
ax = parallel_coordinates(df, 'Name', color=colors)
1273+
legend_colors = [l.get_color() for l in ax.legend().get_lines()]
1274+
self.assertEqual(colors, legend_colors)
1275+
1276+
with tm.assert_produces_warning(FutureWarning):
1277+
parallel_coordinates(df, 'Name', colors=colors)
1278+
1279+
with tm.assert_produces_warning(FutureWarning):
1280+
parallel_coordinates(data=df, class_column='Name')
12521281

12531282
@slow
12541283
def test_radviz(self):
@@ -1259,8 +1288,24 @@ def test_radviz(self):
12591288
path = os.path.join(curpath(), 'data', 'iris.csv')
12601289
df = read_csv(path)
12611290
_check_plot_works(radviz, df, 'Name')
1291+
_check_plot_works(radviz, df, 'Name',
1292+
color=('#556270', '#4ECDC4', '#C7F464'))
1293+
_check_plot_works(radviz, df, 'Name',
1294+
color=['dodgerblue', 'aquamarine', 'seagreen'])
12621295
_check_plot_works(radviz, df, 'Name', colormap=cm.jet)
12631296

1297+
colors = [[0., 0., 1., 1.],
1298+
[0., 0.5, 1., 1.],
1299+
[1., 0., 0., 1.]]
1300+
df = DataFrame({"A": [1, 2, 3],
1301+
"B": [2, 1, 3],
1302+
"C": [3, 2, 1],
1303+
"Name": ['b', 'g', 'r']})
1304+
ax = radviz(df, 'Name', color=colors)
1305+
legend_colors = [c.get_facecolor().squeeze().tolist()
1306+
for c in ax.collections]
1307+
self.assertEqual(colors, legend_colors)
1308+
12641309
@slow
12651310
def test_plot_int_columns(self):
12661311
df = DataFrame(randn(100, 4)).cumsum()

0 commit comments

Comments
 (0)