{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-25311",
    "repo": "matplotlib/matplotlib",
    "created_at": "2023-02-23T21:04:12Z",
    "problem_statement": "[Bug]: Unable to pickle figure with draggable legend\n### Bug summary\r\n\r\nI am unable to pickle figure with draggable legend. Same error comes for draggable annotations.\r\n\r\n\r\n\r\n\r\n\r\n### Code for reproduction\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport pickle\r\n\r\nfig = plt.figure()\r\nax = fig.add_subplot(111)\r\n\r\ntime=[0,1,2,3,4]\r\nspeed=[40,43,45,47,48]\r\n\r\nax.plot(time,speed,label=\"speed\")\r\n\r\nleg=ax.legend()\r\nleg.set_draggable(True) #pickling works after removing this line \r\n\r\npickle.dumps(fig)\r\nplt.show()\r\n```\r\n\r\n\r\n### Actual outcome\r\n\r\n`TypeError: cannot pickle 'FigureCanvasQTAgg' object`\r\n\r\n### Expected outcome\r\n\r\nPickling successful\r\n\r\n### Additional information\r\n\r\n_No response_\r\n\r\n### Operating system\r\n\r\nWindows 10\r\n\r\n### Matplotlib Version\r\n\r\n3.7.0\r\n\r\n### Matplotlib Backend\r\n\r\n_No response_\r\n\r\n### Python version\r\n\r\n3.10\r\n\r\n### Jupyter version\r\n\r\n_No response_\r\n\r\n### Installation\r\n\r\npip\n",
    "patch": "diff --git a/lib/matplotlib/offsetbox.py b/lib/matplotlib/offsetbox.py\n--- a/lib/matplotlib/offsetbox.py\n+++ b/lib/matplotlib/offsetbox.py\n@@ -1505,7 +1505,6 @@ def __init__(self, ref_artist, use_blit=False):\n         if not ref_artist.pickable():\n             ref_artist.set_picker(True)\n         self.got_artist = False\n-        self.canvas = self.ref_artist.figure.canvas\n         self._use_blit = use_blit and self.canvas.supports_blit\n         self.cids = [\n             self.canvas.callbacks._connect_picklable(\n@@ -1514,6 +1513,9 @@ def __init__(self, ref_artist, use_blit=False):\n                 'button_release_event', self.on_release),\n         ]\n \n+    # A property, not an attribute, to maintain picklability.\n+    canvas = property(lambda self: self.ref_artist.figure.canvas)\n+\n     def on_motion(self, evt):\n         if self._check_still_parented() and self.got_artist:\n             dx = evt.x - self.mouse_x\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_11138",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is related to window icon behavior, which does not share a causal chain or fix strategy with pickling errors."
      },
      {
        "idx": 2,
        "id": "similar_25176",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves graphical representation and file saving, unrelated to pickling or object serialization."
      },
      {
        "idx": 3,
        "id": "similar_11515",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about axis sharing in subplots, which does not relate to pickling or object serialization."
      },
      {
        "idx": 4,
        "id": "similar_2376",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue focuses on dependency management and version checks, unrelated to pickling or serialization."
      },
      {
        "idx": 5,
        "id": "similar_18299",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about unresponsive GUI elements, which does not share a causal chain with pickling errors."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Only the first figure window has mpl icon, all other figures have default tk icon.",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\nWhen plot more than one figure window, only the first figure window has the default mpl icon (come from matplotlib.ppm), and all other figure windows' icon is set to the default tk icon.\r\n\r\n**Code for reproduction**\r\n\r\ncode 1:\r\n```python\r\nimport logging\r\nimport matplotlib.pyplot as plt\r\nlogging.basicConfig(format=\"%(name)s %(levelname)s: %(message)s\", level=logging.INFO)\r\nplt.figure(1)\r\nplt.plot([1,2,3])\r\nplt.show()\r\n```\r\n\r\ncode 2:\r\n```python\r\nimport logging\r\nimport matplotlib.pyplot as plt\r\nlogging.basicConfig(format=\"%(name)s %(levelname)s: %(message)s\", level=logging.INFO)\r\nplt.figure(1)\r\nplt.plot([1,2,3])\r\nplt.figure(2)\r\nplt.plot([4,5,6])\r\nplt.show()\r\n```\r\n\r\ncode 3:\r\n```python\r\nimport logging\r\nimport matplotlib.pyplot as plt\r\nlogging.basicConfig(format=\"%(name)s %(levelname)s: %(message)s\", level=logging.INFO)\r\nplt.figure(1)\r\nplt.plot([1,2,3])\r\nplt.figure(2)\r\nplt.plot([4,5,6])\r\nplt.figure(3)\r\nplt.plot([7,8,9])\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\ncode 1 runs normally.\r\n\r\ncode 2 will log:\r\n```\r\nmatplotlib.backends._backend_tk INFO: Could not load matplotlib icon: can't use \"pyimage10\" as iconphoto: not a photo image\r\n```\r\nAnd the icon of figure 1 and figure 2 is different.\r\n\r\ncode 3 will log:\r\n```\r\nmatplotlib.backends._backend_tk INFO: Could not load matplotlib icon: can't use \"pyimage10\" as iconphoto: not a photo image\r\nmatplotlib.backends._backend_tk INFO: Could not load matplotlib icon: can't use \"pyimage19\" as iconphoto: not a photo image\r\n```\r\nThe icon of figure 1 is different than figure 2 and 3.\r\nScreenshot attached:\r\nIcon of window:\r\n![figure_title](https://user-images.githubusercontent.com/35422407/39393621-04eec34c-4afa-11e8-85a0-6f4aa58f8c4c.png)\r\n\r\nAnd the icon in taskbar:\r\n![taskbar](https://user-images.githubusercontent.com/35422407/39393623-0ad91244-4afa-11e8-8536-49138602fb4e.png)\r\n\r\nIf debug, the log information is coming from the exception:\r\n```\r\nfile: matplotlib/backends/_backend_tk.py\r\nclass _BackendTk()\r\nmethod new_figure_manager_given_figure()\r\n        # Put a mpl icon on the window rather than the default tk icon.\r\n        # Tkinter doesn't allow colour icons on linux systems, but tk>=8.5 has\r\n        # a iconphoto command which we call directly. Source:\r\n        # http://mail.python.org/pipermail/tkinter-discuss/2006-November/000954.html\r\n        icon_fname = os.path.join(\r\n            rcParams['datapath'], 'images', 'matplotlib.ppm')\r\n        icon_img = Tk.PhotoImage(file=icon_fname)\r\n        try:\r\n            window.tk.call('wm', 'iconphoto', window._w, icon_img)\r\n        except Exception as exc:\r\n            # log the failure (due e.g. to Tk version), but carry on\r\n            _log.info('Could not load matplotlib icon: %s', exc)\r\n```\r\n\r\n**Expected outcome**\r\nAll figure's icon are same by default.\r\n\r\n**Matplotlib version**\r\n  * Operating system: Windows 7 pro.\r\n  * Matplotlib version:  2.2.2\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: 3.6.5\r\n\r\n",
        "issue_id": 11138,
        "pr_number": 11165,
        "pr_title": "Fix figure window icon",
        "pr_body": "## PR Summary\r\nFixes #11138 \r\n\r\n## PR Checklist\r\n\r\n- [x] Has Pytest style unit tests\r\n- [x] Code is PEP 8 compliant\r\n- [x] New features are documented, with examples if plot related\r\n- [x] 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",
        "issue_closed_at": "2018-07-08T17:50:21Z",
        "base_commit": "c20b0c2bede5e354ac3bc90858d247c2a2d10d5e"
      },
      "summary": "### Summary:\nThis issue pertains to the inconsistent behavior of window icons when generating multiple plot figures using the Matplotlib library with the TkAgg backend. The problem arises specifically when multiple figure windows are created; only the first window displays the correct Matplotlib icon, while subsequent windows default to the generic Tk icon. This inconsistency is due to a failure in loading the Matplotlib icon for additional figures, as indicated by log messages reporting an inability to set the icon due to an exception. This exception is rooted in the `new_figure_manager_given_figure` method within the `_BackendTk` class, where the icon setting process encounters issues. The problem affects users on Windows 7 Pro running Matplotlib version 2.2.2 with Python 3.6.5, utilizing the TkAgg backend. The severity of this issue is primarily cosmetic but can impact user experience and application aesthetics, particularly in environments where visual consistency is crucial. Understanding the technical details requires familiarity with Tkinter's handling of window icons and the specific method used to apply custom icons in the Matplotlib backend for Tk.",
      "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: Only the first figure window has mpl icon, all other figures have default tk icon.\n\nBody:\n### Bug report\r\n\r\n**Bug summary**\r\nWhen plot more than one figure window, only the first figure window has the default mpl icon (come from matplotlib.ppm), and all other figure windows' icon is set to the default tk icon.\r\n\r\n**Code for reproduction**\r\n\r\ncode 1:\r\n```python\r\nimport logging\r\nimport matplotlib.pyplot as plt\r\nlogging.basicConfig(format=\"%(name)s %(levelname)s: %(message)s\", level=logging.INFO)\r\nplt.figure(1)\r\nplt.plot([1,2,3])\r\nplt.show()\r\n```\r\n\r\ncode 2:\r\n```python\r\nimport logging\r\nimport matplotlib.pyplot as plt\r\nlogging.basicConfig(format=\"%(name)s %(levelname)s: %(message)s\", level=logging.INFO)\r\nplt.figure(1)\r\nplt.plot([1,2,3])\r\nplt.figure(2)\r\nplt.plot([4,5,6])\r\nplt.show()\r\n```\r\n\r\ncode 3:\r\n```python\r\nimport logging\r\nimport matplotlib.pyplot as plt\r\nlogging.basicConfig(format=\"%(name)s %(levelname)s: %(message)s\", level=logging.INFO)\r\nplt.figure(1)\r\nplt.plot([1,2,3])\r\nplt.figure(2)\r\nplt.plot([4,5,6])\r\nplt.figure(3)\r\nplt.plot([7,8,9])\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\ncode 1 runs normally.\r\n\r\ncode 2 will log:\r\n```\r\nmatplotlib.backends._backend_tk INFO: Could not load matplotlib icon: can't use \"pyimage10\" as iconphoto: not a photo image\r\n```\r\nAnd the icon of figure 1 and figure 2 is different.\r\n\r\ncode 3 will log:\r\n```\r\nmatplotlib.backends._backend_tk INFO: Could not load matplotlib icon: can't use \"pyimage10\" as iconphoto: not a photo image\r\nmatplotlib.backends._backend_tk INFO: Could not load matplotlib icon: can't use \"pyimage19\" as iconphoto: not a photo image\r\n```\r\nThe icon of figure 1 is different than figure 2 and 3.\r\nScreenshot attached:\r\nIcon of window:\r\n![figure_title](https://user-images.githubusercontent.com/35422407/39393621-04eec34c-4afa-11e8-85a0-6f4aa58f8c4c.png)\r\n\r\nAnd the icon in taskbar:\r\n![taskbar](https://user-images.githubusercontent.com/35422407/39393623-0ad91244-4afa-11e8-8536-49138602fb4e.png)\r\n\r\nIf debug, the log information is coming from the exception:\r\n```\r\nfile: matplotlib/backends/_backend_tk.py\r\nclass _BackendTk()\r\nmethod new_figure_manager_given_figure()\r\n        # Put a mpl icon on the window rather than the default tk icon.\r\n        # Tkinter doesn't allow colour icons on linux systems, but tk>=8.5 has\r\n        # a iconphoto command which we call directly. Source:\r\n        # http://mail.python.org/pipermail/tkinter-discuss/2006-November/000954.html\r\n        icon_fname = os.path.join(\r\n            rcParams['datapath'], 'images', 'matplotlib.ppm')\r\n        icon_img = Tk.PhotoImage(file=icon_fname)\r\n        try:\r\n            window.tk.call('wm', 'iconphoto', window._w, icon_img)\r\n        except Exception as exc:\r\n            # log the failure (due e.g. to Tk version), but carry on\r\n            _log.info('Could not load matplotlib icon: %s', exc)\r\n```\r\n\r\n**Expected outcome**\r\nAll figure's icon are same by default.\r\n\r\n**Matplotlib version**\r\n  * Operating system: Windows 7 pro.\r\n  * Matplotlib version:  2.2.2\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: 3.6.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/backends/_backend_tk.py\n  function: _BackendTk.new_figure_manager_given_figure\n"
    },
    {
      "similar_issue": {
        "issue_title": "[Bug]: Colorbar is displaced when saving as .eps with bbox_inches='tight'",
        "issue_body": "### Bug summary\r\nI am plotting with `imshow()` and create a colorbar. When saving the figure as .eps with `savefig()` and option `bbox_inches='tight'`, the colorbar (without the spines) is displaced.\r\n\r\n### Code for reproduction\r\n```python\r\nimport matplotlib.pyplot as plt\r\n\r\nfig = plt.figure()\r\nplt.imshow([[1, 1], [1, 1]])\r\nplt.colorbar()\r\nplt.savefig(\"test.eps\", bbox_inches='tight')\r\nplt.show()\r\n```\r\n\r\n### Expected outcome\r\nColorbar should be placed inside the spines as when using `plt.show()`. Also, saving as .png instead of .eps works correctly.\r\n\r\n### Actual outcome\r\n![test](https://user-images.githubusercontent.com/12721580/217641953-4a6b5cdd-f777-436f-849f-6580244031b8.png)\r\n\r\n### Additional information\r\nThe bug does not happen when using Matplotlib version 5.2.3. \r\n\r\n### Operating system\r\nWindows 10\r\n\r\n### Matplotlib version\r\n3.6.3\r\n\r\n### Matplotlib backend\r\nmodule://backend_interagg\r\n\r\n### Python version\r\n3.11.0",
        "issue_id": 25176,
        "pr_number": 25193,
        "pr_title": "Fix displacement of colorbar for eps with bbox_inches='tight'",
        "pr_body": "Co-authored-by: Antony Lee <anntzer.lee@gmail.com>\n\nCloses #25176\n\n## PR Summary\n\n## PR Checklist\n\n<!-- Please mark any checkboxes that do not apply to this PR as [N/A]. -->\n\n**Documentation and Tests**\n- [ ] Has pytest style unit tests (and `pytest` passes)\n- [ ] Documentation is sphinx and numpydoc compliant (the docs should [build](https://matplotlib.org/devel/documenting_mpl.html#building-the-docs) without error).\n- [ ] New plotting related features are documented with examples.\n\n**Release Notes**\n- [ ] New features are marked with a `.. versionadded::` directive in the docstring and documented in `doc/users/next_whats_new/`\n- [ ] API changes are marked with a `.. versionchanged::` directive in the docstring and documented in `doc/api/next_api_changes/`\n- [ ] Release notes conform with instructions in  `next_whats_new/README.rst` or `next_api_changes/README.rst`\n\n<!--\nThank you so much for your PR!  To help us review your contribution, please\nconsider the following points:\n\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\n\n- Help with git and github is available at\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\n\n- Create a separate branch for your changes and open the PR from this branch. Please avoid working on `main`.\n\n- The PR title should summarize the changes, for example \"Raise ValueError on\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\n  \"Addresses issue #8576\".\n\n- The summary should provide at least 1-2 sentences describing the pull request\n  in detail (Why is this change required?  What problem does it solve?) and\n  link to any relevant issues.\n\n- If you are contributing fixes to docstrings, please pay attention to\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\n  note the difference between using single backquotes, double backquotes, and\n  asterisks in the markup.\n\nWe understand that PRs can sometimes be overwhelming, especially as the\nreviews start coming in.  Please let us know if the reviews are unclear or\nthe recommended next step seems overly demanding, if you would like help in\naddressing a reviewer's comments, or if you have been waiting too long to hear\nback on your PR.\n-->\n",
        "issue_closed_at": "2023-02-11T11:13:58Z",
        "base_commit": "73909bcb408886a22e2b84581d6b9e6d9907c813"
      },
      "summary": "### Summary:\n\nThis issue concerns a problem with the graphical representation of figures in the Matplotlib library when saving plots as Encapsulated PostScript (.eps) files. The problem arises specifically when using `imshow()` to create plots with associated colorbars and attempting to save these plots using the `savefig()` function with the `bbox_inches='tight'` parameter. The issue manifests as a displacement of the colorbar, which is not aligned properly within the figure's spines, deviating from the expected behavior observed when displaying the plot or saving it in other formats like .png.\n\nKey symptoms include a misalignment of the colorbar when the figure is saved as a .eps file, while the display of the plot and saving in other formats work as intended. This problem is specific to Matplotlib version 3.6.3 and does not occur in version 5.2.3, suggesting a regression or change in behavior between these versions.\n\nThe affected components primarily involve the Matplotlib backend responsible for handling PostScript files, specifically within the functions `get_default_filetype` and `_print_ps` in the `backend_ps.py` module. The issue is likely related to how bounding box calculations or colorbar elements are handled when generating .eps files.\n\nThe potential impact of this issue can be significant for users relying on .eps files for publication or precise figure placement, where visual accuracy and consistency are critical. Users on Windows 10 with Matplotlib version 3.6.3 and using Python 3.11.0 are directly impacted, particularly those who require tight bounding boxes for their figures.\n\nIn a broader context, this issue highlights challenges in maintaining compatibility and expected behavior across different file formats in plotting libraries, emphasizing the need for thorough testing across various output formats and 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: [Bug]: Colorbar is displaced when saving as .eps with bbox_inches='tight'\n\nBody:\n### Bug summary\r\nI am plotting with `imshow()` and create a colorbar. When saving the figure as .eps with `savefig()` and option `bbox_inches='tight'`, the colorbar (without the spines) is displaced.\r\n\r\n### Code for reproduction\r\n```python\r\nimport matplotlib.pyplot as plt\r\n\r\nfig = plt.figure()\r\nplt.imshow([[1, 1], [1, 1]])\r\nplt.colorbar()\r\nplt.savefig(\"test.eps\", bbox_inches='tight')\r\nplt.show()\r\n```\r\n\r\n### Expected outcome\r\nColorbar should be placed inside the spines as when using `plt.show()`. Also, saving as .png instead of .eps works correctly.\r\n\r\n### Actual outcome\r\n![test](https://user-images.githubusercontent.com/12721580/217641953-4a6b5cdd-f777-436f-849f-6580244031b8.png)\r\n\r\n### Additional information\r\nThe bug does not happen when using Matplotlib version 5.2.3. \r\n\r\n### Operating system\r\nWindows 10\r\n\r\n### Matplotlib version\r\n3.6.3\r\n\r\n### Matplotlib backend\r\nmodule://backend_interagg\r\n\r\n### Python version\r\n3.11.0\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_ps.py\n  function: FigureCanvasPS.get_default_filetype\n  function: FigureCanvasPS._print_ps\n"
    },
    {
      "similar_issue": {
        "issue_title": "using 'sharex' once in 'subplots' function can affect subsequent calles to 'subplots'",
        "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\nUsing 'sharex' keyword argument once in the subplot function causes all subsequent axes returned by subplots to have a shared x-axis when the subplot_kw argument is also included.\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\r\nfrom pylab import *\r\n\r\n\r\ndefaults_subplots = dict()\r\n\r\nx1, y1 = range(30), randn(30)\r\nx2, y2 = range(30, 60), randn(30)\r\n\r\nclose('all')\r\n\r\n## Case 1 : single subplot (can be multiple as well)\r\n##  this behaves correctly\r\nf2, ax2 =  subplots(1,1, sharex=True, subplot_kw=defaults_subplots)\r\ntitle('figure 1')\r\nax2.plot(x2, -y2)\r\n\r\n## Case 2 : multiple subplots (single subplot causes bug to not appear)\r\nf1, (ax1, _) = subplots(2,1, sharex=True, subplot_kw=defaults_subplots)\r\ntitle('figure 2')\r\nax1.plot(x1, y1)\r\n\r\n## Case 3 : same code as case 1, however axis is shared with subplots in case 2\r\nf2, ax3 =  subplots(1,1, subplot_kw=defaults_subplots)\r\ntitle('figure 3')\r\nax3.plot(x2, -y2)\r\n\r\nshow()\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\nFigure 1 has an independent x axis, while subplots in figures 2 and 3 share an x axis. \r\n\r\n**Expected outcome**\r\nThe x axis should be independent for each figure.  The subplots in figure 2 should have a shared axis.\r\n \r\n**Fix**\r\nThe bug is the result of modifying the `subplot_kw` dictionary, following patch resolves the issue:\r\n\r\n```\r\n@@ -1171,6 +1171,9 @@\r\n                          (sharey, share_values))\r\n     if subplot_kw is None:\r\n         subplot_kw = {}\r\n+    else:\r\n+        subplot_kw = subplot_kw.copy()\r\n+\r\n     if gridspec_kw is None:\r\n         gridspec_kw = {}\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: Ubuntu 16.04\r\n  * Matplotlib version: 1.5.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: 3.5.2\r\nMatplotlib installed through ubuntu package manager.\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_id": 11515,
        "pr_number": 11601,
        "pr_title": "FIX: subplots don't mutate kwargs passed by user.",
        "pr_body": "## PR Summary\r\n\r\nCloses #11515\r\n\r\nDon't mess with the user-supplied dictionaries in `subplots`...\r\n\r\nDunno if this really merits a test..\r\n\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\n\r\nsubplot_kw = {'sharex': 'all'}\r\nprint(subplot_kw)\r\nfig, ax = plt.subplots(2, 1, subplot_kw=subplot_kw)\r\nprint(subplot_kw)\r\n```\r\n\r\n### New:\r\n\r\n```\r\n{'sharex': 'all'}\r\n{'sharex': 'all'}\r\n```\r\n\r\n### Old:\r\n\r\n```\r\n{'sharex': 'all'}\r\n{'sharex': None, 'sharey': None}\r\n```\r\n\r\n## PR Checklist\r\n\r\n- [ ] 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-->",
        "issue_closed_at": "2018-07-09T19:17:19Z",
        "base_commit": "3d19f94284e15d4d1c4c1d736cf646d18856960a"
      },
      "summary": "### Summary:\nThis issue is related to the behavior of the `subplots` function in the Matplotlib library, where the use of the `sharex` keyword argument in combination with `subplot_kw` can lead to unexpected sharing of x-axes across different subplot calls. Specifically, once `sharex` is used, all subsequent calls to `subplots` with a `subplot_kw` argument result in shared x-axes for those axes, even if not explicitly specified.\n\n1. **Problem description in general terms**: \n   The problem arises when using the `subplots` function in Matplotlib with the `sharex` keyword. When `sharex=True` is used in conjunction with a `subplot_kw` dictionary, this dictionary is modified in place, leading to persistent x-axis sharing across subsequent subplot calls.\n\n2. **Key symptoms and behaviors observed**: \n   - Figures that are expected to have independent x-axes end up sharing x-axes.\n   - This behavior occurs if the `sharex` parameter is used once with a `subplot_kw` argument. Subsequent calls to `subplots` that utilize the same `subplot_kw` dictionary without `sharex` unexpectedly inherit the shared x-axis behavior.\n\n3. **Affected components or systems**: \n   - The issue affects the `subplots` function within Matplotlib, specifically the handling of the `subplot_kw` argument.\n\n4. **Potential impact or severity**: \n   - The impact is primarily on the layout and presentation of plots, which can lead to incorrect visualizations and misinterpretations of data if users are unaware of the unintended axis sharing. This can be particularly problematic in data analysis and presentation contexts where accurate plotting is crucial.\n\n5. **Relevant technical details abstracted for broader understanding**: \n   - The root cause is the in-place modification of the `subplot_kw` dictionary. This is rectified by copying the dictionary within the function to avoid persistent modifications that affect subsequent function calls. The patch ensures that each call to `subplots` receives an independent `subplot_kw`, thus preventing unexpected axis sharing.\n\nThis summary encapsulates the issue's nature and implications, offering a high-level understanding of the problem and its resolution.",
      "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: using 'sharex' once in 'subplots' function can affect subsequent calles to 'subplots'\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\nUsing 'sharex' keyword argument once in the subplot function causes all subsequent axes returned by subplots to have a shared x-axis when the subplot_kw argument is also included.\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\r\nfrom pylab import *\r\n\r\n\r\ndefaults_subplots = dict()\r\n\r\nx1, y1 = range(30), randn(30)\r\nx2, y2 = range(30, 60), randn(30)\r\n\r\nclose('all')\r\n\r\n## Case 1 : single subplot (can be multiple as well)\r\n##  this behaves correctly\r\nf2, ax2 =  subplots(1,1, sharex=True, subplot_kw=defaults_subplots)\r\ntitle('figure 1')\r\nax2.plot(x2, -y2)\r\n\r\n## Case 2 : multiple subplots (single subplot causes bug to not appear)\r\nf1, (ax1, _) = subplots(2,1, sharex=True, subplot_kw=defaults_subplots)\r\ntitle('figure 2')\r\nax1.plot(x1, y1)\r\n\r\n## Case 3 : same code as case 1, however axis is shared with subplots in case 2\r\nf2, ax3 =  subplots(1,1, subplot_kw=defaults_subplots)\r\ntitle('figure 3')\r\nax3.plot(x2, -y2)\r\n\r\nshow()\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\nFigure 1 has an independent x axis, while subplots in figures 2 and 3 share an x axis. \r\n\r\n**Expected outcome**\r\nThe x axis should be independent for each figure.  The subplots in figure 2 should have a shared axis.\r\n \r\n**Fix**\r\nThe bug is the result of modifying the `subplot_kw` dictionary, following patch resolves the issue:\r\n\r\n```\r\n@@ -1171,6 +1171,9 @@\r\n                          (sharey, share_values))\r\n     if subplot_kw is None:\r\n         subplot_kw = {}\r\n+    else:\r\n+        subplot_kw = subplot_kw.copy()\r\n+\r\n     if gridspec_kw is None:\r\n         gridspec_kw = {}\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: Ubuntu 16.04\r\n  * Matplotlib version: 1.5.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: 3.5.2\r\nMatplotlib installed through ubuntu package manager.\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\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.subplots\n"
    },
    {
      "similar_issue": {
        "issue_title": "feature test pyparsing 2 bug instead of version check",
        "issue_body": "the last pyparsing python3 weirdness already screwed distributions, the recent revert makes it even worse.\nmatplotlib should feature test for the bug that breaks 2.0.0 instead of relying on version numbers to at least give distributions a chance of resolving the issue in a sane way.\nthis patch, if accepted, should be applied to master and the 1.3.x branch\n\n``` diff\n--- a/setupext.py\n+++ b/setupext.py\n@@ -984,14 +984,13 @@ class Pyparsing(SetupPackage):\n                 \"matplotlib requires pyparsing >= {0}\".format(\n                     '.'.join(str(x) for x in required)))\n\n-        if pyparsing.__version__ == \"2.0.0\":\n-            if PY3:\n+        # check for bug in 2.0.0\n+        f = pyparsing.Forward()\n+        f <<= pyparsing.Literal('a')\n+        if f is None:\n                 return (\n                     \"pyparsing 2.0.0 has bugs that prevent its use with \"\n                     \"matplotlib\")\n-            else:\n-                return (\n-                    \"pyparsing 2.0.0 is not compatible with Python 2.x\")\n\n         return \"using pyparsing version %s\" % pyparsing.__version__\n```\n",
        "issue_id": 2376,
        "pr_number": 2380,
        "pr_title": "check if pyparsing <<= is broken instead of checking the version",
        "pr_body": "distributions with packaged pyparsing might have already patched\npyparsing but not bumped the version number.\ncloses #2376\n",
        "issue_closed_at": "2013-09-06T13:14:43Z",
        "base_commit": "0f8a45216a964ff76372428f95fa449709ba7565"
      },
      "summary": "### Summary:\n\nThis issue pertains to how software dependencies are managed, specifically focusing on the use of version numbers to determine compatibility between software components. The problem arises from relying on version checks to manage compatibility with the `pyparsing` library, which has proven inadequate due to bugs present in version 2.0.0 of the library. Instead of using version numbers to check compatibility, the report suggests conducting feature tests to identify the presence of specific bugs, thereby allowing for more flexible and reliable dependency management.\n\n1. **Problem Description in General Terms:**\n   The issue involves managing compatibility between software components, particularly focusing on how dependency versions are checked. The traditional method of using version numbers to determine compatibility is found to be insufficient due to specific bugs in certain library versions.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The symptom of the issue is that the current version-based checks fail to adequately detect and handle bugs in the `pyparsing` library version 2.0.0. This has already caused distribution problems and could lead to further complications if not addressed.\n\n3. **Affected Components or Systems:**\n   The affected component is the `matplotlib` library, which relies on `pyparsing` for certain functionalities. The issue impacts both the master and the 1.3.x branch of the `matplotlib` codebase.\n\n4. **Potential Impact or Severity:**\n   The impact of the issue is potentially severe, as it affects the reliability and stability of the `matplotlib` library across different environments. Incorrect version checks can lead to unresolved bugs being introduced into distributions, causing widespread issues.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The technical recommendation is to move away from version-based compatibility checks and instead implement feature tests. In this specific case, a feature test is proposed to identify a known bug in `pyparsing` 2.0.0, allowing for more accurate detection and handling of compatibility issues. The solution involves modifying the `setupext.py` file to include a feature test that checks for the presence of the bug by creating and evaluating specific `pyparsing` constructs.",
      "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: feature test pyparsing 2 bug instead of version check\n\nBody:\nthe last pyparsing python3 weirdness already screwed distributions, the recent revert makes it even worse.\nmatplotlib should feature test for the bug that breaks 2.0.0 instead of relying on version numbers to at least give distributions a chance of resolving the issue in a sane way.\nthis patch, if accepted, should be applied to master and the 1.3.x branch\n\n``` diff\n--- a/setupext.py\n+++ b/setupext.py\n@@ -984,14 +984,13 @@ class Pyparsing(SetupPackage):\n                 \"matplotlib requires pyparsing >= {0}\".format(\n                     '.'.join(str(x) for x in required)))\n\n-        if pyparsing.__version__ == \"2.0.0\":\n-            if PY3:\n+        # check for bug in 2.0.0\n+        f = pyparsing.Forward()\n+        f <<= pyparsing.Literal('a')\n+        if f is None:\n                 return (\n                     \"pyparsing 2.0.0 has bugs that prevent its use with \"\n                     \"matplotlib\")\n-            else:\n-                return (\n-                    \"pyparsing 2.0.0 is not compatible with Python 2.x\")\n\n         return \"using pyparsing version %s\" % pyparsing.__version__\n```\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/__init__.py\n  function: compare_versions\n  function: compare_versions\n\nsetupext.py\n  function: Pyparsing.get_install_requires\n  function: PdfToPs.check\n"
    },
    {
      "similar_issue": {
        "issue_title": "New configure_subplots behaves badly on TkAgg backend",
        "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\nAfter #16818, with the TkAgg backend, configure subplots window can't be closed and the sliders do not respond to input. The window close issue is straightforward to understand: the button response calls `Gcf.destroy` but the figure is intentionally not registered, so the `FigureManagerTk.destory` is never called. I suspect (but have not confirmed) that the slider events are being lost due to the new figure manager making a new `tkinter.Tk` instance [here](https://github.com/anntzer/matplotlib/blob/c55ca9fd64f74c4bb9ad57ea371ae8a1ec07b7d0/lib/matplotlib/backends/_backend_tk.py#L849). [EDIT: NOPE, see comment]\r\n\r\nCC @anntzer \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\r\nimport matplotlib.pyplot as plt\r\n\r\nmatplotlib.use(\"TkAgg\")\r\nplt.plot([1,2,3],[1,2,5])\r\n#  if not interactive\r\nplt.show()\r\n# click Configure Subplots\r\n```\r\n\r\n**Actual outcome**\r\n\r\ninteractive Tk window but sliders don't work and close window button is not responsive\r\n\r\n**Expected outcome**\r\n\r\nprevious behavior\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: Win10\r\n  * Matplotlib version: master\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: 3.8.5\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",
        "issue_id": 18299,
        "pr_number": 18306,
        "pr_title": "Fix configure subplots",
        "pr_body": "## PR Summary\r\n\r\nFixes #18299. Draft for the moment because I still need to see if we can keep #17025 from haunting us. For the moment the reference to the subplot_tool is kept on the navbar; I think that makes more sense than an artificial cycle, as the navbar is responsible for spawning the tool anyway.\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/next_api_changes/* 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-08-24T15:22:34Z",
        "base_commit": "68408879105e53eb1377d15b2ecaf7538c22afb4"
      },
      "summary": "### Summary:\nThis issue describes a problem with the Matplotlib library, specifically affecting the TkAgg backend when configuring subplots. The problem arises after a recent update (#16818), leading to an unresponsive configure subplots window. Users find that the window cannot be closed, and sliders within the window do not respond to input. This behavior is linked to the window's closure mechanism, where the `Gcf.destroy` function is invoked, but due to the figure not being registered correctly, `FigureManagerTk.destroy` is not executed as expected. Additionally, there is a suspicion that slider events might be lost due to the creation of a new `tkinter.Tk` instance, though this is not confirmed. The issue primarily affects users working on the Windows 10 operating system using Matplotlib's master version with Python 3.8.5. The severity of the issue lies in its disruption to the typical functionality of interactive plotting, which is essential for users relying on dynamic plot configuration. Key components affected include the window management and event handling in the TkAgg backend. The issue highlights the importance of ensuring proper registration and event handling for interactive elements in Matplotlib's graphical user interface components.",
      "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: New configure_subplots behaves badly on TkAgg backend\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\nAfter #16818, with the TkAgg backend, configure subplots window can't be closed and the sliders do not respond to input. The window close issue is straightforward to understand: the button response calls `Gcf.destroy` but the figure is intentionally not registered, so the `FigureManagerTk.destory` is never called. I suspect (but have not confirmed) that the slider events are being lost due to the new figure manager making a new `tkinter.Tk` instance [here](https://github.com/anntzer/matplotlib/blob/c55ca9fd64f74c4bb9ad57ea371ae8a1ec07b7d0/lib/matplotlib/backends/_backend_tk.py#L849). [EDIT: NOPE, see comment]\r\n\r\nCC @anntzer \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\r\nimport matplotlib.pyplot as plt\r\n\r\nmatplotlib.use(\"TkAgg\")\r\nplt.plot([1,2,3],[1,2,5])\r\n#  if not interactive\r\nplt.show()\r\n# click Configure Subplots\r\n```\r\n\r\n**Actual outcome**\r\n\r\ninteractive Tk window but sliders don't work and close window button is not responsive\r\n\r\n**Expected outcome**\r\n\r\nprevious behavior\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: Win10\r\n  * Matplotlib version: master\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: 3.8.5\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\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/_pylab_helpers.py\n  function: Gcf.destroy\n\nlib/matplotlib/backend_bases.py\n  function: NavigationToolbar2._update_view\n\nlib/matplotlib/backends/backend_nbagg.py\n  function: _BackendNbAgg.new_figure_manager_given_figure\n\nlib/matplotlib/pyplot.py\n  function: subplot_tool\n"
    }
  ]
}