{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-23987",
    "repo": "matplotlib/matplotlib",
    "created_at": "2022-09-22T21:39:02Z",
    "problem_statement": "[Bug]: Constrained layout UserWarning even when False\n### Bug summary\r\n\r\nWhen using layout settings such as `plt.subplots_adjust` or `bbox_inches='tight`, a UserWarning is produced due to incompatibility with constrained_layout, even if constrained_layout = False. This was not the case in previous versions.\r\n\r\n### Code for reproduction\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport numpy as np\r\na = np.linspace(0,2*np.pi,100)\r\nb = np.sin(a)\r\nc = np.cos(a)\r\nfig,ax = plt.subplots(1,2,figsize=(8,2),constrained_layout=False)\r\nax[0].plot(a,b)\r\nax[1].plot(a,c)\r\nplt.subplots_adjust(wspace=0)\r\n```\r\n\r\n\r\n### Actual outcome\r\n\r\nThe plot works fine but the warning is generated\r\n\r\n`/var/folders/ss/pfgdfm2x7_s4cyw2v0b_t7q80000gn/T/ipykernel_76923/4170965423.py:7: UserWarning: This figure was using a layout engine that is incompatible with subplots_adjust and/or tight_layout; not calling subplots_adjust.\r\n  plt.subplots_adjust(wspace=0)`\r\n\r\n### Expected outcome\r\n\r\nno warning\r\n\r\n### Additional information\r\n\r\nWarning disappears when constrained_layout=False is removed\r\n\r\n### Operating system\r\n\r\nOS/X\r\n\r\n### Matplotlib Version\r\n\r\n3.6.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\nconda\n",
    "patch": "diff --git a/lib/matplotlib/figure.py b/lib/matplotlib/figure.py\n--- a/lib/matplotlib/figure.py\n+++ b/lib/matplotlib/figure.py\n@@ -2426,9 +2426,12 @@ def __init__(self,\n             if isinstance(tight_layout, dict):\n                 self.get_layout_engine().set(**tight_layout)\n         elif constrained_layout is not None:\n-            self.set_layout_engine(layout='constrained')\n             if isinstance(constrained_layout, dict):\n+                self.set_layout_engine(layout='constrained')\n                 self.get_layout_engine().set(**constrained_layout)\n+            elif constrained_layout:\n+                self.set_layout_engine(layout='constrained')\n+\n         else:\n             # everything is None, so use default:\n             self.set_layout_engine(layout=layout)\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_14950",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves backend management and interactive mode, which is unrelated to layout warnings."
      },
      {
        "idx": 2,
        "id": "similar_11515",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve unintended behavior due to parameter handling in subplot configurations."
      },
      {
        "idx": 3,
        "id": "similar_14911",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about removing shared axes, which does not relate to layout warnings or parameter handling."
      },
      {
        "idx": 4,
        "id": "similar_14011",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves argument handling conflicts, which is not directly related to layout warnings."
      },
      {
        "idx": 5,
        "id": "similar_11138",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about icon appearance, which is unrelated to layout or parameter handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "plt.ioff() not supressing figure generation",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\nUsual behaviour for supressing plots (by enabling plt.ioff()) no longer working since update to latest version of conda.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\nx = np.random.rand(10)\r\ny = np.random.rand(10)\r\n\r\nplt.ioff()\r\nplt.plot(x, y)\r\n```\r\n\r\n**Actual outcome**\r\nIn Spyder IDE, still generates figure window. \r\n\r\n\r\n**Expected outcome**\r\nFigure window should not appear. plt.ioff() should disable interactive mode, and require a plt.show() call to generate figure window.\r\n\r\n**Matplotlib version**\r\n  * Operating system: Windows 10\r\n  * Matplotlib version: 3.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.3\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: numpy 1.16.4\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\nconda\r\n\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\nDefault channel (via https://www.anaconda.com/distribution/ )",
        "issue_id": 14950,
        "pr_number": 14979,
        "pr_title": "FIX: Don't enable IPython integration if not entering REPL.",
        "pr_body": "IPython can also be used to simply run files; when this is the case we\r\nare not going to be interactive; and we do not want to enable the\r\neventloop integration. Otherwise someone doing:\r\n\r\n    $ ipython script.py\r\n\r\nWill simply see a window blink, as IPython will exit immediately instead\r\nof showing the window and exit.\r\n\r\nI'm not quite sure how to test that are we basically _want_ something to\r\nblock forever and wait for user input; so no test added\r\n\r\nCloses: https://github.com/ipython/ipython/issues/11837\r\n\r\n## PR Summary\r\n\r\n## PR Checklist\r\n\r\n- [ ] Has Pytest style unit tests\r\n- [x] 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\n",
        "issue_closed_at": "2019-08-09T13:39:32Z",
        "base_commit": "73e2f562bff000e8c3f1718151bda968fae89e0a"
      },
      "summary": "### Summary:\n\nThis issue is a software bug related to the Matplotlib library, specifically concerning the functionality of the `plt.ioff()` command, which is intended to disable interactive plotting mode. The problem was identified after an update to the latest version of the Conda package manager. Users observed that, contrary to expected behavior, a figure window was still being generated in the Spyder IDE environment even when `plt.ioff()` was explicitly called in the code. This suggests that the command was not effectively disabling interactive mode, which traditionally requires a subsequent `plt.show()` call to render plots. \n\nKey symptoms include the unintended appearance of a figure window despite the use of `plt.ioff()`, indicating that the suppression of plot generation was not functioning as anticipated. The affected systems include Windows 10 operating systems running Python 3.7.3 with Matplotlib version 3.1.0, specifically when using the Qt5Agg backend in the Spyder IDE.\n\nThe potential impact of this issue is moderate, as it disrupts the expected workflow for users who rely on interactive plot suppression for tasks such as automated script execution or batch processing where manual plot display is undesired. It could affect data analysis or visualization processes by causing unwanted interruptions.\n\nRelevant technical details include the involvement of Matplotlib's backend management, with the patch addressing functions in the `backend_bases.py` file, specifically `_draw` and `FigureCanvasBase._fix_ipython_backend2gui`. This suggests a backend-specific issue possibly related to the integration with the IPython environment or GUI handling, which was resolved through modifications in these functions.",
      "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: plt.ioff() not supressing figure generation\n\nBody:\n### Bug report\r\n\r\n**Bug summary**\r\nUsual behaviour for supressing plots (by enabling plt.ioff()) no longer working since update to latest version of conda.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\nx = np.random.rand(10)\r\ny = np.random.rand(10)\r\n\r\nplt.ioff()\r\nplt.plot(x, y)\r\n```\r\n\r\n**Actual outcome**\r\nIn Spyder IDE, still generates figure window. \r\n\r\n\r\n**Expected outcome**\r\nFigure window should not appear. plt.ioff() should disable interactive mode, and require a plt.show() call to generate figure window.\r\n\r\n**Matplotlib version**\r\n  * Operating system: Windows 10\r\n  * Matplotlib version: 3.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.3\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: numpy 1.16.4\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\nconda\r\n\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\nDefault channel (via https://www.anaconda.com/distribution/ )\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/backend_bases.py\n  function: _draw\n  function: FigureCanvasBase._fix_ipython_backend2gui\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, specifically when using the `sharex` keyword argument in conjunction with the `subplot_kw` argument. The problem manifests when the `sharex` parameter is used in a call to create subplots; it inadvertently causes all subsequent subplot calls to share the x-axis if the `subplot_kw` dictionary is reused without modification. This is due to an unintended modification of the `subplot_kw` dictionary, leading to shared axis behavior persisting across different subplot calls.\n\nKey symptoms include:\n- The x-axis is unexpectedly shared between subplots that should have independent axes, particularly evident when subsequent subplot calls do not explicitly set the `sharex` parameter but still share the axis due to prior modifications.\n- The issue is specifically observed when transitioning from a subplot configuration with shared axes to another configuration without explicit axis sharing.\n\nThe affected component is the `Figure.subplots` function within the Matplotlib library, particularly its handling of the `subplot_kw` dictionary.\n\nThe impact of this issue may confuse users who expect independent axes for each subplot, potentially leading to incorrect data visualization and interpretation. The severity is moderate as it affects the accuracy of visual outputs in scientific and analytical applications using Matplotlib.\n\nThe technical resolution involves creating a copy of the `subplot_kw` dictionary within the function to prevent unintended modifications, thus preserving expected behavior across multiple subplot configurations. This fix ensures that subsequent subplot calls do not inherit shared axis settings unless explicitly specified, maintaining the independence of axes as intended by the user.",
      "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": "Removing a shared axes via `ax.remove()` leads to an error.",
        "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\nremoving a shared axes via `ax.remove()` leads to an error.\r\n\r\nThis bisects to \"Fix locator/formatter setting when removing shared Axes\" #13983 (in current master, targeted for 3.2) which initially headed out to make the situation of removing a shared axes better, fixing https://github.com/matplotlib/matplotlib/issues/12853, but apparently the test doesn't capture the below simple case.\r\n\r\nHence marking as release critical for 3.2, in order not to release this bug.\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\n\r\nfig, axs = plt.subplots(2, sharex=True)\r\n\r\naxs[0].remove()\r\n\r\nplt.show()\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\nTraceback (most recent call last):\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\backends\\backend_qt5.py\", line 488, in _draw_idle\r\n    self.draw()\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\backends\\backend_agg.py\", line 396, in draw\r\n    self.figure.draw(self.renderer)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\artist.py\", line 38, in draw_wrapper\r\n    return draw(artist, renderer, *args, **kwargs)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\figure.py\", line 1722, in draw\r\n    renderer, self, artists, self.suppressComposite)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\image.py\", line 136, in _draw_list_compositing_images\r\n    a.draw(renderer)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\artist.py\", line 38, in draw_wrapper\r\n    return draw(artist, renderer, *args, **kwargs)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axes\\_base.py\", line 2622, in draw\r\n    mimage._draw_list_compositing_images(renderer, self, artists)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\image.py\", line 136, in _draw_list_compositing_images\r\n    a.draw(renderer)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\artist.py\", line 38, in draw_wrapper\r\n    return draw(artist, renderer, *args, **kwargs)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axis.py\", line 1227, in draw\r\n    ticks_to_draw = self._update_ticks()\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axis.py\", line 1103, in _update_ticks\r\n    major_locs = self.get_majorticklocs()\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axis.py\", line 1348, in get_majorticklocs\r\n    return self.major.locator()\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\ticker.py\", line 2032, in __call__\r\n    return self.tick_values(vmin, vmax)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\ticker.py\", line 2040, in tick_values\r\n    locs = self._raw_ticks(vmin, vmax)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\ticker.py\", line 1979, in _raw_ticks\r\n    nbins = np.clip(self.axis.get_tick_space(),\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axis.py\", line 2193, in get_tick_space\r\n    length = ((ends[1][0] - ends[0][0]) / self.axes.figure.dpi) * 72\r\nAttributeError: 'NoneType' object has no attribute 'dpi'\r\n```\r\n\r\n**Expected outcome**\r\n\r\nA plot with the first axes removed, as would be achieved with the same code running in 3.1\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: Win 8.1\r\n  * Matplotlib version: current master\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.6\r\n\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": 14911,
        "pr_number": 14997,
        "pr_title": "Correctly set formatters and locators on removed shared axis",
        "pr_body": "Fixes #14911 \r\n\r\nThe issue was that a shared axis might never have it's `Formatter/Locator` set, which is fine when it is shared, but when the axis storing the `Formatter/Locator` it relies on is removed, the previous shared axis needs to have the `Formatter/Locator`s set.\r\n\r\nAlso fixed typo `_reset_axis_form` > `_reset_axis_from`.\r\n\r\nI've tried a few things, but cannot come up with a more elegant solution than this; if anyone has any ideas suggestions welcome.",
        "issue_closed_at": "2019-08-19T13:22:50Z",
        "base_commit": "7de91c8ba92f86f46a3090a2922096648c3df54b"
      },
      "summary": "### Summary:\nThis issue is related to a bug in a plotting library whereby attempting to remove a shared axis using the `ax.remove()` method results in an error. The problem surfaced after a recent change aimed at improving how locators and formatters are set when removing shared axes. The bug is critical because it introduces a regression that affects the ability to remove shared axes without errors, a capability that was functioning correctly in the previous version (3.1).\n\n1. **Problem description in general terms**: The bug occurs when attempting to remove an axis that is shared with others in a plot, leading to an exception and preventing the plot from rendering as expected.\n\n2. **Key symptoms and behaviors observed**: Upon running the provided code snippet, an error is raised during the drawing process of the plot. The specific error is an `AttributeError` indicating that a `NoneType` object does not have the attribute `dpi`. This error suggests that the removal of the shared axis leaves certain attributes uninitialized or improperly handled.\n\n3. **Affected components or systems**: The issue affects the Matplotlib library, specifically the `Figure` and `Axes` components in the plotting system. It impacts the functionality of shared axes within a figure, particularly when attempting to remove an axis.\n\n4. **Potential impact or severity**: The impact is significant as it breaks backward compatibility, preventing users from removing shared axes, a feature that previously worked. It is marked as a release-critical issue for version 3.2, indicating that it needs to be resolved before the release to maintain the integrity of the library's functionality.\n\n5. **Any relevant technical details abstracted for broader understanding**: The error traces back to the code responsible for rendering the plot, specifically during the tick update process. The issue seems to be related to the handling of tick locations and space calculation, which fails due to an uninitialized or mismanaged plot attribute after an axis removal. The fix involves updating the `Figure.subplots` and `Figure._break_share_link` functions to ensure proper management of shared axes and their attributes.",
      "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: Removing a shared axes via `ax.remove()` leads to an error.\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\nremoving a shared axes via `ax.remove()` leads to an error.\r\n\r\nThis bisects to \"Fix locator/formatter setting when removing shared Axes\" #13983 (in current master, targeted for 3.2) which initially headed out to make the situation of removing a shared axes better, fixing https://github.com/matplotlib/matplotlib/issues/12853, but apparently the test doesn't capture the below simple case.\r\n\r\nHence marking as release critical for 3.2, in order not to release this bug.\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\n\r\nfig, axs = plt.subplots(2, sharex=True)\r\n\r\naxs[0].remove()\r\n\r\nplt.show()\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\nTraceback (most recent call last):\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\backends\\backend_qt5.py\", line 488, in _draw_idle\r\n    self.draw()\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\backends\\backend_agg.py\", line 396, in draw\r\n    self.figure.draw(self.renderer)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\artist.py\", line 38, in draw_wrapper\r\n    return draw(artist, renderer, *args, **kwargs)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\figure.py\", line 1722, in draw\r\n    renderer, self, artists, self.suppressComposite)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\image.py\", line 136, in _draw_list_compositing_images\r\n    a.draw(renderer)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\artist.py\", line 38, in draw_wrapper\r\n    return draw(artist, renderer, *args, **kwargs)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axes\\_base.py\", line 2622, in draw\r\n    mimage._draw_list_compositing_images(renderer, self, artists)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\image.py\", line 136, in _draw_list_compositing_images\r\n    a.draw(renderer)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\artist.py\", line 38, in draw_wrapper\r\n    return draw(artist, renderer, *args, **kwargs)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axis.py\", line 1227, in draw\r\n    ticks_to_draw = self._update_ticks()\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axis.py\", line 1103, in _update_ticks\r\n    major_locs = self.get_majorticklocs()\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axis.py\", line 1348, in get_majorticklocs\r\n    return self.major.locator()\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\ticker.py\", line 2032, in __call__\r\n    return self.tick_values(vmin, vmax)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\ticker.py\", line 2040, in tick_values\r\n    locs = self._raw_ticks(vmin, vmax)\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\ticker.py\", line 1979, in _raw_ticks\r\n    nbins = np.clip(self.axis.get_tick_space(),\r\n  File \"d:\\***\\matplotlib\\lib\\matplotlib\\axis.py\", line 2193, in get_tick_space\r\n    length = ((ends[1][0] - ends[0][0]) / self.axes.figure.dpi) * 72\r\nAttributeError: 'NoneType' object has no attribute 'dpi'\r\n```\r\n\r\n**Expected outcome**\r\n\r\nA plot with the first axes removed, as would be achieved with the same code running in 3.1\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: Win 8.1\r\n  * Matplotlib version: current master\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.6\r\n\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/figure.py\n  function: Figure.subplots\n  function: Figure._break_share_link\n"
    },
    {
      "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:\nThis issue is related to a TypeError encountered when using the `plt.subplot` function from the Matplotlib library with a specified `figure` argument. The problem arises due to the function attempting to handle multiple values for the 'figure' argument, resulting in a conflict during execution.\n\n1. **Problem description in general terms**: \n   The problem involves a conflict in argument handling for the `plt.subplot` function in Matplotlib, where specifying a `figure` argument leads to a TypeError. The function does not properly manage the case where a 'figure' argument is provided, leading to a clash with internal function calls.\n\n2. **Key symptoms and behaviors observed**: \n   Users experience a TypeError indicating that `process_projection_requirements()` received multiple values for the 'figure' argument. The error manifests when `plt.subplot` is called with a specified `figure`, either as a new figure instance or as `None`.\n\n3. **Affected components or systems**: \n   The affected components include the `subplot` function in `lib/matplotlib/pyplot.py` and the `add_subplot` method in `lib/matplotlib/figure.py`. These components are integral to the subplot creation process in the Matplotlib library.\n\n4. **Potential impact or severity**: \n   This issue can hinder users from effectively using the subplot functionality with custom figure objects, potentially disrupting data visualization tasks. The severity is moderate as it impacts usability but does not cause data loss or crashes.\n\n5. **Relevant technical details abstracted for broader understanding**: \n   The root cause lies in the `plt.subplot` function's reliance on `plt.gcf()` to fetch the current figure without properly checking if a 'figure' argument is explicitly passed. The solution involves implementing a check for the 'figure' argument in the function's logic to prevent the TypeError.",
      "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": "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 is related to the inconsistent appearance of window icons when generating multiple figure windows using the Matplotlib library with the TkAgg backend on a Windows operating system. The problem arises when plotting more than one figure window: only the first figure window displays the default Matplotlib icon, while subsequent windows revert to the default Tk icon. The key symptom is the logging of error messages indicating the inability to load the Matplotlib icon for additional figure windows. This discrepancy primarily affects the visual consistency of the application interface, which could confuse users or diminish the aesthetic of applications relying on multiple plots. The issue is traced back to the `new_figure_manager_given_figure` method within the `matplotlib/backends/_backend_tk.py` file, where the attempt to set the icon using the `iconphoto` command fails. This is likely due to limitations or misconfigurations related to the Tk version or its handling of image resources in this context. The severity of this issue is moderate, affecting user interface consistency but not the core functionality of the plots themselves.",
      "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"
    }
  ]
}