Skip to content

Commit

Permalink
Seaborn original (#1)
Browse files Browse the repository at this point in the history
* Ignore otherwise unavoidable warnings in conftest.ini

* Remove old Makefile targets for Stanford website

* Update table css to not break API page

* Update Python kernel that is hardcoded into notebooks

* Fix thumbnail on gallery page

* Include tests in lint check

* PEP8 on Py27

* Force alphabetical sort of example gallery thumbs

* Add file with pinned versions of doc dependencies

* Add v0.9.1 to release notes page

* Add a relplot example to line/scatterplot

Closes #1664

* Add intersphinx links where kwargs are defined

Closes #1937

* Update to reflect new example data

* New pytest breaks coverage?

* Update release notes

* Update install docs to reflect new minimum dependencies

[ci skip]

* Fix gallery generator

* Release notes text

* More improvements to clustergrid layout

This enables use of tight_layout within clustermap. Ideally most plots will
now have everything in the figure and looking nice out of the box. It uses
a somewhat hacky approach that should be revisted as constrained_layout matures.

Also updates the docs a little bit and adds a rule where cbar_pos=None implies
that no colorbar will be drawn.

* Improve clustermap API examples

* Remove commented code

[ci skip]

* Add thumbnail images on the tutorial homepage

* Drop Python 2 from setup files

* Excise six

* Drop 2.7 (and 3.5) from travis build

* Remove references to 2.7 from README/docs

* Make tutorial thumbnails link to relevant page

* Modernize minimal dependencies

* Reorganize 0.9.1 feature notes

* Explicitly error in setup on Python < 3.6

* Remove smooth bootstrap

* Remove seaborn.timeseries

* Remove seaborn.linearmodels

* Remove seaborn.apionly

* Remove top-level import of timeseries module

* Add link to website footer

* Add version 0.10 release notes

* Update version for 0.10.0 release candidate

* Release v0.10.0.rc0

* Make dogplot more tolerant

I really like this easter egg :-)

However, when you suggest someone to use `dogplot` instead of `catplot`, they will receive a `TypeError` explaining that they provided too many arguments. This kind of spoils the fun. What about making it more tolerant?

* Add a pandas API link in introduction

* Bump version for v0.10 release

* Fix a few things in the docs

* Release v0.10.0

* Tweak release notes

* Bump version back to dev on master

* Add 0.9.1 and 0.10.0 DOI badges

* Use the correct platform integer type

`np.array.take` requires that the index be the platform integer type (`int32` for 32bit and `int64` for 64bit), but `np.random.RandomState.randint` returns an `int64` on any platform by default.  This makes sure it returns the right type of integer for the current platform.

Fixes mwaskom#1950

* Fix release notes link

* Add 0.10.1 release notes file and mention bootstrap fix

