{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-22835",
    "repo": "matplotlib/matplotlib",
    "created_at": "2022-04-12T23:13:58Z",
    "problem_statement": "[Bug]: scalar mappable format_cursor_data crashes on BoundarNorm\n### Bug summary\r\n\r\nIn 3.5.0 if you do:\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport numpy as np\r\nimport matplotlib as mpl\r\n\r\nfig, ax = plt.subplots()\r\nnorm = mpl.colors.BoundaryNorm(np.linspace(-4, 4, 5), 256)\r\nX = np.random.randn(10, 10)\r\npc = ax.imshow(X, cmap='RdBu_r', norm=norm)\r\n```\r\n\r\nand mouse over the image, it crashes with\r\n\r\n```\r\nFile \"/Users/jklymak/matplotlib/lib/matplotlib/artist.py\", line 1282, in format_cursor_data\r\n    neighbors = self.norm.inverse(\r\n  File \"/Users/jklymak/matplotlib/lib/matplotlib/colors.py\", line 1829, in inverse\r\n    raise ValueError(\"BoundaryNorm is not invertible\")\r\nValueError: BoundaryNorm is not invertible\r\n```\r\n\r\nand interaction stops.  \r\n\r\nNot sure if we should have a special check here, a try-except, or actually just make BoundaryNorm approximately invertible.  \r\n\r\n\r\n### Matplotlib Version\r\n\r\nmain 3.5.0\r\n\r\n\n[Bug]: scalar mappable format_cursor_data crashes on BoundarNorm\n### Bug summary\r\n\r\nIn 3.5.0 if you do:\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport numpy as np\r\nimport matplotlib as mpl\r\n\r\nfig, ax = plt.subplots()\r\nnorm = mpl.colors.BoundaryNorm(np.linspace(-4, 4, 5), 256)\r\nX = np.random.randn(10, 10)\r\npc = ax.imshow(X, cmap='RdBu_r', norm=norm)\r\n```\r\n\r\nand mouse over the image, it crashes with\r\n\r\n```\r\nFile \"/Users/jklymak/matplotlib/lib/matplotlib/artist.py\", line 1282, in format_cursor_data\r\n    neighbors = self.norm.inverse(\r\n  File \"/Users/jklymak/matplotlib/lib/matplotlib/colors.py\", line 1829, in inverse\r\n    raise ValueError(\"BoundaryNorm is not invertible\")\r\nValueError: BoundaryNorm is not invertible\r\n```\r\n\r\nand interaction stops.  \r\n\r\nNot sure if we should have a special check here, a try-except, or actually just make BoundaryNorm approximately invertible.  \r\n\r\n\r\n### Matplotlib Version\r\n\r\nmain 3.5.0\r\n\r\n\n",
    "patch": "diff --git a/lib/matplotlib/artist.py b/lib/matplotlib/artist.py\n--- a/lib/matplotlib/artist.py\n+++ b/lib/matplotlib/artist.py\n@@ -12,6 +12,7 @@\n \n import matplotlib as mpl\n from . import _api, cbook\n+from .colors import BoundaryNorm\n from .cm import ScalarMappable\n from .path import Path\n from .transforms import (Bbox, IdentityTransform, Transform, TransformedBbox,\n@@ -1303,10 +1304,20 @@ def format_cursor_data(self, data):\n                 return \"[]\"\n             normed = self.norm(data)\n             if np.isfinite(normed):\n-                # Midpoints of neighboring color intervals.\n-                neighbors = self.norm.inverse(\n-                    (int(self.norm(data) * n) + np.array([0, 1])) / n)\n-                delta = abs(neighbors - data).max()\n+                if isinstance(self.norm, BoundaryNorm):\n+                    # not an invertible normalization mapping\n+                    cur_idx = np.argmin(np.abs(self.norm.boundaries - data))\n+                    neigh_idx = max(0, cur_idx - 1)\n+                    # use max diff to prevent delta == 0\n+                    delta = np.diff(\n+                        self.norm.boundaries[neigh_idx:cur_idx + 2]\n+                    ).max()\n+\n+                else:\n+                    # Midpoints of neighboring color intervals.\n+                    neighbors = self.norm.inverse(\n+                        (int(normed * n) + np.array([0, 1])) / n)\n+                    delta = abs(neighbors - data).max()\n                 g_sig_digits = cbook._g_sig_digits(data, delta)\n             else:\n                 g_sig_digits = 3  # Consistent with default below.\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_14011",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue involves argument handling in a function, which is unrelated to the invertibility problem in the current issue."
      },
      {
        "idx": 2,
        "id": "similar_12893",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about toolbar item management in a GUI, which does not relate to the invertibility or error handling in the current issue."
      },
      {
        "idx": 3,
        "id": "similar_19736",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue deals with ordering of axes, which is unrelated to the invertibility and error handling in the current issue."
      },
      {
        "idx": 4,
        "id": "similar_12458",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue involves visual representation in colorbars, which does not share reasoning patterns with the invertibility problem."
      },
      {
        "idx": 5,
        "id": "similar_17114",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about deprecation warnings for argument handling, unrelated to the invertibility and error handling in the current issue."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "TypeError on plt.subplot(figure=plt.figure())",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\nWhen calling `plt.subplot` with a `figure` argument, we get:\r\n```\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\nThe argument 'figure' is specified in the [doc](https://matplotlib.org/api/_as_gen/matplotlib.pyplot.subplot.html)\r\n\r\nThe function `plt.subplot` uses `plt.gcf()` to get the current figure. It should check whether a figure was provided, eg. `fig = kwargs.pop('figure') if kwargs.get('figure') else plt.gcf()`\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nplt.subplot(figure=plt.figure())\r\n# OR EVEN\r\nplt.subplot(figure=None)\r\n```\r\n\r\n**Actual outcome**\r\n```                              \r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n<ipython-input-30-bdfa817205a7> in <module>\r\n----> 1 plt.subplot(figure=None)\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/pyplot.py in subplot(*args, **kwargs)\r\n   1082 \r\n   1083     fig = gcf()\r\n-> 1084     a = fig.add_subplot(*args, **kwargs)\r\n   1085     bbox = a.bbox\r\n   1086     byebye = []\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/figure.py in add_subplot(self, *args, **kwargs)\r\n   1347         else:\r\n   1348             projection_class, kwargs, key = process_projection_requirements(\r\n-> 1349                 self, *args, **kwargs)\r\n   1350 \r\n   1351             # try to find the axes with this key in the stack\r\n\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\n\r\n**Matplotlib version**\r\n  * Operating system: Linux\r\n  * Matplotlib version: 3.0.2 (with conda and with pip)\r\n  * Matplotlib backend: Qt5Agg\r\n  * Python version: tested on 3.7.2 and 3.5\r\n\r\n",
        "issue_id": 14011,
        "pr_number": 14014,
        "pr_title": "Disallow figure argument for pyplot.subplot() and Figure.add_subplot()",
        "pr_body": "## PR Summary\r\n\r\nCloses #14011.\r\n\r\n`Figure.add_subplot()` and `pyplot.subplot()` have technically accepted a `figure` keyword argument by allowing all keywords from the `Axes` constructor.\r\n\r\nIn this context, supplying a figure does not make sense since the axes should be bound to `self` or the current figure respecively.\r\n\r\nI'm daring to go without a deprecation since this anyway did only work so far if the user supplied the same figure that would have been used without the parameter. Please let me know if that's too bold and we should deprecate this first.",
        "issue_closed_at": "2019-05-28T22:25:29Z",
        "base_commit": "559925e3ec43a5cbe1697a4496482d38d8489f68"
      },
      "summary": "### Summary:\n\nThis issue is related to a TypeError encountered when using the `plt.subplot` function in the Matplotlib library. The error arises when a `figure` argument is explicitly provided to `plt.subplot`, which leads to a conflict in argument assignment during the execution of `process_projection_requirements()`, resulting in a \"multiple values for argument 'figure'\" error. This issue occurs because the `plt.subplot` function does not correctly handle the presence of a `figure` argument, instead relying on `plt.gcf()` to obtain the current figure without checking if a figure was explicitly provided.\n\nKey symptoms include the generation of a TypeError when attempting to create a subplot with a specified figure, either as a new figure object or as `None`. This affects the functionality of the `subplot` function in scenarios where users attempt to manually specify the figure, which can disrupt workflows that rely on this flexibility.\n\nThe affected components include the `subplot` function in the `lib/matplotlib/pyplot.py` module and the `add_subplot` function in the `lib/matplotlib/figure.py` module. The issue impacts users working with Matplotlib version 3.0.2 on Linux systems, using Python versions 3.7.2 and 3.5, particularly those utilizing the Qt5Agg backend.\n\nThe potential impact of this issue is significant for users who need to explicitly manage figures when creating subplots, as it prevents the correct execution of their scripts and can lead to confusion due to the misleading error message.\n\nRelevant technical details indicate that the problem could be mitigated by modifying the `subplot` function to check for and correctly handle the presence of a `figure` argument before defaulting to the current figure. This adjustment would ensure compatibility with user-specified figures, aligning the function's behavior with the documentation and user expectations.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: TypeError on plt.subplot(figure=plt.figure())\n\nBody:\n### Bug report\r\n\r\n**Bug summary**\r\nWhen calling `plt.subplot` with a `figure` argument, we get:\r\n```\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\nThe argument 'figure' is specified in the [doc](https://matplotlib.org/api/_as_gen/matplotlib.pyplot.subplot.html)\r\n\r\nThe function `plt.subplot` uses `plt.gcf()` to get the current figure. It should check whether a figure was provided, eg. `fig = kwargs.pop('figure') if kwargs.get('figure') else plt.gcf()`\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nplt.subplot(figure=plt.figure())\r\n# OR EVEN\r\nplt.subplot(figure=None)\r\n```\r\n\r\n**Actual outcome**\r\n```                              \r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n<ipython-input-30-bdfa817205a7> in <module>\r\n----> 1 plt.subplot(figure=None)\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/pyplot.py in subplot(*args, **kwargs)\r\n   1082 \r\n   1083     fig = gcf()\r\n-> 1084     a = fig.add_subplot(*args, **kwargs)\r\n   1085     bbox = a.bbox\r\n   1086     byebye = []\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/figure.py in add_subplot(self, *args, **kwargs)\r\n   1347         else:\r\n   1348             projection_class, kwargs, key = process_projection_requirements(\r\n-> 1349                 self, *args, **kwargs)\r\n   1350 \r\n   1351             # try to find the axes with this key in the stack\r\n\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\n\r\n**Matplotlib version**\r\n  * Operating system: Linux\r\n  * Matplotlib version: 3.0.2 (with conda and with pip)\r\n  * Matplotlib backend: Qt5Agg\r\n  * Python version: tested on 3.7.2 and 3.5\r\n\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/figure.py\n  function: Figure.add_subplot\n  function: Figure.add_subplot\n\nlib/matplotlib/pyplot.py\n  function: subplot\n"
    },
    {
      "similar_issue": {
        "issue_title": "[PyQt] NavigationToolbar2QT : Error when removing tools",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\n\r\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n\r\n**Code**\r\n\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\r\n```python\r\nclass FigureWidget(QtWidgets.QWidget):\r\n    \"\"\"Figure widget used by different views\r\n\r\n    Parameters\r\n    ----------\r\n    parent : Qt parent\r\n       Qt parent object\r\n    canvas : FigureCanvas\r\n       the figure canvas class\r\n    exclude_toolbar_items : tuple\r\n       elements to exclude from the toolbar\r\n    \"\"\"\r\n    def __init__(self, parent=None, canvas=None, exclude_toolbar_items=()):\r\n        super().__init__(parent)\r\n\r\n        self.canvas = canvas\r\n        self.layout = QtWidgets.QVBoxLayout()\r\n        self.layout.addWidget(self.canvas)\r\n\r\n        if isinstance(canvas, FigureCanvas):\r\n          class _SimpleNavigationToolbar(NavigationToolbar):\r\n            # only display the buttons we need\r\n            toolitems = [t for t in NavigationToolbar.toolitems if\r\n                        t[0] not in exclude_toolbar_items]\r\n          self.toolbar = _SimpleNavigationToolbar(self.canvas, self.canvas)\r\n\r\n          self.layout.addWidget(self.toolbar)\r\n      else:\r\n          self.toolbar = None\r\n\r\n      self.setLayout(self.layout)\r\n```\r\n\r\n**Error example**\r\n\r\nWhen **exclude_toolbar_items=('Pan',))**, we get the following result on our window :\r\n\r\n![toolbar_error](https://user-images.githubusercontent.com/39213808/49034667-e5ff8100-f1b2-11e8-80d2-25ad2ca06d02.png)\r\n\r\nBut if we click on the **Zoom** button (_encircled in red_), we get the error message on the log and written just below as if the **Pan** button stills exists.\r\n\r\n```\r\n2018-11-26 19:35:01.566 [ERROR]\t[utils.py:28]\t\tUncaught exception\r\nTraceback (most recent call last):\r\n  File \"C:\\Users\\Renaud Gautier\\Anaconda3\\envs\\some_env\\lib\\site-packages\\matplotlib\\backends\\backend_qt5.py\", line 803, in zoom\r\n    self._update_buttons_checked()\r\n  File \"C:\\Users\\Renaud Gautier\\Anaconda3\\envs\\some_env\\lib\\site-packages\\matplotlib\\backends\\backend_qt5.py\", line 794, in _update_buttons_checked\r\n    self._actions['pan'].setChecked(self._active == 'PAN')\r\nKeyError: 'pan'\r\n```\r\n\r\n**Matplotlib version**\r\n\r\n  * Operating system: Windows 10\r\n  * Matplotlib version: 3.0.2\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.1\r\n  * Other libraries: PyQt 5 (PySide)\r\n\r\n\r\n",
        "issue_id": 12893,
        "pr_number": 14719,
        "pr_title": "Make Qt navtoolbar more robust against removal of either pan or zoom.",
        "pr_body": "... by using a QButtonGroup to ensure that a button gets unchecked when\r\nthe other gets checked.\r\n\r\nCloses #12893.\r\n\r\n## PR Summary\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-->\r\n",
        "issue_closed_at": "2019-07-17T18:39:21Z",
        "base_commit": "9f1c7306d23cd9eac858897b3c873c8314e300cf"
      },
      "summary": "### Summary:\n\nThis issue is related to a bug in the PyQt NavigationToolbar2QT component of the Matplotlib library, specifically when managing toolbar items within a GUI application. The problem arises when certain tools, such as the \"Pan\" tool, are removed from the toolbar using the `exclude_toolbar_items` parameter in a custom `FigureWidget` class. Despite the removal of these tools, actions within the toolbar, such as clicking the \"Zoom\" button, still reference the removed tools, leading to a `KeyError` when the application attempts to access non-existent toolbar actions.\n\nKey symptoms include:\n1. GUI components displaying incorrect behavior despite the toolbar being customized to exclude specific items.\n2. Errors are logged when interacting with toolbar buttons, indicating that the application is attempting to perform actions on non-existent tools.\n3. The error specifically highlights a failure when updating the state of toolbar buttons, such as checking the status of a \"Pan\" button that has been excluded.\n\nThe affected components are:\n- Matplotlib's NavigationToolbar2QT in the Qt5Agg backend.\n- The `FigureWidget` class using the toolbar, which is part of a PyQt application.\n\nThe impact of this issue is moderate, as it affects the user interface's functionality and could lead to confusion or application crashes during interaction with the toolbar. Technical users relying on Matplotlib's GUI features would encounter usability issues when customizing toolbars, particularly when excluding certain items.\n\nRelevant technical details include:\n- The error occurs due to the toolbar's internal management of tool actions, which does not account for the dynamic exclusion of tools.\n- The `KeyError` arises from attempting to check the status of a removed action, highlighting a gap in the robustness of toolbar customization logic.\n- The issue affects applications running on Python 3.7.1 with Matplotlib version 3.0.2 and the PyQt5 library on Windows 10.\n\nThe changes made in the patch likely address these issues by enhancing the toolbar's initialization and action management to properly handle excluded items, preventing the `KeyError` and ensuring consistent behavior across the application.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: [PyQt] NavigationToolbar2QT : Error when removing tools\n\nBody:\n### Bug report\r\n\r\n**Bug summary**\r\n\r\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n\r\n**Code**\r\n\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\r\n```python\r\nclass FigureWidget(QtWidgets.QWidget):\r\n    \"\"\"Figure widget used by different views\r\n\r\n    Parameters\r\n    ----------\r\n    parent : Qt parent\r\n       Qt parent object\r\n    canvas : FigureCanvas\r\n       the figure canvas class\r\n    exclude_toolbar_items : tuple\r\n       elements to exclude from the toolbar\r\n    \"\"\"\r\n    def __init__(self, parent=None, canvas=None, exclude_toolbar_items=()):\r\n        super().__init__(parent)\r\n\r\n        self.canvas = canvas\r\n        self.layout = QtWidgets.QVBoxLayout()\r\n        self.layout.addWidget(self.canvas)\r\n\r\n        if isinstance(canvas, FigureCanvas):\r\n          class _SimpleNavigationToolbar(NavigationToolbar):\r\n            # only display the buttons we need\r\n            toolitems = [t for t in NavigationToolbar.toolitems if\r\n                        t[0] not in exclude_toolbar_items]\r\n          self.toolbar = _SimpleNavigationToolbar(self.canvas, self.canvas)\r\n\r\n          self.layout.addWidget(self.toolbar)\r\n      else:\r\n          self.toolbar = None\r\n\r\n      self.setLayout(self.layout)\r\n```\r\n\r\n**Error example**\r\n\r\nWhen **exclude_toolbar_items=('Pan',))**, we get the following result on our window :\r\n\r\n![toolbar_error](https://user-images.githubusercontent.com/39213808/49034667-e5ff8100-f1b2-11e8-80d2-25ad2ca06d02.png)\r\n\r\nBut if we click on the **Zoom** button (_encircled in red_), we get the error message on the log and written just below as if the **Pan** button stills exists.\r\n\r\n```\r\n2018-11-26 19:35:01.566 [ERROR]\t[utils.py:28]\t\tUncaught exception\r\nTraceback (most recent call last):\r\n  File \"C:\\Users\\Renaud Gautier\\Anaconda3\\envs\\some_env\\lib\\site-packages\\matplotlib\\backends\\backend_qt5.py\", line 803, in zoom\r\n    self._update_buttons_checked()\r\n  File \"C:\\Users\\Renaud Gautier\\Anaconda3\\envs\\some_env\\lib\\site-packages\\matplotlib\\backends\\backend_qt5.py\", line 794, in _update_buttons_checked\r\n    self._actions['pan'].setChecked(self._active == 'PAN')\r\nKeyError: 'pan'\r\n```\r\n\r\n**Matplotlib version**\r\n\r\n  * Operating system: Windows 10\r\n  * Matplotlib version: 3.0.2\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.1\r\n  * Other libraries: PyQt 5 (PySide)\r\n\r\n\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/backends/backend_qt5.py\n  function: ToolbarQt._icon\n  function: NavigationToolbar2QT._init_toolbar\n  function: NavigationToolbar2QT.edit_parameters\n"
    },
    {
      "similar_issue": {
        "issue_title": "subplot_mosaic axes are not added in consistent order",
        "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 axes of a subplot_mosaic show up in a random order in `fig.axes` (likely due to the use of a `set` for uniquification in `_identify_keys_and_nested`).\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug.\r\nPlease make sure to minimize the number of dependencies required, and provide\r\nany necessary plotted data.\r\nAvoid using threads, as Matplotlib is (explicitly) not thread-safe.-->\r\n\r\n```sh\r\nfor _ in $(seq 10); do python -c 'from pylab import *; fig, axs = subplot_mosaic(\"ab\"); print(fig.axes.index(axs[\"a\"]))'; done\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n1\r\n0\r\n1\r\n1\r\n1\r\n0\r\n0\r\n0\r\n0\r\n1\r\n```\r\n\r\n**Expected outcome**\r\n\r\nAxes should be added in a consistent order.  I guess a reasonable one would be as if iterating the spec in C order (dropping duplicates).\r\n\r\nNot release critical (especially as the order was not fixed, so fixing an order is not a backcompat break), but would be nice to get this sorted out before the API moves out of being experimental.\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: linux\r\n  * Matplotlib version (`import matplotlib; print(matplotlib.__version__)`): head\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): any\r\n  * Python version: 39\r\n  * Jupyter version (if applicable): \r\n  * Other libraries: \r\n\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---\r\n\r\nNote: the simple solution of replacing `unique_ids = set()` by `unique_ids = cbook._OrderedSet()` is good enough for the non-nested case, but doesn't handle nested layouts such as `subplot_mosaic([[\"a\", [[\"b1\", \"b2\"], [\"b3\", \"b4\"]]], [\"c\", \"d\"]])` because currently the nested submosaic is always added after all the non-nested axes.",
        "issue_id": 19736,
        "pr_number": 19964,
        "pr_title": "FIX: add subplot_mosaic axes in the order the user gave them to us",
        "pr_body": "## PR Summary\r\n\r\nThe order the Axes are added to the Figure (and hence the order they are in\r\nthe returned dictionary and fig.axes) is now based on the first time we see the\r\nkey if the layout were recursively unraveled as a c-style array.\r\n\r\nCloses #19736\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- [x] Has pytest style unit tests (and `pytest` passes).\r\n- [x] Is [Flake 8](https://flake8.pycqa.org/en/latest/) compliant (run `flake8` on changed files to check).\r\n- [x] Conforms to Matplotlib style conventions (install `flake8-docstrings` and run `flake8 --docstring-convention=all`).\r\n- [ ] API changes documented in `doc/api/next_api_changes/` (follow instructions in README.rst there).\r\n\r\nI don't think this needs an API change note as the order was previously unreliable.",
        "issue_closed_at": "2021-04-16T21:43:45Z",
        "base_commit": "a051169c1b51a36c270b7b696ec86fae8f2f23e8"
      },
      "summary": "### Summary:\nThis issue pertains to the inconsistency in the ordering of axes when using the `subplot_mosaic` function in Matplotlib, a popular plotting library. The problem arises due to the current method of handling unique identifiers within the function, specifically utilizing a `set` which inherently does not maintain order. This unordered behavior results in the axes being added to the figure in a seemingly random sequence, which can vary between executions. The primary symptom of this issue is the inconsistent index positions of axes within the `fig.axes` list when using the `subplot_mosaic` function. This inconsistency disrupts the expected behavior where axes should be added in a predictable and consistent order, ideally following a sequence akin to iterating over the specification in C order, while avoiding duplicates.\n\nThe affected components are primarily functions within the Matplotlib library responsible for layout handling, particularly `_identify_keys_and_nested` and `_do_layout` in `figure.py`. The severity of this issue is moderate; it is not critical for release stability, as it does not break backward compatibility, but addressing it is important for finalizing the API's behavior out of its experimental stage. Technically, the issue could be mitigated by switching from a `set` to an ordered collection, like `cbook._OrderedSet`, to preserve the order of axes consistently, although additional considerations are needed for nested layouts within the mosaic configurations.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: subplot_mosaic axes are not added in consistent order\n\nBody:\n<!--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 axes of a subplot_mosaic show up in a random order in `fig.axes` (likely due to the use of a `set` for uniquification in `_identify_keys_and_nested`).\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug.\r\nPlease make sure to minimize the number of dependencies required, and provide\r\nany necessary plotted data.\r\nAvoid using threads, as Matplotlib is (explicitly) not thread-safe.-->\r\n\r\n```sh\r\nfor _ in $(seq 10); do python -c 'from pylab import *; fig, axs = subplot_mosaic(\"ab\"); print(fig.axes.index(axs[\"a\"]))'; done\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n1\r\n0\r\n1\r\n1\r\n1\r\n0\r\n0\r\n0\r\n0\r\n1\r\n```\r\n\r\n**Expected outcome**\r\n\r\nAxes should be added in a consistent order.  I guess a reasonable one would be as if iterating the spec in C order (dropping duplicates).\r\n\r\nNot release critical (especially as the order was not fixed, so fixing an order is not a backcompat break), but would be nice to get this sorted out before the API moves out of being experimental.\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: linux\r\n  * Matplotlib version (`import matplotlib; print(matplotlib.__version__)`): head\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): any\r\n  * Python version: 39\r\n  * Jupyter version (if applicable): \r\n  * Other libraries: \r\n\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---\r\n\r\nNote: the simple solution of replacing `unique_ids = set()` by `unique_ids = cbook._OrderedSet()` is good enough for the non-nested case, but doesn't handle nested layouts such as `subplot_mosaic([[\"a\", [[\"b1\", \"b2\"], [\"b3\", \"b4\"]]], [\"c\", \"d\"]])` because currently the nested submosaic is always added after all the non-nested axes.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/figure.py\n  function: FigureBase._identify_keys_and_nested\n  function: FigureBase._identify_keys_and_nested\n  function: FigureBase._do_layout\n  function: FigureBase._do_layout\n"
    },
    {
      "similar_issue": {
        "issue_title": "add_lines misses lines for matplotlib.colorbar.ColorbarBase",
        "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\nFor matplotlib.colorbar.ColorbarBase(...) usage of add_lines(...) may yield missing lines/poorly adjusted lines.\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport matplotlib as mpl\r\nimport numpy as np\r\n\r\nfig = plt.figure()\r\nax = fig.add_axes([0.05, 0.8, 0.9, 0.15])\r\ncmap = mpl.cm.cool\r\nnorm = mpl.colors.Normalize(vmin=-4, vmax=4)\r\nlevels = (-1.0, 1.0, 2.0, 3.0)\r\n\r\ncb = mpl.colorbar.ColorbarBase(ax, cmap=cmap, norm=norm)\r\ncolors_bg = np.tile(list((1.0, 1.0, 1.0, 1.0)), (len(levels), 1))\r\ncb.add_lines(levels=levels, colors=colors_bg, linewidths=7)\r\n\r\nplt.show()\r\n\r\n\r\n```\r\n\r\n**Expected outcome**\r\n\r\n4 white lines, crossing the colorbar.\r\nUsed to work on matplotlib 2.2.3!\r\n\r\n**Matplotlib version**\r\n  * Operating system: Ubuntu 18.04 LTS\r\n  * Matplotlib version: 3.0.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.0\r\n\r\nMiniconda install, fully updated.",
        "issue_id": 12458,
        "pr_number": 12461,
        "pr_title": "FIX: make add_lines work with new colorbar",
        "pr_body": "## PR Summary\r\n\r\nCloses #12458\r\n\r\nSee below for a less pathological example...\r\n\r\n`cbar.add_lines` was not operational after new colorbar changes in 3.0.0.  \r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport matplotlib as mpl\r\nimport numpy as np\r\n\r\nfig = plt.figure()\r\nax = fig.add_axes([0.05, 0.8, 0.9, 0.15])\r\ncmap = mpl.cm.cool\r\nnorm = mpl.colors.Normalize(vmin=-4, vmax=4)\r\nlevels = (-1.0, 1.0, 2.0, 3.0)\r\n\r\ncb = mpl.colorbar.ColorbarBase(ax, cmap=cmap, norm=norm)\r\ncolors_bg = np.tile(list((1.0, 1.0, 1.0, 1.0)), (len(levels), 1))\r\ncb.add_lines(levels=levels, colors=colors_bg, linewidths=1)\r\n\r\n```\r\n\r\n## Before\r\n![cbarold](https://user-images.githubusercontent.com/1562854/46681303-ce871d00-cb9f-11e8-8acd-e5defedfe90c.png)\r\n\r\n\r\n## After\r\n\r\n![cbarnew](https://user-images.githubusercontent.com/1562854/46681265-b3b4a880-cb9f-11e8-8efd-87b24d565751.png)\r\n\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\nfig, ax = plt.subplots()\r\nX = np.random.rand(10, 10)*10000\r\npcm = ax.pcolormesh(X)\r\n# add 1000 to make colors visible...\r\ncont = ax.contour(X+1000)\r\ncb = fig.colorbar(pcm)\r\ncb.add_lines(cont)\r\nplt.show()\r\n```\r\n\r\n## Before\r\n\r\n![before](https://user-images.githubusercontent.com/1562854/46701766-b4683180-cbd5-11e8-8c18-d994ba47e396.png)\r\n\r\n## After\r\n![new](https://user-images.githubusercontent.com/1562854/46701741-9d294400-cbd5-11e8-9006-708b7ef51fdc.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_closed_at": "2018-10-14T19:38:43Z",
        "base_commit": "f93222a555160bf967f02dae42cce39a03384774"
      },
      "summary": "### Summary:\n\nThis issue pertains to the `add_lines` method of the `ColorbarBase` class in the Matplotlib library, which is responsible for adding lines to a colorbar. Users have reported that when using this method, some lines may be missing or improperly adjusted, leading to incorrect visual representation in colorbars. This problem was identified in Matplotlib version 3.0.0, despite the code functioning as expected in version 2.2.3. The issue is specifically observed when users attempt to add multiple lines with specific color and width settings, expecting them to cross the colorbar as intended. The problem affects users employing the Qt5Agg backend on Ubuntu 18.04 LTS, using Python 3.7.0. The severity of the issue lies in its impact on the visual accuracy of data presentations, which is crucial for users relying on precise graphical outputs. The affected component is the `Colorbar.add_lines` function within the `lib/matplotlib/colorbar.py` file, necessitating a fix to restore the expected functionality and visual outcome.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: add_lines misses lines for matplotlib.colorbar.ColorbarBase\n\nBody:\n<!--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\nFor matplotlib.colorbar.ColorbarBase(...) usage of add_lines(...) may yield missing lines/poorly adjusted lines.\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport matplotlib as mpl\r\nimport numpy as np\r\n\r\nfig = plt.figure()\r\nax = fig.add_axes([0.05, 0.8, 0.9, 0.15])\r\ncmap = mpl.cm.cool\r\nnorm = mpl.colors.Normalize(vmin=-4, vmax=4)\r\nlevels = (-1.0, 1.0, 2.0, 3.0)\r\n\r\ncb = mpl.colorbar.ColorbarBase(ax, cmap=cmap, norm=norm)\r\ncolors_bg = np.tile(list((1.0, 1.0, 1.0, 1.0)), (len(levels), 1))\r\ncb.add_lines(levels=levels, colors=colors_bg, linewidths=7)\r\n\r\nplt.show()\r\n\r\n\r\n```\r\n\r\n**Expected outcome**\r\n\r\n4 white lines, crossing the colorbar.\r\nUsed to work on matplotlib 2.2.3!\r\n\r\n**Matplotlib version**\r\n  * Operating system: Ubuntu 18.04 LTS\r\n  * Matplotlib version: 3.0.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.0\r\n\r\nMiniconda install, fully updated.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/colorbar.py\n  function: Colorbar.add_lines\n"
    },
    {
      "similar_issue": {
        "issue_title": "`add_axes` shows deprecation warning when called with only `kwarg`s",
        "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\nCalling `add_axes` without args is deprecated. However, if a kwarg is passed, the deprecation warning still shows.\r\n\r\n\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug.\r\nPlease make sure to minimize the number of dependencies required, and provide\r\nany necessary plotted data.\r\nAvoid using threads, as Matplotlib is (explicitly) not thread-safe.-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nfig = plt.figure()\r\nax = fig.add_axes(rect=[0, 0, 1, 1])\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n<ipython-input-128-1ef4234f1c1f>:3: MatplotlibDeprecationWarning: Calling add_axes() without argument is deprecated. You may want to use add_subplot() instead.\r\n  ax = fig.add_axes(rect=[0, 0, 1, 1])\r\n```\r\n\r\n**Expected outcome**\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\nNo warning should be shown.\r\n\r\n**Discussion**\r\n\r\n`figure.add_axes` currently starts with\r\n\r\n```\r\n        if not len(args):\r\n            cbook.warn_deprecated(\r\n                \"3.3\",\r\n                message=\"Calling add_axes() without argument is \"\r\n                \"deprecated. You may want to use add_subplot() \"\r\n                \"instead.\")\r\n            return\r\n```\r\n\r\nBecause the function forwards `kwargs`, the intended behavior is a bit ambiguous to me, but I'm assuming from the docstring that the intention is to force the user to pass `rect` specifically? \r\n\r\n```\r\nif not len(args) and 'rect' not in kwargs:\r\n    ...\r\n```\r\n\r\nI can make this a PR if necessary, but if I'm not sure if we continue to update 3.2...And I don't know what the deprecation schedule even looks like for removing the \"ability to use no args\", so I don't know if this will even be an issue after 3.3....just wanted to point it out.\r\n\r\nFeel free to close if this is a non-issue.",
        "issue_id": 17114,
        "pr_number": 17142,
        "pr_title": "BUGFIX: conditional for add_axes arg deprecation",
        "pr_body": "## PR Summary\r\n\r\nFixes #17114.\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-->\r\n",
        "issue_closed_at": "2020-04-15T08:44:02Z",
        "base_commit": "e55e79b97d0b3ff772a4f7aaa0fb15193d84300c"
      },
      "summary": "### Summary:\nThis issue pertains to a deprecation warning in the Matplotlib library related to the `add_axes` method of the `Figure` class. The problem arises when the `add_axes` method is called using only keyword arguments, specifically when passing the `rect` keyword argument. Despite providing the necessary information via keyword arguments, the method still triggers a deprecation warning, indicating that calling `add_axes` without arguments is deprecated and suggesting the use of `add_subplot` instead. The warning should not occur when valid keyword arguments are supplied, as they effectively fulfill the requirement of providing positional arguments.\n\nKey symptoms include the appearance of a deprecation warning when the method is called with keyword arguments, potentially confusing users who believe they are using the function correctly. This issue affects the `Figure.add_axes` method in the Matplotlib library and may impact users relying on keyword arguments for this method, leading to unnecessary warnings in their applications.\n\nThe potential impact is moderate, primarily affecting user experience by generating misleading warnings. This could lead to confusion and discourage users from using keyword arguments, despite them being a valid and supported method of calling the function.\n\nIn technical terms, the issue stems from the current implementation of the `add_axes` method, which checks for the presence of positional arguments (`args`) but does not adequately account for the presence of required keyword arguments (`kwargs`). The proposed solution involves modifying the method to first check for the 'rect' key within `kwargs` before issuing a deprecation warning, thereby aligning the behavior with user expectations and documentation.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: `add_axes` shows deprecation warning when called with only `kwarg`s\n\nBody:\n<!--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\nCalling `add_axes` without args is deprecated. However, if a kwarg is passed, the deprecation warning still shows.\r\n\r\n\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug.\r\nPlease make sure to minimize the number of dependencies required, and provide\r\nany necessary plotted data.\r\nAvoid using threads, as Matplotlib is (explicitly) not thread-safe.-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nfig = plt.figure()\r\nax = fig.add_axes(rect=[0, 0, 1, 1])\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n<ipython-input-128-1ef4234f1c1f>:3: MatplotlibDeprecationWarning: Calling add_axes() without argument is deprecated. You may want to use add_subplot() instead.\r\n  ax = fig.add_axes(rect=[0, 0, 1, 1])\r\n```\r\n\r\n**Expected outcome**\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\nNo warning should be shown.\r\n\r\n**Discussion**\r\n\r\n`figure.add_axes` currently starts with\r\n\r\n```\r\n        if not len(args):\r\n            cbook.warn_deprecated(\r\n                \"3.3\",\r\n                message=\"Calling add_axes() without argument is \"\r\n                \"deprecated. You may want to use add_subplot() \"\r\n                \"instead.\")\r\n            return\r\n```\r\n\r\nBecause the function forwards `kwargs`, the intended behavior is a bit ambiguous to me, but I'm assuming from the docstring that the intention is to force the user to pass `rect` specifically? \r\n\r\n```\r\nif not len(args) and 'rect' not in kwargs:\r\n    ...\r\n```\r\n\r\nI can make this a PR if necessary, but if I'm not sure if we continue to update 3.2...And I don't know what the deprecation schedule even looks like for removing the \"ability to use no args\", so I don't know if this will even be an issue after 3.3....just wanted to point it out.\r\n\r\nFeel free to close if this is a non-issue.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/figure.py\n  function: Figure.add_axes\n"
    }
  ]
}