{
  "instance_id": "matplotlib__matplotlib-24970",
  "repo": "matplotlib/matplotlib",
  "created_at": "2023-01-13T14:23:39Z",
  "problem_statement": "[Bug]: NumPy 1.24 deprecation warnings\n### Bug summary\r\n\r\nStarting NumPy 1.24 I observe several deprecation warnings.\r\n\r\n\r\n### Code for reproduction\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport numpy as np\r\n\r\nplt.get_cmap()(np.empty((0, ), dtype=np.uint8))\r\n```\r\n\r\n\r\n### Actual outcome\r\n\r\n```\r\n/usr/lib/python3.10/site-packages/matplotlib/colors.py:730: DeprecationWarning: NumPy will stop allowing conversion of out-of-bound Python integers to integer arrays.  The conversion of 257 to uint8 will fail in the future.\r\nFor the old behavior, usually:\r\n    np.array(value).astype(dtype)`\r\nwill give the desired result (the cast overflows).\r\n  xa[xa > self.N - 1] = self._i_over\r\n/usr/lib/python3.10/site-packages/matplotlib/colors.py:731: DeprecationWarning: NumPy will stop allowing conversion of out-of-bound Python integers to integer arrays.  The conversion of 256 to uint8 will fail in the future.\r\nFor the old behavior, usually:\r\n    np.array(value).astype(dtype)`\r\nwill give the desired result (the cast overflows).\r\n  xa[xa < 0] = self._i_under\r\n/usr/lib/python3.10/site-packages/matplotlib/colors.py:732: DeprecationWarning: NumPy will stop allowing conversion of out-of-bound Python integers to integer arrays.  The conversion of 258 to uint8 will fail in the future.\r\nFor the old behavior, usually:\r\n    np.array(value).astype(dtype)`\r\nwill give the desired result (the cast overflows).\r\n  xa[mask_bad] = self._i_bad\r\n```\r\n\r\n### Expected outcome\r\n\r\nNo warnings.\r\n\r\n### Additional information\r\n\r\n_No response_\r\n\r\n### Operating system\r\n\r\nArchLinux\r\n\r\n### Matplotlib Version\r\n\r\n3.6.2\r\n\r\n### Matplotlib Backend\r\n\r\nQtAgg\r\n\r\n### Python version\r\n\r\nPython 3.10.9\r\n\r\n### Jupyter version\r\n\r\n_No response_\r\n\r\n### Installation\r\n\r\nLinux package manager\n",
  "patch": "diff --git a/lib/matplotlib/colors.py b/lib/matplotlib/colors.py\n--- a/lib/matplotlib/colors.py\n+++ b/lib/matplotlib/colors.py\n@@ -715,16 +715,17 @@ def __call__(self, X, alpha=None, bytes=False):\n         if not xa.dtype.isnative:\n             xa = xa.byteswap().newbyteorder()  # Native byteorder is faster.\n         if xa.dtype.kind == \"f\":\n-            with np.errstate(invalid=\"ignore\"):\n-                xa *= self.N\n-                # Negative values are out of range, but astype(int) would\n-                # truncate them towards zero.\n-                xa[xa < 0] = -1\n-                # xa == 1 (== N after multiplication) is not out of range.\n-                xa[xa == self.N] = self.N - 1\n-                # Avoid converting large positive values to negative integers.\n-                np.clip(xa, -1, self.N, out=xa)\n-                xa = xa.astype(int)\n+            xa *= self.N\n+            # Negative values are out of range, but astype(int) would\n+            # truncate them towards zero.\n+            xa[xa < 0] = -1\n+            # xa == 1 (== N after multiplication) is not out of range.\n+            xa[xa == self.N] = self.N - 1\n+            # Avoid converting large positive values to negative integers.\n+            np.clip(xa, -1, self.N, out=xa)\n+        with np.errstate(invalid=\"ignore\"):\n+            # We need this cast for unsigned ints as well as floats\n+            xa = xa.astype(int)\n         # Set the over-range indices before the under-range;\n         # otherwise the under-range values get converted to over-range.\n         xa[xa > self.N - 1] = self._i_over\n",
  "similar_bug_items": [
    {
      "pr_number": 4050,
      "pr_title": "Fix masked array handling",
      "pr_body": "This fixes #4049, and is an alternative to #4008.  Unlike #4008, this fixes the problem directly in `_fast_from_vertices_and_codes` rather than at a number of call sites that call it.  While it does make that function slower, it apparently needs the masked array treatment from all places that call it anyway, so sticking it right inside the function seems fine.\n\nIn the process of fixing this bug, it was discovered that a fix to handle NaNs in draw_markers (cf43d57) was not brought over from the 1.4.x branch (probably my fault, since merges of C++ code are really hairy right now).  This missing bugfix was papered over by the fact that NaNs were no longer being passed to `draw_markers`.\n\nLastly, this adds an optimization to the log scaling to use NaNs rather than masked arrays.  The original array is not touched, so this should be effectively the same thing, just without the large time and memory overhead of masked arrays.\n\nThis includes a test I shamelessly cherry-picked from #4008.\n",
      "issue_id": 4049,
      "issue_title": "Issue with plotting zeros in log space",
      "issue_body": "The following simple example shows an issues with zero values when calling `loglog`:\n\n```\nimport matplotlib.pyplot as plt\n\nnu = [1e2, 1e3, 1e4, 1e5, 1e6, 1e7]\nfnu = [1, 1e-30, 1e-45, 0., 0., 0.]\n\nfig = plt.figure()\nax = fig.add_subplot(1,1,1)\nax.loglog(nu, fnu, color='blue')\nfig.savefig('mpl.png')\n```\n\nThe output is:\n\n![mpl](https://cloud.githubusercontent.com/assets/314716/5959827/8d0677cc-a7d1-11e4-8cd3-7227dee4a37a.png)\n\nOf course, zero is undefined in log space, but I don't understand why it defaults to plotting a value of 0.1 instead. Doing:\n\n```\nfnu = [1, 1e-30, 1e-45, np.nan, np.nan, np.nan]\n```\n\nDoes the right thing on the other hand. So maybe the best solution is to replace 0 values by np.nan inside `loglog`?\n\nI am using matplotlib 1.5.x with Python 3.4.\n",
      "issue_closed_at": "2015-01-30T23:18:44Z",
      "base_commit": "dd4b2bc76c800f2fae69953c888681fd67788192",
      "changes": [
        {
          "file": "lib/matplotlib/path.py",
          "type": "function",
          "name": "_fast_from_codes_and_verts",
          "class_name": "Path",
          "code": "def _fast_from_codes_and_verts(cls, verts, codes, internals=None):\n        \"\"\"\n        Creates a Path instance without the expense of calling the constructor\n\n        Parameters\n        ----------\n        verts : numpy array\n        codes : numpy array (may not be None)\n        internals : dict or None\n            The attributes that the resulting path should have.\n            Allowed keys are ``readonly``, ``should_simplify``,\n            ``simplify_threshold``, ``has_nonfinite`` and\n            ``interpolation_steps``.\n\n        \"\"\"\n        internals = internals or {}\n        pth = cls.__new__(cls)\n        pth._vertices = verts\n        pth._codes = codes\n        pth._readonly = internals.pop('readonly', False)\n        pth.should_simplify = internals.pop('should_simplify', True)\n        pth.simplify_threshold = (\n            internals.pop('simplify_threshold',\n                          rcParams['path.simplify_threshold'])\n        )\n        pth._has_nonfinite = internals.pop('has_nonfinite', False)\n        pth._interpolation_steps = internals.pop('interpolation_steps', 1)\n        if internals:\n            raise ValueError('Unexpected internals provided to '\n                             '_fast_from_codes_and_verts: '\n                             '{0}'.format('\\n *'.join(six.iterkeys(\n                                 internals\n                             ))))\n        return pth"
        },
        {
          "file": "lib/matplotlib/path.py",
          "type": "function",
          "name": "_fast_from_codes_and_verts",
          "class_name": "Path",
          "code": "def _fast_from_codes_and_verts(cls, verts, codes, internals=None):\n        \"\"\"\n        Creates a Path instance without the expense of calling the constructor\n\n        Parameters\n        ----------\n        verts : numpy array\n        codes : numpy array (may not be None)\n        internals : dict or None\n            The attributes that the resulting path should have.\n            Allowed keys are ``readonly``, ``should_simplify``,\n            ``simplify_threshold``, ``has_nonfinite`` and\n            ``interpolation_steps``.\n\n        \"\"\"\n        internals = internals or {}\n        pth = cls.__new__(cls)\n        pth._vertices = verts\n        pth._codes = codes\n        pth._readonly = internals.pop('readonly', False)\n        pth.should_simplify = internals.pop('should_simplify', True)\n        pth.simplify_threshold = (\n            internals.pop('simplify_threshold',\n                          rcParams['path.simplify_threshold'])\n        )\n        pth._has_nonfinite = internals.pop('has_nonfinite', False)\n        pth._interpolation_steps = internals.pop('interpolation_steps', 1)\n        if internals:\n            raise ValueError('Unexpected internals provided to '\n                             '_fast_from_codes_and_verts: '\n                             '{0}'.format('\\n *'.join(six.iterkeys(\n                                 internals\n                             ))))\n        return pth"
        },
        {
          "file": "lib/matplotlib/scale.py",
          "type": "function",
          "name": "get_transform",
          "class_name": "SymmetricalLogScale",
          "code": "def get_transform(self):\n        \"\"\"\n        Return a :class:`SymmetricalLogTransform` instance.\n        \"\"\"\n        return self._transform"
        }
      ]
    },
    {
      "pr_number": 16006,
      "pr_title": "Ignore pos in StrCategoryFormatter.__call__ to display correct label in the preview window ",
      "pr_body": "Fixes #14881 \r\n\r\nThe position *pos* in `__call__` can be ignored as the tick label is independent of position. So, `__call__(value, None)` would return a category label even if *pos* is `None`, which is the expected behavior.\r\n\r\nThe test case has been modified to pass only a single argument (so *pos* defaults to `None`).",
      "issue_id": 14881,
      "issue_title": "Categoricals not showing up in the preview window",
      "issue_body": "As reported by  @wuweihust on gitter,  string categorical tick labels don't show up in the preview window of an interactive plot:\r\n```python\r\n%matplotlib notebook\r\nimport matplotlib.pyplot as plt\r\nfig, ax = plt.subplots()\r\nax.plot(['hi', 'bye', 'why'], [3,1,2])\r\n```\r\n<img width=\"514\" alt=\"error\" src=\"https://user-images.githubusercontent.com/1300499/61806958-a69f3800-ae06-11e9-8483-4d36bec7bb1b.PNG\">\r\n\r\nOn gitter, @jklymak recommend implementing the `format_data_short` method for the [StrCategoryFormatter](https://github.com/matplotlib/matplotlib/blob/master/lib/matplotlib/category.py#L130). \r\n\r\nThe implementation should probably be something like the [default](https://github.com/matplotlib/matplotlib/blob/master/lib/matplotlib/ticker.py#L261):\r\n\r\n```python  \r\n    def format_data(self, value):\r\n        return self.__call__(value)\r\n\r\n    def format_data_short(self, value):\r\n        return self.format_data(value)\r\n```\r\n\r\nWhich, as an aside, why aren't these called given `StrCategoryFormatter` inherits from `Formatter`? ",
      "issue_closed_at": "2020-01-02T14:55:27Z",
      "base_commit": "a070ad53324c5a8478db85f4fa0e980eeb3d2ece",
      "changes": [
        {
          "file": "lib/matplotlib/category.py",
          "type": "function",
          "name": "__init__",
          "class_name": "UnitData",
          "code": "def __init__(self, data=None):\n        \"\"\"\n        Create mapping between unique categorical values and integer ids.\n\n        Parameters\n        ----------\n        data : iterable\n            sequence of string values\n        \"\"\"\n        self._mapping = OrderedDict()\n        self._counter = itertools.count()\n        if data is not None:\n            self.update(data)"
        }
      ]
    },
    {
      "pr_number": 24912,
      "pr_title": "Remove contour warning for \"no-valid-levels\".",
      "pr_body": "If the user explicitly passes a levels array (the default is auto-determined), let's assume that they know what they are doing.  Closes #23778.\r\n\r\n(I *could* consider keeping the warning for now in the case where the user didn't pass `levels` but `z` is uniform throughout, as that's more likely to be a \"data-exploration\" case.)\r\n\r\n## PR Summary\r\n\r\n## PR Checklist\r\n\r\n<!-- Please mark any checkboxes that do not apply to this PR as [N/A]. -->\r\n\r\n**Documentation and Tests**\r\n- [ ] Has pytest style unit tests (and `pytest` passes)\r\n- [ ] Documentation is sphinx and numpydoc compliant (the docs should [build](https://matplotlib.org/devel/documenting_mpl.html#building-the-docs) without error).\r\n- [ ] New plotting related features are documented with examples.\r\n\r\n**Release Notes**\r\n- [ ] New features are marked with a `.. versionadded::` directive in the docstring and documented in `doc/users/next_whats_new/`\r\n- [ ] API changes are marked with a `.. versionchanged::` directive in the docstring and documented in `doc/api/next_api_changes/`\r\n- [ ] Release notes conform with instructions in  `next_whats_new/README.rst` or `next_api_changes/README.rst`\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Create a separate branch for your changes and open the PR from this branch. Please avoid working on `main`.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->\r\n",
      "issue_id": 23778,
      "issue_title": "[ENH]: Allow override of contour level autoscaling",
      "issue_body": "### Problem\n\nIn Matplotlib 3, when using a list of values for the `levels` argument in `contour()`, the list of values is overridden in the case that all requested levels fall outside the data range. While this may be desirable for casually browsing data when the user is unfamiliar with the data range, it causes serious problems for batch applications where the user legitimately intends to use their list of levels but does not know whether every input array will produce contours.\r\n\r\nExample:\r\n```\r\nmyplot = plt.contour( x , y , data , levels = [100] )\r\nprint( myplot.levels )\r\n```\r\n\r\nThe above prints `[0.0]` when `data` is an array of values ranging from 0 to 50 (i.e., the requested contour level of 100 is outside the data range). As a result, the plot contains erroneous contours around near-zero values, presumably due to floating point precision.\r\n\r\nThis is a consequence of the change described here (https://matplotlib.org/stable/api/prev_api_changes/api_changes_3.0.0.html?highlight=contour%20levels):\r\n\r\n> Selection of contour levels is now the same for contour and contourf; previously, for contour, levels outside the data range were deleted. **(Exception: if no contour levels are found within the data range, the levels attribute is replaced with a list holding only the minimum of the data range.)**\n\n### Proposed solution\n\nAdd a kwarg to `contour()` that overrides the autoscaling behavior. When the kwarg is set, it would trigger a flag in `_process_contour_level_args()` (https://github.com/matplotlib/matplotlib/blob/main/lib/matplotlib/contour.py):\r\n\r\n```\r\nif not self.filled:\r\n            inside = (self.levels > self.zmin) & (self.levels < self.zmax)\r\n            levels_in = self.levels[inside]\r\n            if len(levels_in) == 0 and not(OVERRIDE_AUTOSCALE_FLAG):\r\n                self.levels = [self.zmin]\r\n                _api.warn_external(\r\n                    \"No contour levels were found within the data range.\")\r\n```",
      "issue_closed_at": "2023-01-12T21:56:55Z",
      "base_commit": "7bc69f27db70f87b59b0452216d7ae2b5babb329",
      "changes": [
        {
          "file": "lib/matplotlib/contour.py",
          "type": "function",
          "name": "_process_contour_level_args",
          "class_name": "ContourSet",
          "code": "def _process_contour_level_args(self, args, z_dtype):\n        \"\"\"\n        Determine the contour levels and store in self.levels.\n        \"\"\"\n        if self.levels is None:\n            if args:\n                levels_arg = args[0]\n            elif np.issubdtype(z_dtype, bool):\n                if self.filled:\n                    levels_arg = [0, .5, 1]\n                else:\n                    levels_arg = [.5]\n            else:\n                levels_arg = 7  # Default, hard-wired.\n        else:\n            levels_arg = self.levels\n        if isinstance(levels_arg, Integral):\n            self.levels = self._autolev(levels_arg)\n        else:\n            self.levels = np.asarray(levels_arg, np.float64)\n\n        if not self.filled:\n            inside = (self.levels > self.zmin) & (self.levels < self.zmax)\n            levels_in = self.levels[inside]\n            if len(levels_in) == 0:\n                self.levels = [self.zmin]\n                _api.warn_external(\n                    \"No contour levels were found within the data range.\")\n\n        if self.filled and len(self.levels) < 2:\n            raise ValueError(\"Filled contours require at least 2 levels.\")\n\n        if len(self.levels) > 1 and np.min(np.diff(self.levels)) <= 0.0:\n            raise ValueError(\"Contour levels must be increasing\")"
        }
      ]
    },
    {
      "pr_number": 15166,
      "pr_title": "FIX: indexed pandas bar",
      "pr_body": "## PR Summary\r\n\r\nCloses #15162\r\n\r\nbasically if you do `df = pd.DataFrame({\"x\":[1,2,3],\"width\":[.2,.4,.6]},index=[1,2,3])`, then `df.x[0]` errors because that index doesn't exist, which breaks `bar`.\r\n\r\nWhile I appreciate this is a bit *more* code than trying to call `iat(0)`, which is what we did before, this solution doesn't presuppose `iat` exists.  \r\n\r\n```python\r\nimport pandas as pd\r\nfrom matplotlib import pyplot as plt\r\nimport numpy as np\r\n\r\ndf = pd.DataFrame({\"x\":[1.,2.,3.],\"width\":[.2,.4,.6]}, index=[1, 2, 3])\r\nplt.figure()\r\nplt.bar(df.x, 1., width=df.width)\r\nplt.savefig('/Users/jklymak/downloads/Test1.png')\r\n\r\ndf = pd.DataFrame({\"x\":[1,3,10]},index=[1000,2000,3000])\r\n\r\nplt.figure()\r\nplt.bar(df.x, 1, width=.2)\r\nplt.savefig('/Users/jklymak/downloads/Test2.png')\r\n```\r\n\r\nNow yields the expected (and pre 3.1.0):\r\n\r\n![Test1](https://user-images.githubusercontent.com/1562854/64070032-8421eb00-cc0c-11e9-8967-cd933a66ac48.png)\r\n![Test2](https://user-images.githubusercontent.com/1562854/64070034-86844500-cc0c-11e9-94d4-04607d82602e.png)\r\n\r\n\r\n## PR Checklist\r\n\r\n- [ ] Has Pytest style unit tests\r\n- [ ] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/api_changes.rst if API changed in a backward-incompatible way\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Do not create the PR out of master, but out of a separate branch.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->",
      "issue_id": 15162,
      "issue_title": "axes.bar fails when x is int-indexed pandas.Series",
      "issue_body": "### Bug report\r\n\r\n#### Bug summary\r\nThe following codes fail in matplotlib 3.1.1, while work properly in 3.0.3\r\n\r\n#### case 1\r\n**Code for reproduction**\r\n```python\r\nimport pandas as pd\r\nfrom matplotlib import pyplot as plt\r\n\r\ndf = pd.DataFrame({\"x\":[1,2,3],\"width\":[.2,.4,.6]},index=[1,2,3])\r\n\r\nplt.figure()\r\nplt.bar(df.x, 1, width=df.width)\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n```\r\nTraceback (most recent call last):\r\n  File \"/Desktop/fail_example.py\", line 7, in <module>\r\n    plt.bar(df.x, 1, width=df.width)\r\n  File \"/.pyenv/versions/3.7.3/lib/python3.7/site-packages/matplotlib/pyplot.py\", line 2440, in bar\r\n    **({\"data\": data} if data is not None else {}), **kwargs)\r\n  File \"/.pyenv/versions/3.7.3/lib/python3.7/site-packages/matplotlib/__init__.py\", line 1601, in inner\r\n    return func(ax, *map(sanitize_sequence, args), **kwargs)\r\n  File \"/.pyenv/versions/3.7.3/lib/python3.7/site-packages/matplotlib/axes/_axes.py\", line 2430, in bar\r\n    label='_nolegend_',\r\n  File \"/.pyenv/versions/3.7.3/lib/python3.7/site-packages/matplotlib/patches.py\", line 707, in __init__\r\n    Patch.__init__(self, **kwargs)\r\n  File \"/.pyenv/versions/3.7.3/lib/python3.7/site-packages/matplotlib/patches.py\", line 89, in __init__\r\n    self.set_linewidth(linewidth)\r\n  File \"/.pyenv/versions/3.7.3/lib/python3.7/site-packages/matplotlib/patches.py\", line 368, in set_linewidth\r\n    self._linewidth = float(w)\r\n```\r\n\r\n**Expected outcome**\r\nOutcome in 3.0.3:\r\n![Figure_1](https://user-images.githubusercontent.com/38477252/64062230-0ddab400-cc1f-11e9-8f3b-2387eb4c04e8.png)\r\n\r\n\r\n#### case 2\r\n**Code for reproduction**\r\n```python\r\nimport pandas as pd\r\nfrom matplotlib import pyplot as plt\r\n\r\ndf = pd.DataFrame({\"x\":[1,3,10]},index=[1000,2000,3000])\r\n\r\nplt.figure()\r\nplt.bar(df.x, 1, width=.2)\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n![Figure_2](https://user-images.githubusercontent.com/38477252/64063566-b0e7f980-cc30-11e9-9dfa-a5b8c301ec6f.png)\r\n\r\n**Expected outcome**\r\nOutcome in 3.0.3:\r\n![Figure_3](https://user-images.githubusercontent.com/38477252/64063567-b2b1bd00-cc30-11e9-9418-bef1ab0b3bd2.png)\r\n\r\n\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: MacOSX\r\n  * Matplotlib version: 3.1.1 (installed from pip)\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): MacOSX\r\n  * Python version: 3.7.3\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: pandas 0.24.2\r\n\r\n**Cause of the bug**\r\n```\r\n_axes.py, line 2363 in bar:\r\n            x0 = x\r\n            x = np.asarray(self.convert_xunits(x))\r\n            width = self._convert_dx(width, x0, x, self.convert_xunits)\r\n_axes.py, line 2166 in _convert_dx: \r\n            try:\r\n                x0 = x0[0]\r\n            except (TypeError, IndexError, KeyError):\r\n                x0 = x0\r\n```\r\nI guess x0 is expected to be a scalar after this line, However when x0 is an int-indexed (and 0 is not in its indices) pandas.Series, it is continued to be pandas.Series and causes chained disorders to end in the error above.\r\nTo evidence, they worked properly when rewritten as (ugly!):\r\n```\r\n            try:\r\n                x0 = x0[0]\r\n            except (TypeError, IndexError, KeyError):\r\n                try:\r\n                    x0 = x0.iat[0]\r\n                except:\r\n                    x0 = x0\r\n```",
      "issue_closed_at": "2019-09-02T08:59:53Z",
      "base_commit": "b3fadcb90f020369f5e63b2dd71c9bad65ef958e",
      "changes": [
        {
          "file": "lib/matplotlib/axes/_axes.py",
          "type": "function",
          "name": "_convert_dx",
          "class_name": "Axes",
          "code": "def _convert_dx(dx, x0, xconv, convert):\n        \"\"\"\n        Small helper to do logic of width conversion flexibly.\n\n        *dx* and *x0* have units, but *xconv* has already been converted\n        to unitless (and is an ndarray).  This allows the *dx* to have units\n        that are different from *x0*, but are still accepted by the\n        ``__add__`` operator of *x0*.\n        \"\"\"\n\n        # x should be an array...\n        assert type(xconv) is np.ndarray\n\n        if xconv.size == 0:\n            # xconv has already been converted, but maybe empty...\n            return convert(dx)\n\n        try:\n            # attempt to add the width to x0; this works for\n            # datetime+timedelta, for instance\n\n            # only use the first element of x and x0.  This saves\n            # having to be sure addition works across the whole\n            # vector.  This is particularly an issue if\n            # x0 and dx are lists so x0 + dx just concatenates the lists.\n            # We can't just cast x0 and dx to numpy arrays because that\n            # removes the units from unit packages like `pint` that\n            # wrap numpy arrays.\n            try:\n                x0 = x0[0]\n            except (TypeError, IndexError, KeyError):\n                x0 = x0\n\n            try:\n                x = xconv[0]\n            except (TypeError, IndexError, KeyError):\n                x = xconv\n\n            delist = False\n            if not np.iterable(dx):\n                dx = [dx]\n                delist = True\n            dx = [convert(x0 + ddx) - x for ddx in dx]\n            if delist:\n                dx = dx[0]\n        except (ValueError, TypeError, AttributeError):\n            # if the above fails (for any reason) just fallback to what\n            # we do by default and convert dx by itself.\n            dx = convert(dx)\n        return dx"
        }
      ]
    },
    {
      "pr_number": 11917,
      "pr_title": "BUG: make arg 'N' and kwarg 'levels' behave the same when scalar",
      "pr_body": "Closes #11913\r\n\r\n## PR Summary\r\n\r\n## PR Checklist\r\n\r\n- [ X] Has Pytest style unit tests\r\n- [ ] Code is PEP 8 compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/api_changes.rst if API changed in a backward-incompatible way\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Do not create the PR out of master, but out of a separate branch.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->\r\n",
      "issue_id": 11913,
      "issue_title": "plt.contour levels parameter don't work as intended if receive a single int",
      "issue_body": "<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nThe official documentation (https://matplotlib.org/api/_as_gen/matplotlib.pyplot.contour.html) says that the parameter `levels` of the `pyplot.contour` function is an integer will be calculated and shown a number of contours equal to the number passed as a parameter.\r\nThe reality of the facts, however, is that the outline associated with the past value is plotted.\r\n\r\n**Code for reproduction**\r\n\r\nI used the contour demo example from https://matplotlib.org/gallery/images_contours_and_fields/contour_demo.html#contour-demo adding the `levels` parameter as int.\r\n\r\n```python\r\nimport matplotlib\r\nimport numpy as np\r\nimport matplotlib.cm as cm\r\nimport matplotlib.pyplot as plt\r\n\r\ndelta = 0.025\r\nx = np.arange(-3.0, 3.0, delta)\r\ny = np.arange(-2.0, 2.0, delta)\r\nX, Y = np.meshgrid(x, y)\r\nZ1 = np.exp(-X**2 - Y**2)\r\nZ2 = np.exp(-(X - 1)**2 - (Y - 1)**2)\r\n# the original demo had 2 here, but so most of the values would have been less than 5\r\nZ = (Z1 - Z2) * 6\r\n\r\nplt.contour(X, Y, Z, levels=5)\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n\r\n![Output_bug_1](https://i.imgur.com/BKuH99m.png)\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n**Expected outcome**\r\n\r\nAccording to official documentation I should expect 5 outlines and not the boundary associated with the value 5.\r\n![Right_outcome_1](https://i.imgur.com/wEOm7SP.png)\r\n\r\nThe expected output was obtained by modifying the penultimate line in:\r\n```python\r\nplt.contour(X, Y, Z, levels=np.linspace(np.min(Z),np.max(Z),7))\r\n```\r\n<!--A description of the expected outcome from the code snippet-->\r\n<!--If this used to work in an earlier version of Matplotlib, please note the version it used to work on-->\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: Arch Linux\r\n  * Matplotlib version: 2.2.3\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.0\r\n  * Other libraries: `numpy`\r\n\r\nAll libraries have been installed via the official ArchLinux repository\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\n",
      "issue_closed_at": "2018-08-23T02:41:46Z",
      "base_commit": "2fb8c69e99e3e26e6edf0a23cb43e47d3fd71d6c",
      "changes": [
        {
          "file": "lib/matplotlib/contour.py",
          "type": "function",
          "name": "_contour_level_args",
          "class_name": "ContourSet",
          "code": "def _contour_level_args(self, z, args):\n        \"\"\"\n        Determine the contour levels and store in self.levels.\n        \"\"\"\n        if self.filled:\n            fn = 'contourf'\n        else:\n            fn = 'contour'\n        self._auto = False\n        if self.levels is None:\n            if len(args) == 0:\n                lev = self._autolev(7)\n            else:\n                level_arg = args[0]\n                try:\n                    if isinstance(level_arg, Integral):\n                        lev = self._autolev(level_arg)\n                    else:\n                        lev = np.asarray(level_arg).astype(np.float64)\n                except:\n                    raise TypeError(\n                        \"Last {0} arg must give levels; see help({0})\"\n                        .format(fn))\n            self.levels = lev\n        else:\n            self.levels = np.asarray(self.levels).astype(np.float64)\n\n        if not self.filled:\n            inside = (self.levels > self.zmin) & (self.levels < self.zmax)\n            levels_in = self.levels[inside]\n            if len(levels_in) == 0:\n                self.levels = [self.zmin]\n                warnings.warn(\"No contour levels were found\"\n                              \" within the data range.\")\n\n        if self.filled and len(self.levels) < 2:\n            raise ValueError(\"Filled contours require at least 2 levels.\")\n\n        if len(self.levels) > 1 and np.min(np.diff(self.levels)) <= 0.0:\n            raise ValueError(\"Contour levels must be increasing\")"
        }
      ]
    }
  ]
}