* DOC: update truncate parameter string to reflect new default (#1961)

* Use numpy's indexing dtype in bootstrap (#1968)

Follow-up to #1952 that uses the correct dtype

* Don't fail in regplot on singletons, don't fit regression either (#1969)

* FIX: don't squeeze singletons

* Disable regression fit in case of singleton inputs

* Update release notes

[ci skip]

* Copy props from old cmap when creating new cmap in heatmap (#1948)

* preserve cmap props when centering

* preserve explicitly set extremes

* Update release notes

* added tests for sig_stars() function (#1972)

* added tests for sig_stars() function

Since the `sig_stars()` function in utils.py doesn't have tests. I added the test to increase the coverage test.

* fixed 5th case in test_sig_stars() function

* Changed the stars variables

* Removed whitespaces in blank lines

* FIX: Ignore masked cells when finding heatmap data limits (#1956)

* respect mask when setting heatmap limits

* respect mask when setting heatmap limits

* improve code style

* Update release notes

* Add deprecation notice for sig_stars (#1973)

* MNT: Remove unused code paths (#1965)

* TST: pandas==1.0 compat

* Remove old matplotlib paths

* Remove old scipy paths

* Remove _set_spine_position

The behavior that this function addressed has been resolved in matplotlib 1.4:
https://github.com/matplotlib/matplotlib/pull/3104

* Clean more old compat code paths

Removed a few try/except clauses aimed to cover old matplotlib/pandas
versions that are no longer supported.

* Remove __future__ imports

* Improve code style

* Make all links possible use https:// (#1985)

* FIX: avoid error when prop_cycle has no color (#1992)

* Rework get_color_cycle

* No longer fail when cycler has no color (fixes #1977)

* Improves docstring

* Adds tests

* default to dark gray

* remove redundant test

* Avoid error in despine when axis has matplotlib categories (#1991)

Fixes #1978

* Make remaining links use https:// (#1984) (#1988)

* python3-only to_utf8 (#1979)

Co-authored-by: Michael Waskom <[email protected]>

* Fix `add_legend` to always populate `_legend` (#1999)

Even when `legend_out` is False

* Fix test import

* Avoid floating point error with maximum husl sat/lum (#2000)

* homogenization to use _color_to_rgb and normalization of husl_to_rgb output in [0,1]

* added better test to husl_to_rgb input and output

* Use numpy function and improve tests

Co-authored-by: Ivan Gonzalez <[email protected]>

* Autoscale in swarmplot to get valid transform (#2017)

Fixes #2013

* Add optional argument showfliers for boxenplot (#2010)

* Add optional argument showfliers for boxenplot

Same API as matplotlib boxplot to show/hide markers beyond the box(es)

* Remove trailing whitespace

* Add default value (True) for showfliers parameter

* Fix doc of showfliers parameter

* Add test for boxenplot showfliers parameter

* Update release notes

* Added fix for minor typos in 0.9.1 release notes (#2019)

* Housekeeping in utilities module (#2035)

* Tweak some utitlity docstrings and deprecate percentiles function

percentiles is now redundant with numpy.percentile and had not been
used internally in some time.

* Switch from internal percentiles function to numpy.percentile

* Deprecate ci_to_errorsize and pmf_hist

Closes #2034

* Revert deprecation of ci_to_errsize

* Excise and deprecate sort_df

Closes #2033

* PEP8

* Update release notes

* Fix deprecation warning handling in tests

* ENH: Handle`legend.title_fontsize` rcparam (#2025)

* test legend title size

* don't ignore legend.title_fontsize rcparam

* add 'legend.title_fontsize' to context

* Update release notes

* Examples of ways to have the same mapping between facets (#2030)

* PEP8

* Avoid seeing an error from statsmodels in kdeplot when data IQR == 0 (#2040)

* Handle some small housekeeping items prior to releasing v0.10.1 (#2041)

Document functions supporting example data

Add v0.10.1 release notes to whatsnew page

Avoid matplotlib deprecation warning in boxplot example

* Finalize v0.10.1 release notes

* Add Zenodo DOI for v0.10.1

* 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.

* Make FacetGrid a bit more convenient (#2046)

* Add FacetGrid.axes_dict attribute

* Clear inner labels from FacetGrid when setting x/y labels

* Update release notes

* Require keyword arguments for most parameters (#2052)

* Enforce keyword-only arguments for all non-semantic parameters in plotting API

* Ignore vscode cruft

* Fix tests that use positional arguments

* Standardize function signature formatting

* Accept positional args past * and warn for next release cycle

* Converge on standard plotting function signatures

* Update tests to use keyword arguments

* Move development-related decorators to specific module

* Standardize parameter names in distributions module (#2060)

* Standardize parameter names in distributions module

* Compat with older statsmodels

* Improve kdeplot tests

* Stricter code linting

- Define fewer PEP8 exceptions
- Define flake8 config centrally
- Fix existing issues

* Stricter code linting (#2064)

- Define fewer PEP8 exceptions
- Define flake8 config centrally
- Fix existing issues

* Add tight_layout method on FacetGrid and PairGrid (#2073)

* Add Grid.tight_layout for legend-aware automatic layout

* Use Grid.tight_layout internally

* Refactor variable processing (#2071)

* Add initial common function for processing long-form inputs

* Attempt to use new core variable processing for longform relational plots

* Create and ignore a directory for notes

* Move relational plots to use common variable processing

* Refactor establish_variables method into core

* Allow relational plots to use wide lists of lists

* Change base class to _VectorPlotter

* Add initial attempt at generalized wide data processing

* Modify tests for new intermeidate wide-form data representation

* Remove relational-specific wide data processing

* Fold relplot tests under TestRelationalPlotter

* Move tests for core variable processing

* Revert test reorganization; PEP8 and clean up names

* Add tests for wide dict inputs

* Pandas compat

* Modernize numpy random usage in test fixtures

* Fix docstring and comments

* Use containment checks rather than KeyError handling

* Improve test coverage for long data and messy wide data

* Test variables from dataframe index

* Flesh out wide data docstring

* Return variables dict along with plot_data df

* First attempt at generalizing relplot inputs

* Refactor and parametrize flat variables tests

* Test at base class level

* Test relplot from wide data and long vectors

* Fix test

* Programmatically define arbitrarily large style mappings (#2075)

* Programatically define arbitrary dash specs

* Add unique default markers and update tests

* Don't pass MarkerStyle into plt.plot

This fails; see https://github.com/matplotlib/matplotlib/issues/17432

* Update release notes

* Emphasize that default dashes/markers are unique.

* Add refs to github PRs

* Scale the default scatterplot edge width by the point radius (#2078)

* Scale the default scatterplot edge width by the point radius

* Reorder operations in scatterplot plot

* Allow vectors for c= or s= in scatterplot (#2079)

* Improve FacetGrid margin titles to not show previous texts (#2083)

* Improve FacetGrid margin titles to not show previous texts

* Add ref to github issue

* Require keyword arguments almost everywhere (#2081)

* Require all args but `data` to have keywords

* Remove argument __repr__ from keyword warning

Fixes #2066

* Update internal code and docstring examples to use kwargs everywhere

* Don't fail on anonymous functions

* Add keyword arguments in gallery examples and tutorials

* Provide more information in the warning

* Centralize and modify variable type inference (#2084)

* Centralize and modify variable type inference

* Use core.variable_type elsewhere in the library

* Bump pinned pandas to avoid bug

* Test coverage

* Move orientation inference to core and improve error handling

* Parameterize necessity of numeric variable by plot type

* Tweak language

* Shorten parameter name

* Correct comment

* Tweak docs

* Deprecate iqr and axlabel; improve deprecation warning class (#2087)

* Deprecate iqr and axlabel; improve deprecation warning class

* Note deprecations

[ci skip]

* Refactor semantic mapping operations (#2090)

* Prototype of rugplot that passes original tests

* Update test style

* Implement idea for less-verbose interaction with Plotter classes

* Explore an idea about how to abstract hue mapping

* Shush Flake8

* Define semantics with tuples, not lists, to make immutable

* Define semantic mappings with some complex higher-order magic

* Move some of the hue mapping logic

* Continued refactoring of variable assignment and hue mapping

* Refactor lineplot and get tests to pass

* Get most RelationalPlotter tests passing

* Fix error introduced during refactoring

* Move hue mapping tests from test_relational to test_core

* Avoid treating string palette arg as signaling categorical

* Set map_type to include datetime, add note about missing implementation

* Change semantic inheritance to be restrictive rather than expansive

* Consider boolean data categorical at Plotter level

* Sort out where utils/core funcs should go

* Strip nose out of the utils tests

* Move new decorator to where it belongs and add a test

* Clean up a few leftovers from utils reorg

* Add more HueMapping tests

* Make core module private

* Make objects in core non-private

* Add initial version of SizeMapping object

* Messy first pass at replacing parse_size with SizeMapping

* Fix size mapping to match current behavior, defer decoupling from plotter

* Add test to capture relplot bug

* Fix relplot numeric hues

* Move all hue/size lookup logic into corresponding Mapping objects

* Finalize refactoring of size mapping

* Add prototype of StyleMapping

* Integrate StyleMapping into relational plots

* Get relational tests to pass

* Move StyleMapping tests to core and excise parse_style from relational

* Point rugplot at old code for now

* Add some more basic tests

* Treat units as a normal semantic

* Rename assign_variables method

* Address some TODOs about style/organization/defaults

* Address more small TODOs and flesh out docs

* LogNorm now fails with non-positive data (as it arguably should)

* Handle units in relplot (fixes #2080)

* Ignore false-alarm warning from numpy on string/number comparison

* Catch a few pieces of residual cruft

* Ignore a separate dubious numpy warning

* Improve test coverage

* Avoid error in relational user guide page

* Improve lineplot handling of mpl kwargs (#2095)

* Improve lineplot handling of mpl kwargs

Fixes #1526

* Update release notes

* Refactor method for getting semantic subsets down to core (#2097)

* Refactor method for getting semantic subsets down to core

* Require explicit grouping semantics

* Fix ordering bug by maintaining category metadata (#2099)

* Update docs (#2098)

* Update kdeplot example to use keyword-only arguments
* Update intersphinx path to numpy docs

* Fix typo and dud test (#2100)

* Add basic CI workflow

* Fix CI workflow

* Iterate CI

* Add doc build to CI

* Define kernel for doc build during CI

* Explicit install of deps and utils during CI

* Test docs during CI (#2109)

* Excecute gallery scripts and fail on errors

* Revert change to github ci workflow

* Test doc build with intentionally broken notebook

* Revert broken notebook

* Use MPLBACKEND environment variable

* Reorganize testing-related files

* Specify qt version for travis

* Don't test backend rcParam

* Fix dud test. (#2116)

* Modernize kdeplot and rugplot (#2104)

* Add expand_margins parameter to rugplot and make default

* Reorganize handling of mpl kwargs

* Handle deprecated rugplot params and begin specing out kdeplot

* Prototype out kdeplot using existing internal functions

* Mostly functional new implementation of univariate kdeplot

* Add new (and changed) kdeplot parameters: bw_method, bw_adjust, weights

* Prototype a number of new kdeplot features

* Reorganize KDE plotting a bit

* Tidy up the univariate plotting function with comments

* Handle missing hue levels and stacked cumulative plots

* Implement kde in log space

* Clean up existing tests

* Add test coverage for univariate kde plot

* Consider boolean x/y variables to be numeric

* Add explicit log scaling and reorganize outer kdeplot logic

* Add more kdeplot tests

* Compat with pinned matplotlib and scipy versions

* Handle and test singleton input

* Add axis labels to core and use in kdeplot

* Make flat_data organization parameterizable

* Add provisional legend for kdeplot

* Implement soft deprecation of shade in kdeplot

* Allow positional x in kdeplot/rugplot

* Cleaning

* Add tests for new rugplot

* Rename scale_by_hue -> common_norm and cut_by_hue -> common_grid

* Input checking and TODO cleanup

* Make univariate fill default depend on hue_method

* Use fill= instead of shade= when using kdeplot internally

* Refactor kernel density estimation logic into its own class

* Add bivariate KDE computation

* Implement much of new bivariate kdeplot

* Sort out bivariate kdeplot color(mapping) and some other issues

* Add bivariate log scaling and handle some aspects of the old API

* Temporarily enable old approach to bivariate color map

* Reverse the gradient of the hue-mapped light_palette

* Deprecate shade_lowest in favor of thresh

* Mark old tests that aren't going to pass with new version

* Fix color= logic in kdeplot

* Add rugplot legend

* Add test coverage for bivariate kdeplot

* Pinned matplotlib compat

* Add reverse iteration through semantic subsets and clean up kdeplot

* Improve stack/fill computation and set sticky support edges for fill

* Disable density axis labels in jointgrid marginal axes

* Update kdeplot usage elsewhere in library

* Allow lable for bivariate kdeplot without hue

* Remove old code and tests

* Add parameter documentation and notes for kdeplot

* Check the inputs types to a bivariate kdeplot and error early

* Add bivariate kdeplot examples

* Add a matplotlib rc to the doc directory forcing bbox_inches=tight

* Add rugplot api docs

* Skip doctests on pinned dep build

* Fix link to matplotlib color docs

* Remove last remaining internal usage of shade

* Add release notes for new distribution plots

* Simplify common_norm logic

* Converge on multiple= parameter

* Use only fill_between for filled densities, and add more color handling

* Update references to matplotlib artists in kdeplot

* Remove separate fill_kws dictionary

* Allow None as clip value

* Add new gallery examples

* Update axisgrid tests

* Simplify kdeplot drawing and modify test for old matplotlib compat

* Fix small issues in docstrings

[ci skip]

* Add overwrought apporach to docstring standardization

* Allow used named .format arguments

* Don't fail on int input and mask (#2103)

Cast to float before filling with np.nan (fixes #2102)

* Boxenplot bug fixes, small features and style changes (#2086)

* Avoid drawing unnecessary outliers

* Remove deprecated lvplot

* refactor defaults and internal signatures

* Fix and improve boxenplots tests

* FIX: avoid generating an extra box (#2086)

* Draw a single box with the correct color

* Tweaked boxenplot style

A few changes to make it more consistent with boxplot:

* Outliers now use gray color instead of plot color.

* Boxes also have edge color of self.gray. The default style enforces
  patches edges to be white (#1468) and this made invisible boxes on
  white background. boxplot uses self.gray edges as well so this is
  consistent.

* Use butt capstyle for medians

* Add boxenplot tests

* Allow k to be a number

* autoscale after drawing boxenplot (#2085)

* Make last box have some color

* more tests

* improve tests coverage

* improve strip over boxen example

* improve boxenplot docstring

* use tukey method by default (#803)

* improve code style

* add 'full' option to k_depth

* restrict 'outlier_prop' to (0,1]

* Fix "trustworthy" method (#2118)

* Adds a new parameter to control alpha levels of "trustworthy"

* Fixes the formula to calculate number of boxes for "trustworthy"

* update release notes

* rename box_alpha to trust_alpha

* improve code style

* Store code examples in API docs using notebooks (#2123)

* Add new infrastructure for generating docs from notebooks

* Move rugplot examples into notebook

* More imporvements to new notebook processing infrastructure

* Add output stripping to doc notebook build

* Add script for auto-generating API doc notebooks

* Improve Makefile infra

* Convert kdeplot API docs to notebook

* Read notebook kernel from environment variable

* Add pandoc to GH doc build

* Consolidate workflow

* Add histplot function (#2125)

* Refactor the KDE plotting so the computation is easier to re-use

* Add univariate histogram computation

* Prototype out much of the innner histogram functionality

* Add log-scaling, unsegmented hist, and other features

* Add sticky edges

* Further flesh out segment/fill for histogram

* Improve default aesthetics

* Spec out public histplot function

* Add discrete mode in histplot

* Copy over some supporting code from kdeplot for the time being

* Add bivariate histogram computation

* Add tests for histogram computation

* Add some histplot tests

* Cover most of histplot with tests

* Code housekeeping

* Simplify default linewidth scaling and other changes

* Better, although still unsatisfying, default handling

* Add shrink parameter

* Further tweak default linewidth

* Fix parsing of function docstrings

* Increase allowed linewidth

* Add API docs and examples for histplot

* Pin more specific matplotlib version

* Fix histplot kde color

* Add example that uses histplot

* Adapt default binwidth to the orientation of the plot

* Fix example

* Convert internal use of distplot to histplot

* Udpdate axisgrid tests

* Update histplot alpha test

* PEP8

* Refactor axis units/scaling, allowing experimental support for category/datetime in distribution plots

* Add tests for new axis scale/unit interaction

* Bump minimal matplotlib to 2.2 for consistent category and datetime64 behavior

* Prefer dropna method once we have reduced columns of plot data

* Allow non-filled bar edges to be a bit thicker

* Add clean rules to doc notebook subeets

* Use penguins and planets in histplot docstring

* Make segement default depend on presence of hue semantic

* Fix awkward wording

* Add 'dodge' as a multple method in histplot

* Make three options for histplot appearance: bars, step, poly

* Remove vestgial utility function

* Introduce other elements earlier in histplot examples

* Add frequency as a histogram stat

* Fix test name

* Reorganize DistributionPlotter methods

* Modify implementation of discrete

* Add prototype of bivariate histogram

* Add external interface for bivariate histogram

* Fix test for discrete histogram

* Add test coverage for bivariate histogram

* Document bivariate histplot

* PEP8

* Standardize bivariate colormaps and colorbars between histplot and kdeplot

* Add example that uses bivariate histogram

* Change multiple regression example to use penguins

* Add release notes on histplot

* Add color to histplot signature

* Don't follow color cycle with datetime variable when drawing filled plot

* Fix hue test

* Tweak some docs and comments

* Revert test for unused default

* Default to discrete bins for categorical variables

* Work around #2135 to always use non-null data

* Clean up a couple of TODO comments

* Simplify example

* Fix default color in histplot with datetime variable (#2136)

* Fix default color in histplot with datetime variable

* Fix default color in histplot with datetime variable

* Improve support for datetime (and categorical) data in relational plots (#2138)

* Improve support for datetime (and categorical) data in relational plots

Fixes #2130

* Disable pandas unit conversion during testing

* Force matplotlib date converters in test fixture

* Clarified documentation of despine (#2140)

* clarified documentation of despine

* improved wording

* Add ecdfplot function (#2141)

* Add basic ecdfplot implementation

* Allow user to override drawstyle

* Add unit tests

* Add docstring content

* Add more docstring information and fix test

* Add complementary ECDF

* Add ecdfplot API examples

* Fix step plots with y data variable

* Housekeeping

* Fix error message

* Mention ecdfplot in release notes

* MNT: fix some failures with matplotlib=3.3.0rc1 (#2144)

* Avoid error on new matplotlib for equal aspect test

* Avoid palplot failure on mpl3.3

* Avoid error for unnamed groups

Mpl3.3 requires that removing tick labels for categorical
plots is done with empty labels rather than an empty list.
This is an issue with unnamed groups for categorical plots
(e.g. boxplot(x=vector)).

* Delete .mailmap

* TST: Increase testing speed by utilizing multiple cores (#2146)

* utilize multiple CPUs with pytest

* cache test datasets before testing

* avoid pulling qt for non-interactive tests

* cleanup qtagg mentions

* Dont add null columns in plot_data for unassigned semantics (#2148)

* Dont assign null columns in plot_data for unassigned semantics

* Fix comment wording

[ci skip]

* DOC: enable Sphinx rules for linking to GitHub issues, PRs and users (#2151)

* add sphinx-issues extension

* remove unnecessary mpl import

* add links to PRs

* Elaborate on how to build the docs

* Improve seaborn discoverability (#2160)

* update trove classifiers

* Explicitly install pyqt to allow qt5agg tests

Since not all matplotlib distributions specify pyqt as a dependency

* Remove magic number in example script (#2165)

* Fix typo (#2168)

* Improve matrix functions docstrings (#2188)

* fix matplotlib backends usage path

* add intersphinx links

* Better comply with numpydoc

* Use only stdlib in get_dataset_names (#2190)

* Use only stdlib in get_dataset_names

* Fix import for miscplot tests

* Don't test on matplotlib 3.3.1 to avoid scatter bug (#2197)

xref #2194, matplotlib/matplotlib#18254

* Add displot, a figure-level distribution function  (#2157)

* Initial pass at prototyping new approach to figure-level functions

* Very messy implementation of new figure-level distplot

* Mostly functional bivariate histogram distplot, with hacks

* Use utility function to share default parameters (good idea?)

* Simplify some operations, add more original distplot features

* Implement basic kind='kde' in new distplot

* Implement basic kind=ecdf in new distplot

* Implement backwards compat for ax

* Minor formatting changes

* Rename semantic_subsets -> iter_data

* Centralize log scale logic

* Minor changes to easy distplot API transition

* Remove vestigial code that subset columns of plot_data

* Fix semantic ordering bug

* Increased hackification of the interface between VectorPlotter and FacetGrid

* Handle histogram post-processing on each facet

* Better (but still partial) integration between distplot and FacetGrid

* More distplot deprecation/API change handling

* Get tests passing

* Avoid duplicate columns in the dataframe passed to FacetGrid

* Enable log scaling and custom color

* Attempt to ease more distplot transition w/r/t kde_kws

* Abandon plan to convert distplot, introduce displot instead

* Add FacetGrid parameters to displot signature

* Add stopgap to get proper FacetGrid legend kind of working

* Revert all distplot changes since v0.10.1

* Add deprecation notice to distplot

* Revert keyword change in existing distplot docs and tests

* Add minimal support for new-style API in distplot, for use in FacetGrid

* Fix small issues with kde color and facet parameters

* Address some TODOs

* Handle a missing-data problem in hue mapping

* Add categorical ordering for some diamonds fields

* Add displot docstring

* Change direction of distribution/axisgrid imports; fill in displot template

* Add API examples for displot

* Add basic infrastructure for testing displot against axes-level function

* Add displot vs kdeplot tests

* Add displot tests vs ecdfplot

* Add rug tests and silence warnings

* Test bivariate and faceted displot

* Add test to cover some new core functionality

* Test new utility function

* Update example gallery

* Improve faceted displot test

* Handle stack/fill/dodge properly in faceted displot

* Control range of bivariate histogram colormap with respect to axes-specific bins

* Add another displot gallery example

* Drop NA in bivariate histogram when determining bins

* Invert y axis with categorical variables

* Handle some TODOs in the code

* Move location of keyword arg dict copy

* Fix inverted categorical y axis on older matplotlibs

* Deal with some TODOs but add note about shared categorical axes

* Add new distributions tutorial

* Update release notes

* Handle legend kwarg in displot

* Unset sticky edges on (thresholded) 2D hist

* Run coverage checks across travis matrix; enhance coverage

* Make a few edits to the new doc README

* Fix and modernize aspects of relational plot docs (#2200)

* Fix relational colors test method

Fixes #2147

* Modernize relational doc inheritence

Fixes #2065, Fixes #2187

* Dedent relplot doc components

* Reorganize docs to emphasize distribution module

* Handle mpl33 deprecations (#2199)

Co-authored-by: Maoz Gelbart <[email protected]>

* Support wide data with categorical columns (#2202)

* Convert relational model API examples to use notebooks (#2201)

* Update scatterplot API docs to use notebook

* Convert lineplot API examples to notebook

* Convert relplot API examples to use notebook

* Improve notebook processing, don't remove html output

* Start improving lineplot API examples

* Improve (?) lineplot API examples

* Improve scatterplot API examples

* Hide import cells in distribution plot API examples

* Demo using FacetGrid in relplot docs

* Fix doc bugs

[ci skip]

* Always set private despine variable in PairGrid (#2203)

Fixes #2166

* Change dropna default to False in axisgrid.py (#2204)

* Change dropna default to False in axisgrid.py

* Update release notes

* Improve variable assignment feedback (#2205)

* Raise when semantics are set with wide-form data

* Improve error messages when assigning longform data

* Fix tests that trigger new errors

* Avoid kde when variance is almost 0 (#2206)

Fixes #2186

* Address various warnings raised within the test (#2208)

* Fix log warning in comp_data test (and fix comp_data too)

* Avoid numpy ragged array warning when checking flat data

* Adjust code that triggers ragged array error

* Address other ragged array warnings

* Set xticks/yticks before setting labels

* use scatterplot instead of plt.scatter (#2069)

Co-authored-by: Michael Waskom <[email protected]>

* FIX: allow un-sharing categories in catplot (#2196)

* add tests for 1702

* unify categories across facets only when required

* document count as allowed kind parameter

* Honor user order input

* remove lvplot remnants

* warn if different categories may share color

* update release notes

* don't warn if hue is provided

* fix failing jointplot example

* fix distplot example 6

* Scale `legend.title_fontsize` when scaling fonts (#2214)

* add legend.title_fontsize to tested keys

* scale also legend.title_fontsize

* update release notes

* Add hue as parameter in JointGrid and "hist" as a kind in jointplot (#2210)

* Add 'hist' as a kind in jointplot

* Accept thresh=None in kdeplot

* Add provisional hue support in JointGrid/jointplot

* Move plot equality assertions into _testing module

* Test JointGrid with hue

* Test new jointplot features

* Make jointplot(kind='kde') default to unfilled densities

* Dispatch tuple-ized bin parameters with histplot

* Accept hue mapping parameters and pass to joint/marginal functions if possible

* Use core input processing in JointGrid

* Remove distplot kwargs from the marginal_kws dict and warn about them

* Fix internal names for JointGrid variables

* Default to densities for jointplot margins, like in pairplot

* Do hue-conditional behavior correctly in wide-form mode

* Add marginal_ticks as parameter of jointplot/JointGrid

* Fix typo

* Convert jointplot/JointGrid API examples to notebooks and update with new features

* Adapt marginal ticks test to run on older matplotlibs

* Convert JointGrid/jointplot docstrings to use inherited descriptions

* Update distributions tutorial and fix tutorial index page

* Update JointGrid-related examples

* Try setting backend to Agg during doc build

* Debugging doc build failure

* Attempting to isolate doc failure

* Don't crash doc build on bad thumbnail

* Add marginal ticks example back to the repo

* Undebug ci workflow

* Update release notes

* Fix object-typed numeric hue/size input to relational plots (#2173)

* Test object-typed hue/size

* Soft-convert object-typed arrays

* Satisfy linter

* fix a typo

* Change culmen to bill in all examples using penguins (#2215)

Mirrors changes in the R penguins dataset, saves characters, and
it's easier to remember how to spell 'bill'

* Adjust swarmplot overlap warning and avoid in examples (#2216)

* Adjust swarmplot warning to 5% of points

* Adjust examples that trigger swarmplot warning

* Remove deprecaed JointGrid annotation code (#2217)

* Add user guide documentation on plotting functions and data structures (#2218)

* Add more informative error message for bad dataset name

* Add narrative docs on seaborn data structures

* Fix heatmap example to reflect short month names

* Language tweaks

* Add a tutorial chapter giving an overview to seaborn plotting functions

* Add a schematic figure of long-frm vs wide-form data

* Add new basic user guide chapters to tutorial homepage

* Remove figure-level/axes-level and data structure discussion from introduction

* Convert main scatterplot matrix example to penguins

* Fix typos

* Tweak gallery examples

* Set penguins sex to title case on load

* Tweak thumbnail

* Point to new docs in release notes

* Make note section highlighting lighter

* Use decreasing values for categorical size mapping (#2221)

Fixes #2122

* Use core axis labeling method in relational plots (#2222)

* Add a rich HTML representation of color palette objects (#2225)

* Add rich html_repr to color palette object

* Update palettes tutorial and notebook

* Reverse direction of default distributions sequential colormap (#2224)

* Reduce surprise about relational plot legends (#2229)

* Fix unknown palette error

* Select better brief ticks

Larger maximum number of ticks and no ticks outside the range of the data

* Add 'auto' legend mode in relational plots

* Use 'auto' when relational legend is 'True'

* Only use dummy-artist 'subtitles' with multiple semantic variables

* Add clarity about numeric semantic mapping in scatterplot/lineplot docstrings

* Update release notes

* Update relplot legend tests

* Update legend locator test

* Add utility function to make subtitles look more like titles

* Delint

* Old matplotlib compat

* Try testing on latest matplotlib

* Test legendd=True

* Don't try to set attributes on removed axes (#2233)

Fixes #2228

* Delegate hue in PairGrid to plotting functions (#2234)

* Add provisional support for delegating hue in PairGrid

* Use histplot on pairplot diagonal

* Update Pairgrid tests

* Return self from map_diag

* Improve test coverage

* Convert PairGrid docstring to notebook and update

* Fix test

* Improve support for legends and markers with new plots

* Make color/label injection optional

* Update markers test

* More flexibility in PairGrid

* Convert pairplot API examples to notebook

* Add public access to Grid legend object

* Fix iterative plot_bivariate and improve test coverage

* Don't cast diagonal data to array (fixes #1663)

* replace numpy aliases with builtin types (#2236)

* Add new palette functionality and new colormaps (#2237)

* Add flare and crest colormaps

* Fix internal link

* Tweak some examples to use new colormaps

* Add as_cmap option to color_palette

* Get color palette object through color_palette

* Fix typo

* Get cmap object in kdeplot from internal lookup

* Test new functionality

* Fix logic of _d colormaps and allow _r_d

* Change sep default to 1 in diverging palette

* Pre-release docs enhancements (#2239)

* Add colormap html repr to matplotlib colormaps in palette tutorial

* Organize v0.11 release notes by module

* More release note improvements

* Execute all notebooks with python 3.8 and latest libraries

* Fix regression in palettes image

* Add late-breaking pairgrid enhancements to release notes

* Tweak gallery thumbnails

* Mention new colormaps in release notes

* Cover new color palette functionality in the release notes

* Reorganize homepage thumbnails

* Rewrite color palettes tutorial

* Simplify notebook cleaning code

* Improve palette docstrings

* More color theory background in palette tutorial

* More color variation on homepage

* PMention new palette tutorial in release notes

* Don't copy docstring source files into built site

* Add release note category badges

* Improve grouped barplot example

* Improve links

* Convert and update FacetGrid docstring

* Update tutorials

* Tweaks

* More tweaks

* Add references to seaborn objects used in gallery scripts

* Add proper logos to docs (#2245)

* Add proper logos to docs

* Add logo to README

* Left-align logo

[ci skip]

* Fix discrete string-specified light/dark palettes (#2247)

* DOC: minor fixes (#2242)

* Fix broken link

* tweak

* prefer :doc: over :ref:

* fix broken link

* fix comma

* Better documentation of FacetGrid's access to underlying matplotlib objects (#2248)

* Document FacetGrid axes_dict
Correct axes_dict example

* Further clarify FacetGrid's public access to underlying matplotlib objects

Co-authored-by: Maoz Gelbart <[email protected]>

* Pre-release docs updates (#2250)

* Language tweaks in intro

* Add background back to cubehelix palette example

* Add an example of making a heatmap using a scatterplot

* Fix cropping fof function overview schematic

* Tweak violinplot example

* Add a new histogram example and tweak another one

* Reorganize example gallery

* Downsize images a bit

* Tweak some text in various notebooks

* Improve installation page

* Improvements and streamlining of the introduction page

* Add axis label kwargs in FacetGrid.set_axis_labels

* Tweaking a bit further

* Mention docs updates in the release notes

* Streamline color theory examples

* Tweak lineplot example colors

* Clarify long/wide data

* Tweak logo

* Remove whitebg svg logos

* Various tweaks

* Fix typo

* Add link to seaborn discourse channel

* Add set_theme() to replace set() (#2253)

* Add set_theme function and change set to an alias

* Add test

* Change set -> set_theme everywhere

* Update aesthetics tutorial

* Update API page and release notes

* Expose set_theme as public API

* Fix bivariate histogram color in displot (#2255)

* Fix bivariate histogram color in displot

* Fix univariate kdeplot color in displot

* Convert coor attribute to rgba in artist tetsts

* Improve PairGrid tight_layout (#2256)

- Track the layout_pad parameter and use whenever tight_layout is called
- Call tight_layout at the end of pairplot

* Small formatting fixes in release notes

* Fix tutorial links in displot docstring

* Add new Zenodo DOIs

* Update internal version to 0.12.0.dev0

* Add links to archived versions of docs

* Pass `col_order` and `row_order` to FacetGrid in displot (#2262)

Co-authored-by: badge <[email protected]>

* Fix PairGrid with non-square grid and non-marginal diagonal axes (#2270)

* Fix PairGrid with non-square grid and non-marginal diagonal axes

Fixes #2260

* Add #2262 to release notes

* TST: fix colors and paths comparison in relational tests (#2281)

* test correct collection

* use matplotlib's same_color

* compare paths arrays lengths

* Fix: use linewidth when plotting boxes and medians (#2287)

* throw a meaningful error message in lmplot in case  kwarg is missing (#2302)

* Fix: do not annotate clustermap w/ annot=False (#2323)

Co-authored-by: criddell <[email protected]>

* Fix `adjust_subtitles` when `legend_out=False`. (#2304)

* Test adjust_subtitles and legend_out interactions

* Fix adjust_subtitles when legend_out is False

* Remove redundant smoke tests

* Force doc CI to use Python 3.8 (#2335)

Relevant matplotlib issue https://github.com/matplotlib/matplotlib/issues/18718

* Error if row/col colors are indexed but data isn't (#2313)

* Test pandas row/col colors against nonindexed data

* Error if col/row colors are pandas but data isn't

* Improve matrix docstrings

* Reformat code block

* Use numpy array directly

* Format single backticks as literal code block

* Fix jointplot reference syntax in distributions tutorial. (#2359)

* Fix jointplot reference syntax in distributions tutorial.

* Fix rST syntax for hue (add space around ``code``).

* better checks for `sharey` and `sharex` in `axesgrid.py` (#2347)

* bugfix issue 2346

* fix

* MAINT: Drop nose and test on python==3.9 (#2328)

* MAINT: Migrate nose to pytest

* MAINT: Migrate nose to pytest

* MAINT: Migrate nose to pytest

* MAINT: Migrate nose to pytest

* MAINT: Migrate nose to pytest

* MAINT: Migrate nose to pytest

* Modernize some tests

* MAINT: Migrate nose to pytest

* Drop nose dependency

* Improve skip parameter name

* Test on python3.9

* Declare python==3.9 support

* TST: FIX: Consider array length in artist arrays comparison (#2363)

* Add artists length comparison

* Fix jointplot tests

* Fix displot tests

* Fix pairgrid (#2368)

* Add failing test for #2307

* Fix PairGrid hue mapping logic

Fixes #2307

* Fix faceted bivariate KDE normalization (#2378)

Fixes #2377

* Fix NA propagation in lineplot (#2273)

* Use nanpercentile in ci function

Fixes #2272

* Drop NA inside lineplot

Narrowly fixes #2272

But would like a broader solution here that also addresses #1552

* Add a test to catch NA propagation

* FIX: Infer categorical dtypes before boolean resolution (#2379)

* Add test for #2317

* Improve variable_type docstring

* Give precedence to categorical dtype inference

* Run tests on github actions (#2383)

* Assorted fixes for small problems (#2382)

* Fix color_palette docstring (fixes #2372)

* Disable jitter in dotplot example (fixes #2366)

* Raise early in jointplot when selected kind does not support hue (fixes #2326)

* Add weights to ecdfplot docstring (fixes #2348)

* Fix corner PairGrid without marginal diagonal (fixes #2354)

* Use math.isclose for zero variance check

See https://github.com/numpy/numpy/issues/10161

Fixes #2294

* Raise informative error when PairGrid has no rows/columns (Fixes #2311)

* Use same y axis scaling for diag_kind='hist' and diag_kind='auto' resolving to hist (fixes #2314)

* Handle list/array boolean check

* Update release notes

* Fix error with no marginal plots where density axis would be shared

* Slight rearrangement of PairGrid variable processing

* Add/restore functionality to long-form data processing (#2386)

* Add/restore functionality to long-form data processing

* Add tests for restored functionality

* Update release notes

* Require strings to access index fields

* Allow clustermap row/col colors to be categorical (#2389)

* Test for categorical row/col_colors input

* Allow categorical row/col_colors input

* Remove unreachable code

At this stage colors is not a pandas object

* Remove unused variables

* Reduce usage of global matplotlib state in axisgrid objects (#2388)

* Reduce usage of global matplotlib state in axisgrid objects

* Improve test coverage and legac compat in JointGrid

* Update release notes

* Always cast func.__module__ to str for safety

* Docs tidying for v0.11.1 release (#2393)

* Update doc dependencies

* Suppress function signatures on main API page

* Add conf params for compatability with newer doc theme

* Fix typos and formatting

* Prepare release notes for release

* Simplify CI build matrix

* Fix PF reference in release notes

* Fix API page sphinx

* Try building docs in parallel

* Fix API docs sphinx

* Reduce doc CI parallelization (#2394)

Can't parallelize over notebooks/html steps without breaking things

* Add v0.11.1 Zenodo badge

* Corrects typo in the diverging palette doc sub-section title (#2397)

* Corrects typo in the doc.

* Fixes the length of the underline

* Raise minimal supported Python to 3.7 and bump requirements (#2396)

* Raise minimal officially supported Python to 3.7

Following NEP29 and upstream libraries

* Make minor bumps to minimally supported library dependencies

Otherwise I couldn't get the pinned libraries installed on Python 3.7

* Change pip requirements style in CI

* Remove code that special-cases now unsupported scipy

* Fix KDE weights test

* Adapt test that fails on pinned matplotlib

* Remove compatability for no-longer-supported dependency versions

* Update release notes

* Make scipy an optional dependency (#2398)

* Vendor reduced version of scipy's KDE, adapt existing KDE code

* Adapt violinplot and stripplot to not require scipy

* Remove vendored kde docstring examples

* Fix missing import

* Remove more unhelpful doctests

* Note that cumulative kdeplot requres scipy

* Make scipy optional in matrix module

* Replace scipy iqr calls and adapt old distplot code

* Standardize flag for scipy availability

* Define extra dependencies in setup file

* Rework CI workflow for new dependency strategy

* Pass extras_require to setuptools

* Remove previously deprecated utility functions

* Remove scipy from categorical tests

* Remove scipy from regression module

* Remove scipy from categorical

* Remove scipy from distribution tests

* Protect scipy-using code in matrix tests

* Remove scipy from distributions tests (again)

* Fix docs about scipy requirements

* Update installing docs

* Update release notes

* Cover some missing-scipy-triggered errors in tests

* Update README and Remove requirements file

* Use modern canonical way of drawing the figure (#2399)

Closes #2343

* Add a note about getting offline docs access through the website repo

* Revert change to forced draw command (#2408)

The change in #2399 inadvertantly broke seaborn on the macosx mpl
backend.

See https://github.com/matplotlib/matplotlib/issues/19197

This PR reverts that change until the issue can be sorted out.

* Increase errorbar flexibility (#2407)

* Add EstimateAggregator and related functions

* Add tests for EstimateAggregator object

* Rework lineplot to use new aggregator object

* Test warning/redirection of old ci= arg

* Update errorbar param in lineplot docs and tutorial

* Add errorbar param to lineplot docstring

* Remove now-unused lineplot-specific aggregation method

* Add release notes stub

* Add text for tutorial chapter on error bars

* Fix lineplot on log scaled axis

* Let log_scaled default to False for unattached plotters

* Handle named functions and nans better in bootstrap function

* Generalize ci deprecation and increase docstring salience

* Simplify code

* Refactor tests and bump minimal pandas (#2412)

* Move long-form variable assignment tests to core test class

* Lift minimum pandas to 0.24

* Modernize some pandas type conversions

* Update .values -> .to_numpy() in tests

* Improve NA robustness in VectorPlotter.comp_data (#2417)

* Improve NA robustness in VectorPlotter.comp_data

* Adjust datetime test to account for archaic matplotlib limitation

* Update release notes

* Abstract logic of forcing figure draw with matplotlib backcompat (#2426)

See https://github.com/matplotlib/matplotlib/issues/19197 for context
Fixes #2343

* boxplot whis keyword docstring clarification (#2427)

* whis keyword docstring change

* Tweak language

Co-authored-by: Michael Waskom <[email protected]>

* Restrict comparison values for variable type strings (#2436)

This should avoid subtle bugs that could crop up when comparing against
the wrong form (e.g. "category" instead of "categorical").

There might be a built-in way to do this, but I couldn't find it...

* support Float64Dtype in boxenplot, related to #2434 (#2435)

* Fix typo (#2431)

* Modernize categorical plotting and refactor stripplot (#2413)

* Proof of principle refactored stripplot passing all tests

* Improve handling of categorical dates

* Improve automatic categorical orientation with dates

* Add more continuous datetime variable to long_df fixture

* Begin updating stripplot tests

* Update more stripplot tests

* Add test for single strip, with hue

* Fix infer_orient argcheck

* Add tests for flat and wide data in stripplot

* Refactor hue backcompat into a plotter class method, make optional

* Enable new default coloring rules in stripplot

* Update catplot to use new stripplot function

* Update assert_plots_equal to test all collections

* Clean up some comments

* Remove old stripplot code

* Fix typo

* Add explicit categorical order to VectorPlotter._attach

* Modify the implementation of categorical data handling to permit unshared facets

* Improve integration of axis converters with unshared facet grids

* Fix ordering by category dtype

* Fix catplot point sizes

* Add (un)fixed_scale

* Fix plot equality assertion

* Disable tests that hit matplotlib bug due to incomplete implemenation

* Improve test coverage

* Move forced/ordered categorical scaling logic to core

* Add core-level tets for scale method(s)

* Reduce use of special attributes, add formatter and hue_norm

* Update stripplot API examples

* Re-enable kwarg deprecation warning

* Fix log scaled stripplot

* Fixed log-scaled categorical axis

* Don't jitter single strips

* Improve swarmplot algorithm (#2443)

* WIP making swarmplot dynamically update the swarm

* Move beeswarm algorithm into distinct class

* Remove old swarm algorithm methods

* Update beeswarm algorithm to use pointwise sizes

* Force figure draw in swarmplot tests to activate swarm algorithm

* Use exact original value axis data

* Update swarmplot tests and release notes

* Fix tets

* Refactor swarmplot (#2447)

* Refactor swarmplot to match new stripplot (copying too much code)

* Refactor some shared components of swarm and strip plot

* Add dropna logic to iter_data

* Don't try to swarm empty collection

* Fix rst syntax

* Improve droopna logic and copy dataframe to avoid warnings

* Fix bug with jitter on empty category

* Remove original swarmplot code

* Transition catplot with kind='swarm' to new code

* Add more swarmplot tests

* Fix small test issues

* Mark a puzzling pinned test failure as xfail

* Delay log scale query in beeswarm until draw time

* Fix single point jitter

* Added control over the swarmplot warning with warn_thresh

* Update datalim and force autoscale at draw-time

* Update swarmplot API examples

* Refactor common parts of strip and swarm plot tests

* Always update datalim while swarming

* Move bug report text from website into contributing file

* Generalize getting default color from color cycle (#2449)

* Clean up auto-gray code

* Add initial versiono of default_color function

* Reenable swarmplot mandaatory kwarg warning deprecator

* Expand flexibility of supported scatter coloring kwarg

* Change logic of scatter-based coloring to post-proccess mpl object

* Test default and specified colors

* Rework how shared strip/swarm tests work

* Test user-supplied color array with swarm/strip plot

* Address failures on pinned tests

* Use centralized default_color function in scatterplot

* Use default_color function in lineplot

* Use general default color function for kdeplot, rugplot, and ecdfplot

* Use default_color function in histplot

* Get default color after attaching axes

* Mark kdeplot datetime autoscale test as xfail due to matplotlib bug

* Fix logic of color tests

* Workaround empty fill_between datetime autoscale bug

Fixes #2133 on newer matplotlibs

* More backcompat and edge casing

* Add color tests for distribution module

* Fix bar hist legend artists

* Mute color with hue warning for now

* Update README CI status badge to reflect GitHub Actions status

Closes #2453

* Handle deprecation of ci=None in lineplot (#2457)

Fixes #2441

* Fix rugplot with datetime data (#2458)

Fixes #2451

* Set alpha properly on unfilled hist/kde plots (#2460)

* Set alpha properly on unfilled hist/kde plots

Fixes #2450

* Fix typo in kdeplot docstring

* Generalize color comparison

* Add percent-based normalization in histplot (#2461)

* Add percent-based normalization in histplot

* Test bivariate normalization

* Fix multiple resolution when hue variable has no name (#2462)

* Fix multiple resolution when hue variable has no name

Fixes #2452

(cherry picked from commit 008f7e0e030681f8047c7d628e6bb3fc3d23e6ff)

* Remove unused kwarg

* Don't try to resolve multiples if there aren't any

* Simplify logic that ignored multiple when no hue was assigned

* Fix typo and remove outdated comment

* Fix faceted bivariate histogram normalization at displot (#2468)

Fixes #2465

* Update release notes

* Don't fail when docstrings have been stripped by -OO mode (#2473)

* Don't fail when docstrings have been stripped by -OO mode

Fixes #2470

* Fix comment

* Clarify language

* Fix typo

* Fix histplot shrink with non-discrete bins (#2477)

The code for shifting the shrunken bars assumed that discrete binning
was in effect. This is probably the only situation where shrinking
really makes sense, but there was no prevention or warning of getting
an innacurate result when using it with continuous bins.

Fixes #2476

* Update dates

* update matplotlib canonical... (#2482)

.. this will help with inter sphinx warnings.

* Don't pass a set to ListedColormap in clustermap (#2490)

* Don't pass a set object to ListedColormap

Addresses the issue in https://github.com/matplotlib/matplotlib/issues/19544

* Handle multiple LineCollection color kwargs

* Test side colors size homogeneity test

* Fix log scaling in distribution plots (#2504)

* Improve log_scale parameter documentation

Partly addresses #2454

* Fix log-scaled ecdf plots (fixes #2502)

* Fix log-scaled rug plot

* Fix histplot auto line width with log scale or categorical y axis (#2522)

* Fix histplot auto linewidth on log scaled axis

Fixes #2513

* Fix auto linewidth for categorical histograms on the y axis

Fixes #2523

* Add JOSS paper to docs/README (#2546)

* Update docs/readme with links to joss paper

* Remove Zenodo DOIs

* Mention JOSS paper in v0.12 release notes

* DOC: Clarify how to derive dodge parameter value for aligning pointplot in stripplot (#2548)

* DOC: clarify how to derive value for dodge param

* DOC: fix typo develpoment -> development

* DOC: misc fixes. (#2558)

Typos, non-existing parameters, and the fact that space before colon in
parameters is necessary for numpydoc to correctly parse the name and
type

* Reduce redundant computation in distplot linewidth (#2559)

Co-authored-by: Michael Waskom <[email protected]>
Co-authored-by: Michael Waskom <[email protected]>
Co-authored-by: Jan Pipek <[email protected]>
Co-authored-by: Todd <[email protected]>
Co-authored-by: Christopher Whelan <[email protected]>
Co-authored-by: Maoz Gelbart <[email protected]>
Co-authored-by: Iqrar Agalosi Nureyza <[email protected]>
Co-authored-by: Sebastian Pipping <[email protected]>
Co-authored-by: bennguvaye <[email protected]>
Co-authored-by: Ivan Gonzalez <[email protected]>
Co-authored-by: Lukas <[email protected]>
Co-authored-by: danyal-s <[email protected]>
Co-authored-by: Paul Rougieux <[email protected]>
Co-authored-by: Roman Werpachowski <[email protected]>
Co-authored-by: Emilio Dorigatti <[email protected]>
Co-authored-by: Daniel Bauer <[email protected]>
Co-authored-by: Tomas Ojea <[email protected]>
Co-authored-by: Matthew Badger <[email protected]>
Co-authored-by: badge <[email protected]>
Co-authored-by: Clément Robert <[email protected]>
Co-authored-by: Cameron Riddell <[email protected]>
Co-authored-by: criddell <[email protected]>
Co-authored-by: Bradley Dice <[email protected]>
Co-authored-by: Aaron Spring <[email protected]>
Co-authored-by: Robin Scheibler <[email protected]>
Co-authored-by: joooeey <[email protected]>
Co-authored-by: André F. Rendeiro <[email protected]>
Co-authored-by: Ondrej Zacha <[email protected]>
Co-authored-by: Marçal Gabaldà <[email protected]>
Co-authored-by: Jody Klymak <[email protected]>
Co-authored-by: Stefan Appelhoff <[email protected]>
Co-authored-by: Matthias Bussonnier <[email protected]>
Co-authored-by: Isaac Virshup <[email protected]>
  • Loading branch information
1 parent 4502481 commit 3045db8
Show file tree
Hide file tree
Showing 194 changed files with 59,749 additions and 10,667 deletions.
18 changes: 15 additions & 3 deletions .github/CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,26 @@ Contributing to seaborn
General support
---------------

General support questions ("how do I do <x>?") are most at home on [StackOverflow](https://stackoverflow.com/), where they will be seen by more people and are more easily searchable. StackOverflow has a `[seaborn]` tag, which will bring the question to the attention of people who might be able to answer.
General support questions ("how do I do X?") are most at home on either [StackOverflow](https://stackoverflow.com/) or [discourse](https://discourse.matplotlib.org/c/3rdparty/seaborn/21), which have a larger audience of people who will see your post and may be able to offer assistance. StackOverflow is better for specific issues, while discourse is better for more open-ended discussion. Your chance of getting a quick answer will be higher if you include runnable code, a precise statement of what you are hoping to achieve, and a clear explanation of the problems that you have encountered.

Reporting bugs
--------------

If you have encountered a bug in seaborn, please report it on the [Github issue tracker](https://github.com/mwaskom/seaborn/issues/new). It is only really possible to address bug reports if they include a reproducible script using randomly-generated data or one of the example datasets (accessed through `seaborn.load_dataset()`). Please also specify your versions of seaborn and matplotlib, as well as which matplotlib backend you are using.
If you think you've encountered a bug in seaborn, please report it on the [Github issue tracker](https://github.com/mwaskom/seaborn/issues/new). To be useful, bug reports must include the following information:

- A reproducible code example that demonstrates the problem
- The output that you are seeing (an image of a plot, or the error message)
- A clear explanation of why you think something is wrong
- The specific versions of seaborn and matplotlib that you are working with

Bug reports are easiest to address if they can be demonstrated using one of the example datasets from the seaborn docs (i.e. with `seaborn.load_dataset`). Otherwise, it is preferable that your example generate synthetic data to reproduce the problem. If you can only demonstrate the issue with your actual dataset, you will need to share it, ideally as a csv. Note that you can upload a csv directly to a github issue thread, but it must have a `.txt` suffix.

If you've encountered an error, searching the specific text of the message before opening a new issue can often help you solve the problem quickly and avoid making a duplicate report.

Because matplotlib handles the actual rendering, errors or incorrect outputs may be due to a problem in matplotlib rather than one in seaborn. It can save time if you try to reproduce the issue in an example that uses only matplotlib, so that you can report it in the right place. But it is alright to skip this step if it's not obvious how to do it.


New features
------------

If you think there is a new feature that should be added to seaborn, you can open an issue to discuss it. However, seaborn's development has become increasingly conservative, and the answer to most feature requests or proposed additions is "no". Polite requests with an explanation of the proposed feature's virtues will usually get an explanation; feature requests that say "I would like feature X, you need to add it" typically won't.
If you think there is a new feature that should be added to seaborn, you can open an issue to discuss it. But please be aware that current development efforts are mostly focused on standardizing the API and internals, and there may be relatively low enthusiasm for novel features that do not fit well into short- and medium-term development plans.
99 changes: 99 additions & 0 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
name : CI

on:
push:
branches: master
pull_request:
branches: master

env:
NB_KERNEL: python
MPLBACKEND: Agg

jobs:

build-docs:
runs-on: ubuntu-latest
steps:

- name: Checkout
uses: actions/checkout@v2

- name: Setup Python
uses: actions/setup-python@v2

- name: Install seaborn
run: |
python -m pip install --upgrade pip
pip install .[all] -r ci/utils.txt
- name: Install doc tools
run: |
pip install -r doc/requirements.txt
sudo apt-get install pandoc
- name: Build docs
run: |
make -C doc -j `nproc` notebooks
make -C doc html
run-tests:
runs-on: ubuntu-latest

strategy:
matrix:

python: [3.7.x, 3.8.x, 3.9.x]
target: [test]
install: [all]
deps: [latest]
backend: [agg]

include:
- python: 3.7.x
target: unittests
install: all
deps: pinned
backend: agg
- python: 3.9.x
target: unittests
install: light
deps: latest
backend: agg
- python: 3.9.x
target: test
install: all
deps: latest
backend: tkagg

steps:

- name: Checkout
uses: actions/checkout@v2

- name: Setup Python
uses: actions/setup-python@v2
with:
python-version: ${{ matrix.python }}

- name: Install seaborn
run: |
python -m pip install --upgrade pip
if [[ ${{matrix.install}} == 'all' ]]; then EXTRAS='[all]'; fi
if [[ ${{matrix.deps }} == 'pinned' ]]; then DEPS='-r ci/deps_pinned.txt'; fi
pip install .$EXTRAS $DEPS -r ci/utils.txt
- name: Cache datastes
run: python ci/cache_test_datasets.py

- name: Run tests
env:
MPLBACKEND: ${{ matrix.backend }}
run: |
if [[ ${{ matrix.backend }} == 'tkagg' ]]; then PREFIX='xvfb-run -a'; fi
$PREFIX make ${{ matrix.target }}
- name: Upload coverage
uses: codecov/codecov-action@v1
if: ${{ success() }}
5 changes: 4 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -7,5 +7,8 @@ seaborn.egg-info/
.cache/
.coverage
cover/
.idea
htmlcov/
.idea/
.vscode/
.pytest_cache/
notes/
3 changes: 0 additions & 3 deletions .mailmap

This file was deleted.

63 changes: 0 additions & 63 deletions .travis.yml

This file was deleted.

2 changes: 1 addition & 1 deletion LICENSE
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
Copyright (c) 2012-2019, Michael L. Waskom
Copyright (c) 2012-2021, Michael L. Waskom
All rights reserved.

Redistribution and use in source and binary forms, with or without
Expand Down
9 changes: 3 additions & 6 deletions Makefile
Original file line number Diff line number Diff line change
@@ -1,13 +1,10 @@
export SHELL := /bin/bash

test:
pytest --doctest-modules seaborn
pytest -n auto --doctest-modules --cov=seaborn --cov-config=.coveragerc seaborn

unittests:
pytest seaborn

coverage:
pytest --doctest-modules --cov=seaborn --cov-config=.coveragerc seaborn
pytest -n auto --cov=seaborn --cov-config=.coveragerc seaborn

lint:
flake8 --ignore E121,E123,E126,E226,E24,E704,E741,W503,W504 --exclude seaborn/__init__.py,seaborn/colors/__init__.py,seaborn/cm.py,seaborn/tests,seaborn/external seaborn
flake8 seaborn
71 changes: 32 additions & 39 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,40 +1,14 @@
seaborn: statistical data visualization
=======================================

<div class="row">

<a href=https://seaborn.pydata.org/examples/scatterplot_matrix.html>
<img src="https://seaborn.pydata.org/_static/scatterplot_matrix_thumb.png" height="135" width="135">
</a>

<a href=http://seaborn.pydata.org/examples/errorband_lineplots.html>
<img src="https://seaborn.pydata.org/_static/errorband_lineplots_thumb.png" height="135" width="135">
</a>

<a href=http://seaborn.pydata.org/examples/different_scatter_variables.html>
<img src="http://seaborn.pydata.org/_static/different_scatter_variables_thumb.png" height="135" width="135">
</a>

<a href=https://seaborn.pydata.org/examples/many_facets.html>
<img src="https://seaborn.pydata.org/_static/many_facets_thumb.png" height="135" width="135">
</a>

<a href=https://seaborn.pydata.org/examples/structured_heatmap.html>
<img src="https://seaborn.pydata.org/_static/structured_heatmap_thumb.png" height="135" width="135">
</a>

<a href=https://seaborn.pydata.org/examples/horizontal_boxplot.html>
<img src="https://seaborn.pydata.org/_static/horizontal_boxplot_thumb.png" height="135" width="135">
</a>

</div>
<img src="doc/_static/logo-wide-lightbg.svg"><br>

--------------------------------------

seaborn: statistical data visualization
=======================================

[![PyPI Version](https://img.shields.io/pypi/v/seaborn.svg)](https://pypi.org/project/seaborn/)
[![License](https://img.shields.io/pypi/l/seaborn.svg)](https://github.com/mwaskom/seaborn/blob/master/LICENSE)
[![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.1313201.svg)](https://doi.org/10.5281/zenodo.1313201)
[![Build Status](https://travis-ci.org/mwaskom/seaborn.svg?branch=master)](https://travis-ci.org/mwaskom/seaborn)
[![DOI](https://joss.theoj.org/papers/10.21105/joss.03021/status.svg)](https://doi.org/10.21105/joss.03021)
![Tests](https://github.com/mwaskom/seaborn/workflows/CI/badge.svg)
[![Code Coverage](https://codecov.io/gh/mwaskom/seaborn/branch/master/graph/badge.svg)](https://codecov.io/gh/mwaskom/seaborn)

Seaborn is a Python visualization library based on matplotlib. It provides a high-level interface for drawing attractive statistical graphics.
Expand All @@ -47,39 +21,58 @@ Online documentation is available at [seaborn.pydata.org](https://seaborn.pydata

The docs include a [tutorial](https://seaborn.pydata.org/tutorial.html), [example gallery](https://seaborn.pydata.org/examples/index.html), [API reference](https://seaborn.pydata.org/api.html), and other useful information.

To build the documentation locally, please refer to [`doc/README.md`](doc/README.md).

Dependencies
------------

Seaborn supports Python 2.7 and 3.5+.
Seaborn supports Python 3.7+ and no longer supports Python 2.

Installation requires [numpy](http://www.numpy.org/), [scipy](https://www.scipy.org/), [pandas](https://pandas.pydata.org/), and [matplotlib](https://matplotlib.org/). Some functions will optionally use [statsmodels](https://www.statsmodels.org/) if it is installed.
Installation requires [numpy](https://numpy.org/), [pandas](https://pandas.pydata.org/), and [matplotlib](https://matplotlib.org/). Some functions will optionally use [scipy](https://www.scipy.org/) and/or [statsmodels](https://www.statsmodels.org/) if they are available.


Installation
------------

The latest stable release (and older versions) can be installed from PyPI:
The latest stable release (and required dependencies) can be installed from PyPI:

pip install seaborn

It is also possible to include the optional dependencies:

pip install seaborn[all]

You may instead want to use the development version from Github:

pip install git+https://github.com/mwaskom/seaborn.git#egg=seaborn
pip install git+https://github.com/mwaskom/seaborn.git

Seaborn is also available from Anaconda and can be installed with conda:

conda install seaborn

Note that the main anaconda repository typically lags PyPI in adding new releases.

Citing
------

A paper describing seaborn has been published in the [Journal of Open Source Software](https://joss.theoj.org/papers/10.21105/joss.03021). The paper provides an introduction to the key features of the library, and it can be used as a citation if seaborn proves integral to a scientific publication.

Testing
-------

To test seaborn, run `make test` in the source directory.
Testing seaborn requires installing additional packages listed in `ci/utils.txt`.

To test the code, run `make test` in the source directory. This will exercise both the unit tests and docstring examples (using [pytest](https://docs.pytest.org/)) and generate a coverage report.

The doctests require a network connection (unless all example datasets are cached), but the unit tests can be run offline with `make unittests`.

This will exercise both the unit tests and docstring examples (using `pytest`).

Code style is enforced with `flake8` using the settings in the [`setup.cfg`](./setup.cfg) file. Run `make lint` to check.

Development
-----------

Seaborn development takes place on Github: https://github.com/mwaskom/seaborn

Please submit any reproducible bugs you encounter to the [issue tracker](https://github.com/mwaskom/seaborn/issues).
Please submit bugs that you encounter to the [issue tracker](https://github.com/mwaskom/seaborn/issues) with a reproducible example demonstrating the problem. Questions about usage are more at home on StackOverflow, where there is a [seaborn tag](https://stackoverflow.com/questions/tagged/seaborn).

19 changes: 19 additions & 0 deletions ci/cache_test_datasets.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
"""
Cache test datasets before running test suites to avoid
race conditions to due tests parallelization
"""
import seaborn as sns

datasets = (
"anscombe",
"attention",
"dots",
"exercise",
"flights",
"fmri",
"iris",
"planets",
"tips",
"titanic"
)
list(map(sns.load_dataset, datasets))
14 changes: 14 additions & 0 deletions ci/check_gallery.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
"""Execute the scripts that comprise the example gallery in the online docs."""
from glob import glob
import matplotlib.pyplot as plt

if __name__ == "__main__":

fnames = sorted(glob("examples/*.py"))

for fname in fnames:

print(f"- {fname}")
with open(fname) as fid:
exec(fid.read())
plt.close("all")
5 changes: 5 additions & 0 deletions ci/deps_pinned.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
numpy~=1.16.0
pandas~=0.24.0
matplotlib~=3.0.0
scipy~=1.2.0
statsmodels~=0.9.0
File renamed without changes.
4 changes: 4 additions & 0 deletions ci/utils.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
pytest!=5.3.4
pytest-cov
pytest-xdist
flake8
Loading

0 comments on commit 3045db8

Please sign in to comment.