{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-25332",
    "repo": "matplotlib/matplotlib",
    "created_at": "2023-02-26T11:18:40Z",
    "problem_statement": "[Bug]: Unable to pickle figure with aligned labels\n### Bug summary\r\n\r\n Unable to pickle figure after calling `align_labels()`\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\nax1 = fig.add_subplot(211)\r\nax2 = fig.add_subplot(212)\r\ntime=[0,1,2,3,4]\r\nspeed=[40000,4300,4500,4700,4800]\r\nacc=[10,11,12,13,14]\r\nax1.plot(time,speed)\r\nax1.set_ylabel('speed')\r\nax2.plot(time,acc)\r\nax2.set_ylabel('acc')\r\n\r\nfig.align_labels() ##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\nalign.py\", line 16\r\npickle.dumps(fig)\r\nTypeError: cannot pickle 'weakref.ReferenceType' 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\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\n_No response_\r\n\r\n### Jupyter version\r\n\r\n_No response_\r\n\r\n### Installation\r\n\r\nNone\n",
    "patch": "diff --git a/lib/matplotlib/cbook.py b/lib/matplotlib/cbook.py\n--- a/lib/matplotlib/cbook.py\n+++ b/lib/matplotlib/cbook.py\n@@ -788,6 +788,19 @@ class Grouper:\n     def __init__(self, init=()):\n         self._mapping = {weakref.ref(x): [weakref.ref(x)] for x in init}\n \n+    def __getstate__(self):\n+        return {\n+            **vars(self),\n+            # Convert weak refs to strong ones.\n+            \"_mapping\": {k(): [v() for v in vs] for k, vs in self._mapping.items()},\n+        }\n+\n+    def __setstate__(self, state):\n+        vars(self).update(state)\n+        # Convert strong refs to weak ones.\n+        self._mapping = {weakref.ref(k): [*map(weakref.ref, vs)]\n+                         for k, vs in self._mapping.items()}\n+\n     def __contains__(self, item):\n         return weakref.ref(item) in self._mapping\n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_4049",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves data handling in logarithmic scales, which is unrelated to object serialization or weak references."
      },
      {
        "idx": 2,
        "id": "similar_11138",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about GUI inconsistencies, which do not relate to serialization or weak reference handling."
      },
      {
        "idx": 3,
        "id": "similar_11515",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves shared state in subplot configurations, unrelated to serialization or weak references."
      },
      {
        "idx": 4,
        "id": "similar_2376",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about dependency management and version compatibility, not related to serialization or weak references."
      },
      {
        "idx": 5,
        "id": "similar_1625",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves output stream handling in a backend, unrelated to serialization or weak references."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Issue with plotting zeros in log space",
        "issue_body": "The following simple example shows an issues with zero values when calling `loglog`:\n\n```\nimport matplotlib.pyplot as plt\n\nnu = [1e2, 1e3, 1e4, 1e5, 1e6, 1e7]\nfnu = [1, 1e-30, 1e-45, 0., 0., 0.]\n\nfig = plt.figure()\nax = fig.add_subplot(1,1,1)\nax.loglog(nu, fnu, color='blue')\nfig.savefig('mpl.png')\n```\n\nThe output is:\n\n![mpl](https://cloud.githubusercontent.com/assets/314716/5959827/8d0677cc-a7d1-11e4-8cd3-7227dee4a37a.png)\n\nOf course, zero is undefined in log space, but I don't understand why it defaults to plotting a value of 0.1 instead. Doing:\n\n```\nfnu = [1, 1e-30, 1e-45, np.nan, np.nan, np.nan]\n```\n\nDoes the right thing on the other hand. So maybe the best solution is to replace 0 values by np.nan inside `loglog`?\n\nI am using matplotlib 1.5.x with Python 3.4.\n",
        "issue_id": 4049,
        "pr_number": 4050,
        "pr_title": "Fix masked array handling",
        "pr_body": "This fixes #4049, and is an alternative to #4008.  Unlike #4008, this fixes the problem directly in `_fast_from_vertices_and_codes` rather than at a number of call sites that call it.  While it does make that function slower, it apparently needs the masked array treatment from all places that call it anyway, so sticking it right inside the function seems fine.\n\nIn the process of fixing this bug, it was discovered that a fix to handle NaNs in draw_markers (cf43d57) was not brought over from the 1.4.x branch (probably my fault, since merges of C++ code are really hairy right now).  This missing bugfix was papered over by the fact that NaNs were no longer being passed to `draw_markers`.\n\nLastly, this adds an optimization to the log scaling to use NaNs rather than masked arrays.  The original array is not touched, so this should be effectively the same thing, just without the large time and memory overhead of masked arrays.\n\nThis includes a test I shamelessly cherry-picked from #4008.\n",
        "issue_closed_at": "2015-01-30T23:18:44Z",
        "base_commit": "dd4b2bc76c800f2fae69953c888681fd67788192"
      },
      "summary": "### Summary:\n\nThis issue involves an unexpected behavior when plotting data that contains zero values using logarithmic scales in a plotting library. Specifically, when utilizing the `loglog` function to create a plot, zero values are improperly represented, defaulting to an incorrect value of 0.1 instead of being handled as undefined or omitted. This behavior is inconsistent with the mathematical definition of logarithms where zero is undefined. The report suggests that substituting zero values with `np.nan` results in the expected plot behavior, where non-plottable values are ignored or appropriately managed.\n\nKey symptoms and behaviors observed include:\n- Zero values in the dataset are plotted as 0.1 in log scale plots.\n- Substituting zero values with `np.nan` prevents them from being plotted and achieves the correct visualization.\n\nThe affected component is the `loglog` plotting function within the `matplotlib` library, specifically version 1.5.x as used with Python 3.4. The issue likely resides in the data transformation or handling logic of the plotting routines that manage logarithmic scales.\n\nThe potential impact of this issue is significant for users relying on accurate log scale visualizations, especially in scientific and engineering fields where precise data representation is crucial. Misrepresentation of zero values could lead to incorrect data interpretations and conclusions.\n\nRelevant technical details for broader understanding include:\n- The handling of zero values in logarithmic transformations is a critical aspect of plotting functions.\n- Affected code elements are within the `matplotlib` library's path and scale handling modules, specifically in the `Path._fast_from_codes_and_verts` and `SymmetricalLogScale.get_transform` functions. These areas are responsible for the data transformation processes that may need adjustment to handle zero values as `np.nan` or omit them entirely.\n\nThis issue highlights the importance of ensuring that plotting libraries handle edge cases like zero values in logarithmic contexts appropriately to maintain data integrity and visualization accuracy.",
      "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: Issue with plotting zeros in log space\n\nBody:\nThe following simple example shows an issues with zero values when calling `loglog`:\n\n```\nimport matplotlib.pyplot as plt\n\nnu = [1e2, 1e3, 1e4, 1e5, 1e6, 1e7]\nfnu = [1, 1e-30, 1e-45, 0., 0., 0.]\n\nfig = plt.figure()\nax = fig.add_subplot(1,1,1)\nax.loglog(nu, fnu, color='blue')\nfig.savefig('mpl.png')\n```\n\nThe output is:\n\n![mpl](https://cloud.githubusercontent.com/assets/314716/5959827/8d0677cc-a7d1-11e4-8cd3-7227dee4a37a.png)\n\nOf course, zero is undefined in log space, but I don't understand why it defaults to plotting a value of 0.1 instead. Doing:\n\n```\nfnu = [1, 1e-30, 1e-45, np.nan, np.nan, np.nan]\n```\n\nDoes the right thing on the other hand. So maybe the best solution is to replace 0 values by np.nan inside `loglog`?\n\nI am using matplotlib 1.5.x with Python 3.4.\n\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/path.py\n  function: Path._fast_from_codes_and_verts\n  function: Path._fast_from_codes_and_verts\n\nlib/matplotlib/scale.py\n  function: SymmetricalLogScale.get_transform\n"
    },
    {
      "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 a graphical user interface (GUI) inconsistency in the Matplotlib library when rendering multiple figure windows using the TkAgg backend on Windows operating systems. Specifically, when multiple figures are plotted, only the first window displays the expected Matplotlib-specific icon, while subsequent figure windows revert to the default Tk icon. \n\nKey symptoms include discrepancies between the icons of the first and subsequent figure windows, as well as logging errors indicating failure to load the Matplotlib icon. These errors are attributed to the Tkinter library's inability to handle the specified icon format under certain conditions, as indicated by the log messages generated during execution.\n\nThe affected component is the Matplotlib backend for Tkinter, specifically the method responsible for assigning icons to figure windows. The severity of the issue is primarily visual and does not affect the functional plotting capabilities of Matplotlib, but it can result in a less consistent user interface experience.\n\nTechnical details reveal that the problem arises from the method `new_figure_manager_given_figure` within the `_BackendTk` class, which attempts to set a custom icon using the `iconphoto` command. The failure of this operation, due to format or version limitations of Tkinter, leads to the observed behavior. This issue highlights the need for robust error handling and compatibility considerations when interfacing with GUI components across different platforms.",
      "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": "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:\n\nThis issue is related to the use of the 'sharex' keyword argument in the `subplots` function within the Matplotlib library. When 'sharex' is used in combination with the `subplot_kw` argument during a call to `subplots`, it inadvertently causes all subsequent subplot calls to share the x-axis, even if they are intended to be independent. This occurs because the `subplot_kw` dictionary, which is meant to provide additional keyword arguments for subplots, is being modified and reused across multiple subplot calls without being reset or copied, leading to unintended shared state between subplot calls.\n\nKey symptoms include:\n- When a single subplot is created with `sharex=True`, it behaves correctly with an independent x-axis. However, when multiple subplots are created with `sharex=True` in a subsequent call, they share the x-axis with previous subplots, despite user expectations for independence.\n- The problem manifests when subsequent calls to the `subplots` function inadvertently share the x-axis due to the persistent modification of the `subplot_kw` dictionary.\n\nAffected components:\n- This bug affects the `Figure.subplots` function within the Matplotlib library, specifically when using the `sharex` argument alongside `subplot_kw`.\n\nPotential impact:\n- The issue can lead to confusion and incorrect visualizations for users expecting independent x-axes in their figures, impacting the accuracy and interpretation of data visualizations.\n\nRelevant technical details:\n- The fix involves modifying the `Figure.subplots` function to ensure that the `subplot_kw` dictionary is copied rather than modified directly. This prevents unintended sharing of axis properties between subplot calls by maintaining an independent configuration for each call.",
      "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:\nThis issue pertains to the way the `matplotlib` library manages compatibility with different versions of the `pyparsing` library, specifically version 2.0.0. The problem arises due to a bug in `pyparsing` 2.0.0 that affects its functionality, particularly in Python 3 environments. Instead of relying solely on version numbers for compatibility checks, it is recommended to implement a feature test to detect the presence of the specific bug in `pyparsing` 2.0.0. This approach would provide a more robust solution, allowing distributions to handle the issue more effectively.\n\n1. **Problem Description in General Terms:**\n   The core issue revolves around dependency management in software, where relying solely on version numbers for compatibility checks can lead to problems if a specific version contains a bug. In this case, a bug in `pyparsing` version 2.0.0 causes issues with `matplotlib`, particularly under Python 3.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The main symptom is the malfunction of `matplotlib` when used with `pyparsing` version 2.0.0. This issue is exacerbated by a recent code revert that worsened the situation for distributions trying to resolve these compatibility issues.\n\n3. **Affected Components or Systems:**\n   The components affected include the `setupext.py` file in `matplotlib`, specifically within the `Pyparsing` class. The issue impacts the ability of `matplotlib` to correctly determine the usability of specific `pyparsing` versions.\n\n4. **Potential Impact or Severity:**\n   The impact is significant for developers and distributions relying on `matplotlib`, as it can break functionality and lead to software failures. This can affect any software or projects that depend on `matplotlib` and use `pyparsing` 2.0.0, potentially disrupting development and deployment processes.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   A feature test is introduced to detect the bug in `pyparsing` 2.0.0, rather than relying on version checks. This involves creating a `Forward` object and testing its assignment behavior. If the object is `None`, it indicates the presence of the bug, and compatibility issues can be flagged accordingly. This method allows for more dynamic and accurate compatibility assessments.\n\n### Changes Summary:\n- **lib/matplotlib/__init__.py**\n  - Function: `compare_versions`\n  - Function: `compare_versions`\n\n- **setupext.py**\n  - Function: `Pyparsing.get_install_requires`\n  - Function: `PdfToPs.check`",
      "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": "saving pgf to a stream is not supported",
        "issue_body": "Hi,\n\nThe pgf output does not support a stream as illustrated by this snippet\n\n``` python\nimport sys\nplt.plot([1,2])\nplt.savefig(sys.stdout, format='pgf')\n```\n\nIt returns:\n\n``` python\nValueError: saving pgf to a stream is not supported, consider using the pdf option of the pgf-backend\n```\n\nOther formats like png, eps, ps, svg support it. I don't see any good reason to do not support streams for pgf and I guess it is a bug :)\n\nThanks.\n",
        "issue_id": 1625,
        "pr_number": 2587,
        "pr_title": "Make backend_pgf more flexible when saving to file-handles or streams (fix #1625).",
        "pr_body": "Since binary data and thus raster images cannot be embedded in pgf code, saving to a stream was prohibited in backend_pgf. This PR allows saving pgf code to streams after deactivating draw_image() and emitting a user warning.\n\nI'll merge this in a few days if there are no objections (fixing issue #1625).\n",
        "issue_closed_at": "2013-11-12T13:20:52Z",
        "base_commit": "c91589c024aa4c95288173112d3d5c44e1703d27"
      },
      "summary": "### Summary:\n\nThis issue pertains to the inability of the Matplotlib library's PGF backend to save graphical output directly to a stream, such as `sys.stdout`. The problem manifests when attempting to use the `plt.savefig()` function with a PGF format target, which results in a `ValueError` indicating that saving to a stream is unsupported. This behavior contrasts with other formats like PNG, EPS, PS, and SVG, which do support stream output, suggesting an inconsistency in the library's functionality. The affected component is the PGF backend of Matplotlib, specifically within the file `lib/matplotlib/backends/backend_pgf.py`, impacting functions `FigureManagerPgf.__init__` and `FigureCanvasPgf.print_pgf`. The absence of stream support for PGF could limit flexibility for users needing to redirect output dynamically or integrate with other systems through streaming. The severity is moderate, as it does not affect all users but poses a limitation for specific use cases involving PGF output. The issue suggests a potential oversight or incomplete implementation in the PGF backend's handling of output streams.",
      "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: saving pgf to a stream is not supported\n\nBody:\nHi,\n\nThe pgf output does not support a stream as illustrated by this snippet\n\n``` python\nimport sys\nplt.plot([1,2])\nplt.savefig(sys.stdout, format='pgf')\n```\n\nIt returns:\n\n``` python\nValueError: saving pgf to a stream is not supported, consider using the pdf option of the pgf-backend\n```\n\nOther formats like png, eps, ps, svg support it. I don't see any good reason to do not support streams for pgf and I guess it is a bug :)\n\nThanks.\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_pgf.py\n  line: line 12\n  function: FigureManagerPgf.__init__\n  function: FigureCanvasPgf.print_pgf\n"
    }
  ]
}