{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-23913",
    "repo": "matplotlib/matplotlib",
    "created_at": "2022-09-16T21:51:24Z",
    "problem_statement": "legend draggable as keyword\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### Feature request\r\n\r\n**There is not keyword to make legend draggable at creation**\r\n\r\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n\r\nIs there a code reason why one can not add a \"draggable=True\" keyword to the __init__ function for Legend?  This would be more handy than having to call it after legend creation.  And, naively, it would seem simple to do.  But maybe there is a reason why it would not work?\n",
    "patch": "diff --git a/lib/matplotlib/legend.py b/lib/matplotlib/legend.py\n--- a/lib/matplotlib/legend.py\n+++ b/lib/matplotlib/legend.py\n@@ -286,6 +286,9 @@ def _update_bbox_to_anchor(self, loc_in_canvas):\n     The custom dictionary mapping instances or types to a legend\n     handler. This *handler_map* updates the default handler map\n     found at `matplotlib.legend.Legend.get_legend_handler_map`.\n+\n+draggable : bool, default: False\n+    Whether the legend can be dragged with the mouse.\n \"\"\")\n \n \n@@ -342,7 +345,8 @@ def __init__(\n         title_fontproperties=None,  # properties for the legend title\n         alignment=\"center\",       # control the alignment within the legend box\n         *,\n-        ncol=1  # synonym for ncols (backward compatibility)\n+        ncol=1,  # synonym for ncols (backward compatibility)\n+        draggable=False  # whether the legend can be dragged with the mouse\n     ):\n         \"\"\"\n         Parameters\n@@ -537,7 +541,9 @@ def val_or_rc(val, rc_name):\n             title_prop_fp.set_size(title_fontsize)\n \n         self.set_title(title, prop=title_prop_fp)\n+\n         self._draggable = None\n+        self.set_draggable(state=draggable)\n \n         # set the text color\n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_10140",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue focuses on CPU utilization and event handling, which is unrelated to adding a keyword parameter for legend creation."
      },
      {
        "idx": 2,
        "id": "similar_8668",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve adding or documenting keyword parameters in Matplotlib, making the reasoning about parameter handling transferable."
      },
      {
        "idx": 3,
        "id": "similar_15103",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with interactive data cursors and masked arrays, which is unrelated to keyword parameter addition in legend creation."
      },
      {
        "idx": 4,
        "id": "similar_1235",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about legend positioning, which does not relate to the addition of a keyword parameter for legend creation."
      },
      {
        "idx": 5,
        "id": "similar_20490",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue concerns memory management and backend-specific problems, which are unrelated to keyword parameter addition in legend creation."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Qt5Agg eats 100% CPU when plotting with block=True in interactive mode",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\n\r\nWhen using Qt5Agg, Matplotlib consumes a full CPU core while an interactive window is open.  The cursor repeatedly shows a \"spinner\" when I mouse over the canvas.  This didn't used to be the case.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nplt.plot([1, 2], [3, 4])\r\nplt.ion()\r\nplt.show(block=True)\r\n```\r\n\r\n**Actual outcome**\r\n\r\nOne of the CPU cores is pegged at 100%.  Interface is very slow and barely responsive.\r\n\r\n**Expected outcome**\r\n\r\nShould not use up 100% of a CPU core when nothing is happening.\r\n\r\n**Matplotlib version**\r\n\r\n  * Operating system: Linux 4.14.8\r\n  * Matplotlib version: 2.1.1+864.g92a93d698.dirty\r\n  * Matplotlib backend: Qt5Agg\r\n  * Python version: 3.6.4\r\n\r\nThis was reproduced on both XMonad and XFCE4.  Affects both `python-matplotlib` (2.1.1) from official Arch repos and `python-matplotlib-git` from AUR.",
        "issue_id": 10140,
        "pr_number": 10142,
        "pr_title": "FIX: prevent recursive draws with plt.ion not in IPython with qt5agg",
        "pr_body": "## PR Summary\r\n\r\nIn 9b8a944db954c8240e14413e517e1b781881b80b the latch logic was moved\r\nabove the call to `self.draw` to de-latch the call to\r\n`__draw_idle_agg` in `paintEvent` to protect against `blit` calls\r\nduring a draw.\r\n\r\nHowever, this now fails to properly latch the base draw so with\r\n`plt.ion` (not in IPython) the stale callback will cause a (possibly\r\ninfinite) recursion in the draw due to stale being set as part of the\r\ndraw call (which will re-trigger the draw).\r\n\r\nThis adds a second flag to track if we are currently rendering and\r\nbail.\r\n\r\ncloses #10140\r\n\r\n\r\nI suspect a better fix is to re-think how the stale callbacks propagate or how the non-ipython stale callback works, but I think this is the minimal change which fixes a critical issue.\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": "2018-01-04T20:28:55Z",
        "base_commit": "008da385fe73614059430073a722d674ade55014"
      },
      "summary": "### Summary:\nThis issue is related to high CPU utilization in the Matplotlib library when using the Qt5Agg backend in interactive mode. The problem manifests as one CPU core being fully engaged when an interactive plotting window is open, causing system performance degradation and an unresponsive user interface. The issue is observed when the `plt.show(block=True)` function is invoked, leading to excessive CPU usage despite no active interactions occurring. This behavior negatively impacts user experience by making the interface slow and unresponsive.\n\nKey symptoms include:\n- A single CPU core running at 100% utilization.\n- Slow and barely responsive interface.\n- Repeated display of a \"spinner\" cursor over the plotting canvas.\n\nThe affected components are those related to the Qt5Agg backend of Matplotlib, specifically functions within the `FigureCanvasQTAggBase` class. These components are responsible for rendering and updating the plot display in interactive sessions.\n\nThe potential impact of this issue includes reduced application performance and increased power consumption, which can be particularly problematic in resource-constrained environments or when running multiple applications concurrently.\n\nRelevant technical details involve the need for efficient event handling and resource management within the Matplotlib backend to prevent excessive CPU usage during idle periods. The fixed code elements suggest improvements in the initialization and drawing functions to address these inefficiencies.",
      "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: Qt5Agg eats 100% CPU when plotting with block=True in interactive mode\n\nBody:\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nWhen using Qt5Agg, Matplotlib consumes a full CPU core while an interactive window is open.  The cursor repeatedly shows a \"spinner\" when I mouse over the canvas.  This didn't used to be the case.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nplt.plot([1, 2], [3, 4])\r\nplt.ion()\r\nplt.show(block=True)\r\n```\r\n\r\n**Actual outcome**\r\n\r\nOne of the CPU cores is pegged at 100%.  Interface is very slow and barely responsive.\r\n\r\n**Expected outcome**\r\n\r\nShould not use up 100% of a CPU core when nothing is happening.\r\n\r\n**Matplotlib version**\r\n\r\n  * Operating system: Linux 4.14.8\r\n  * Matplotlib version: 2.1.1+864.g92a93d698.dirty\r\n  * Matplotlib backend: Qt5Agg\r\n  * Python version: 3.6.4\r\n\r\nThis was reproduced on both XMonad and XFCE4.  Affects both `python-matplotlib` (2.1.1) from official Arch repos and `python-matplotlib-git` from AUR.\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_qt5agg.py\n  function: FigureCanvasQTAggBase.__init__\n  function: FigureCanvasQTAggBase.draw\n  function: FigureCanvasQTAggBase.draw_idle\n  function: FigureCanvasQTAggBase.__draw_idle_agg\n"
    },
    {
      "similar_issue": {
        "issue_title": "handles keyword argument not documented in the help of legend",
        "issue_body": "<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nThe following on-line documentation has an example where the `handles` keyword is used in a call to `plt.legend`: <http://matplotlib.org/users/legend_guide.html#controlling-the-legend-entries>\r\n\r\nThis keyword argument is not present in the internal function documentation.\r\n\r\n**Matplotlib version**\r\n  * Operating System: Linux (Xubuntu 16.04)\r\n  * Matplotlib Version: 2.0.0\r\n  * Python Version: 3.6\r\n\r\n",
        "issue_id": 8668,
        "pr_number": 9999,
        "pr_title": "improve legend docstring",
        "pr_body": "## PR Summary\r\n\r\nThis improves the legend docstrings:\r\n- describe handles and labels\r\n- add call signatures to `Axes.legend()`\r\n- Structure and reorder `Axes.legend()` so that the most common use case is at the top.\r\n\r\nalso fixes #8668",
        "issue_closed_at": "2017-12-18T15:29:15Z",
        "base_commit": "7a6bab7ca74308de0afc9656573b9c7de851c236"
      },
      "summary": "### Summary: This issue pertains to the discrepancy between the official documentation and the internal function documentation of a popular plotting library, Matplotlib. Specifically, the `handles` keyword argument, which is demonstrated in the online documentation for controlling legend entries, is not adequately documented in the internal codebase's function documentation. This lack of documentation can lead to confusion among users who rely on inline documentation for understanding function parameters and their usage.\n\n1. Problem description in general terms:\n   - There is a mismatch between the online documentation and the internal function documentation for a specific keyword argument (`handles`) used in the legend functionality of a plotting library. This is an issue of incomplete or missing documentation in the codebase.\n\n2. Key symptoms and behaviors observed:\n   - Users may find an example using the `handles` keyword in the online guide but will not find corresponding documentation in the function definitions themselves. This inconsistency can lead to misunderstandings or misuse of the library's features.\n\n3. Affected components or systems:\n   - The issue affects the documentation of functions related to legend handling in several components of the Matplotlib library, including `Axes.legend`, `Figure.legend`, `DraggableLegend._update_bbox_to_anchor`, and `Legend.__init__`.\n\n4. Potential impact or severity:\n   - The severity of the issue is moderate as it could hinder developers and data scientists from fully utilizing the library's capabilities, especially those who rely on inline documentation for quick reference. However, since the functionality itself is not broken, the impact is more on usability and developer experience.\n\n5. Any relevant technical details abstracted for broader understanding:\n   - The `handles` keyword is used to customize legend entries in plots, a common task in data visualization. Ensuring that all relevant documentation is consistent across various sources (online guides and inline documentation) is crucial for maintaining the library's accessibility and ease of use. The fix involves updating internal documentation across several files to align with the online examples.",
      "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: handles keyword argument not documented in the help of legend\n\nBody:\n<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nThe following on-line documentation has an example where the `handles` keyword is used in a call to `plt.legend`: <http://matplotlib.org/users/legend_guide.html#controlling-the-legend-entries>\r\n\r\nThis keyword argument is not present in the internal function documentation.\r\n\r\n**Matplotlib version**\r\n  * Operating System: Linux (Xubuntu 16.04)\r\n  * Matplotlib Version: 2.0.0\r\n  * Python Version: 3.6\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/axes/_axes.py\n  function: Axes.legend\n\nlib/matplotlib/figure.py\n  function: Figure.legend\n\nlib/matplotlib/legend.py\n  function: DraggableLegend._update_bbox_to_anchor\n  function: Legend.__init__\n\nlib/matplotlib/pyplot.py\n  function: pause\n"
    },
    {
      "similar_issue": {
        "issue_title": "Colorbar for imshow messes interactive cursor with masked data",
        "issue_body": "### Bug report\r\n\r\nAdding a colorbar when the mappable is the result of imshow for a masked array changes the behavior of the interactive z-data cursor and triggers a UserWarning.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\nmask = np.zeros((4, 4), bool)\r\nmask[:2] = True\r\nA = np.ma.array(np.random.rand(4, 4), mask=mask)\r\n\r\nfig, ax = plt.subplots(1, 1)\r\nim = ax.imshow(A)\r\nfig.colorbar(im)\r\n```\r\n\r\n**Actual outcome**\r\n```\r\n~/.anaconda3/lib/python3.7/site-packages/matplotlib/ticker.py:632: UserWarning: Warning: converting a masked element to nan.\r\n  return '%-12g' % value\r\n```\r\n![Screenshot from 2019-08-22 18-22-23](https://user-images.githubusercontent.com/52320542/63531938-e9d5ef00-c509-11e9-83ef-7ce9bc3f3c59.png)\r\n\r\n**Expected outcome**\r\nBefore adding the colorbar, the zdata cursor shows a blank (`[]`).\r\n\r\n**Matplotlib version**\r\n  * Operating system: Linux\r\n  * Matplotlib version: 3.1.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.3\r\n  * IPython version: 7.2.0\r\n  * Other libraries: \r\nMatplotlib installed from pip.\r\n\r\n\r\n\r\n",
        "issue_id": 15103,
        "pr_number": 15140,
        "pr_title": "Fix ScalarFormatter formatting of masked values",
        "pr_body": "Fixes #15103. Could probably do with a test. Possibly an API change since previously a masked value would be formatted as `nan`?",
        "issue_closed_at": "2019-08-28T03:46:25Z",
        "base_commit": "40dfc353aa66b93fd0fbc55ca1f51701202c0549"
      },
      "summary": "### Summary:\nThis issue is related to the integration of colorbars with imshow plots of masked arrays within the Matplotlib library, which affects the functionality of interactive data cursors. When a colorbar is added to an imshow plot representing a masked array, the interactive z-data cursor's behavior is altered, resulting in unexpected outputs and the triggering of a UserWarning. The warning specifically indicates a conversion of masked elements to NaN values, which can confuse users relying on the interactive cursor for accurate data representation.\n\n1. **Problem Description**: The problem arises when a colorbar is added to an imshow plot that visualizes a masked array. This causes a change in the behavior of the interactive data cursor, leading to warnings and potentially misleading data interactions.\n\n2. **Key Symptoms and Behaviors Observed**: Users experience a UserWarning about converting masked elements to NaN. Additionally, the interactive cursor displays incorrect or unexpected data values when interacting with the plot.\n\n3. **Affected Components or Systems**: The issue affects the Matplotlib library, particularly components involved in data visualization using imshow and colorbars, as well as the interactive data cursor functionality.\n\n4. **Potential Impact or Severity**: The issue can impact data analysis and visualization tasks by providing incorrect or misleading data through the interactive cursor. This can lead to misinterpretation of the visual data output, especially in scientific or analytical applications.\n\n5. **Relevant Technical Details**: The problem is linked to the Matplotlib version 3.1.1, running on a Linux operating system with Python version 3.7.3 and using the Qt5Agg backend. It involves the handling of masked arrays in conjunction with colorbars and the subsequent interaction with the data cursor, which is addressed in the `LogitFormatter.format_data_short` function within the `lib/matplotlib/ticker.py` file.",
      "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: Colorbar for imshow messes interactive cursor with masked data\n\nBody:\n### Bug report\r\n\r\nAdding a colorbar when the mappable is the result of imshow for a masked array changes the behavior of the interactive z-data cursor and triggers a UserWarning.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\nmask = np.zeros((4, 4), bool)\r\nmask[:2] = True\r\nA = np.ma.array(np.random.rand(4, 4), mask=mask)\r\n\r\nfig, ax = plt.subplots(1, 1)\r\nim = ax.imshow(A)\r\nfig.colorbar(im)\r\n```\r\n\r\n**Actual outcome**\r\n```\r\n~/.anaconda3/lib/python3.7/site-packages/matplotlib/ticker.py:632: UserWarning: Warning: converting a masked element to nan.\r\n  return '%-12g' % value\r\n```\r\n![Screenshot from 2019-08-22 18-22-23](https://user-images.githubusercontent.com/52320542/63531938-e9d5ef00-c509-11e9-83ef-7ce9bc3f3c59.png)\r\n\r\n**Expected outcome**\r\nBefore adding the colorbar, the zdata cursor shows a blank (`[]`).\r\n\r\n**Matplotlib version**\r\n  * Operating system: Linux\r\n  * Matplotlib version: 3.1.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.3\r\n  * IPython version: 7.2.0\r\n  * Other libraries: \r\nMatplotlib installed from pip.\r\n\r\n\r\n\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/ticker.py\n  function: LogitFormatter.format_data_short\n"
    },
    {
      "similar_issue": {
        "issue_title": "Legend placement bug",
        "issue_body": "This script produces a legend that covers the red point:\n\n``` python\nimport matplotlib.pyplot as plt\n\ncolors = ['b','g','r']\nfor n in range(3):\n    plt.scatter([n,],[n,],color=colors[n])\nplt.legend(['foo','foo','foo'],loc='best')\nplt.gca().set_xlim(-0.5, 2.2)\nplt.gca().set_ylim(-0.5, 2.2)\nplt.show()\n```\n",
        "issue_id": 1235,
        "pr_number": 6110,
        "pr_title": "Fixes matplotlib/matplotlib#1235",
        "pr_body": "Credit to @dashed, fixes #1235, supercedes #2857 \n\nThe problem is that _find_best_position does not receive positions of (transformed) points from _auto_legend_data. We attempted to fix it by adding the offsets of points, after preparing the points and transforming them, and calling legendBox.count_contains on offsets.\n",
        "issue_closed_at": "2016-03-07T14:11:57Z",
        "base_commit": "963e51d4df44fa58bf89840b19f2d0f12a0e605a"
      },
      "summary": "### Summary:\n\nThis issue is related to a graphical rendering problem where a legend in a plot is incorrectly placed, such that it obscures important data points on the graph. Specifically, in a plotting script using the Matplotlib library, the legend overlaps with a red data point, which is visually disruptive and can lead to misinterpretation of the data.\n\n1. **Problem Description in General Terms**:\n   The problem involves the automatic positioning of a legend in a data visualization plot. The legend is meant to describe various elements of the plot, but it is mistakenly positioned in a way that it covers critical data points, making them invisible to the viewer.\n\n2. **Key Symptoms and Behaviors Observed**:\n   The primary symptom is the legend covering a red point in the plot, which is unexpected behavior as the legend should ideally find a location that does not obscure any significant data points. This can mislead users or require them to reposition the legend manually.\n\n3. **Affected Components or Systems**:\n   The components affected by this issue are part of the Matplotlib library, specifically within the legend management subsystem. The functions involved in computing the legend's optimal position are primarily impacted, as they are responsible for determining where the legend is placed in relation to the plot elements.\n\n4. **Potential Impact or Severity**:\n   The impact of this issue is significant in contexts where accurate data representation is critical. If the legend obscures data points, it can result in misinterpretation of the visualized information, potentially affecting decision-making processes based on the plot.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**:\n   The technical root of the issue lies in the algorithm responsible for determining the 'best' location for the legend. This algorithm failed to account for the visibility of underlying data points, particularly in scenarios where the plot dimensions are constrained or densely populated with data. Improvements or patches would likely involve enhancing the logic that evaluates potential legend positions to ensure data points remain visible. The changes made in the Matplotlib library's `legend.py` file, particularly in the `Legend._auto_legend_data` and `Legend._find_best_position` functions, suggest updates to the algorithm used for calculating these positions.",
      "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: Legend placement bug\n\nBody:\nThis script produces a legend that covers the red point:\n\n``` python\nimport matplotlib.pyplot as plt\n\ncolors = ['b','g','r']\nfor n in range(3):\n    plt.scatter([n,],[n,],color=colors[n])\nplt.legend(['foo','foo','foo'],loc='best')\nplt.gca().set_xlim(-0.5, 2.2)\nplt.gca().set_ylim(-0.5, 2.2)\nplt.show()\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/legend.py\n  function: Legend._auto_legend_data\n  function: Legend._auto_legend_data\n  function: Legend._find_best_position\n  function: Legend._find_best_position\n"
    },
    {
      "similar_issue": {
        "issue_title": "Memory leaks on matplotlib 3.4.2 (and 3.4.0)",
        "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\r\n**Bug summary**\r\n\r\nMultiple different memory related errors when running as a part of script creating and saving lots of figures.\r\n\r\n\r\n**Code for reproduction**\r\n\r\nSorry, could not create a minimal example that reproduces this. Just wanted to leave a note. \r\n\r\n\r\n\r\n**Actual outcome**\r\n\r\nThere are multiple different errors that happen. Running the same script will produce different results randomly.\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n**Example 1**\r\nJust prints this. No Exceptions, nothing. Script stops running.\r\n```\r\nunable to alloc 4320000 bytes\r\n```\r\n\r\n**Example 2** \r\n\r\n```python\r\n  File \"c:\\myapp\\calculations\\myscript.py\", line 422, in create_figure\r\n    fig, ax = plt.subplots(nrows=1, figsize=(16, 9))\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\_api\\deprecation.py\", line 471, in wrapper\r\n    return func(*args, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\pyplot.py\", line 1439, in subplots\r\n    fig = figure(**fig_kw)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\pyplot.py\", line 797, in figure\r\n    manager = new_figure_manager(\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\pyplot.py\", line 316, in new_figure_manager\r\n    return _backend_mod.new_figure_manager(*args, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backend_bases.py\", line 3545, in new_figure_manager\r\n    return cls.new_figure_manager_given_figure(num, fig)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\_backend_tk.py\", line 899, in new_figure_manager_given_figure\r\n    canvas = cls.FigureCanvas(figure, master=window)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\_api\\deprecation.py\", line 431, in wrapper\r\n    return func(*inner_args, **inner_kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\_backend_tk.py\", line 174, in __init__\r\n    self._tkphoto = tk.PhotoImage(\r\n  File \"C:\\Python\\Python 3.8.6-32\\lib\\tkinter\\__init__.py\", line 4061, in __init__\r\n    Image.__init__(self, 'photo', name, cnf, master, **kw)\r\n  File \"C:\\Python\\Python 3.8.6-32\\lib\\tkinter\\__init__.py\", line 4006, in __init__\r\n    self.tk.call(('image', 'create', imgtype, name,) + options)\r\n_tkinter.TclError: not enough free memory for image buffer\r\n```\r\n\r\n**Example 3**\r\n\r\n```python\r\n  File \"c:\\myapp\\calculations\\myscript.py\", line 467, in create_some_figures\r\n    plt.savefig(self.folder / \"myfig.png\")\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\pyplot.py\", line 966, in savefig\r\n    res = fig.savefig(*args, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\figure.py\", line 3005, in savefig\r\n    self.canvas.print_figure(fname, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backend_bases.py\", line 2255, in print_figure\r\n    result = print_method(\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backend_bases.py\", line 1669, in wrapper\r\n    return func(*args, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\backend_agg.py\", line 508, in print_png\r\n    FigureCanvasAgg.draw(self)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\backend_agg.py\", line 401, in draw\r\n    self.renderer = self.get_renderer(cleared=True)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\backend_agg.py\", line 417, in get_renderer\r\n    self.renderer = RendererAgg(w, h, self.figure.dpi)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\backend_agg.py\", line 91, in __init__\r\n    self._renderer = _RendererAgg(int(width), int(height), dpi)\r\nMemoryError: In RendererAgg: Out of memory\r\n```\r\n\r\n**Expected outcome**\r\n\r\n<!--A description of the expected outcome from the code snippet-->\r\n<!--If this used to work in an earlier version of Matplotlib, please note the version it used to work on-->\r\nNo errors. \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:  Windows 10\r\n  * Matplotlib version (`import matplotlib; print(matplotlib.__version__)`): 3.4.2\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg \r\n  * Python version: 32-bit 3.8.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\r\n## Workaround\r\n\r\nAs a side note, tried on **version 3.3.4** and everything works. Does not work on 3.4.0. I'm calling \r\n\r\n```python\r\n        plt.close(\"all\")\r\n        plt.close()\r\n        gc.collect()\r\n```\r\nafter every `plt.savefig()` just to be sure.\r\n",
        "issue_id": 20490,
        "pr_number": 22935,
        "pr_title": "Backport PR #22002: Fix TkAgg memory leaks and test for memory growth regressions",
        "pr_body": "FIX: TkAgg memory leaks and test for memory growth regressions (#22002)\n\ntkinter variables get cleaned up with normal `destroy` and `gc` semantics but tkinter's implementation of trace is effectively global and keeps the callback object alive until the trace is removed.\n\nAdditionally extend and clean up the tests.\n\nCloses #20490\n\nCo-authored-by: Elliott Sales de Andrade <quantum.analyst@gmail.com>\n(cherry picked from commit 1a016f0395c3a8d87b632a47d813db2491863164)\n",
        "issue_closed_at": "2022-04-28T23:48:45Z",
        "base_commit": "a841f5f51473cb035e5c29fa7665da59bc4ed4d9"
      },
      "summary": "### Summary:\nThis issue is related to memory management problems in the Matplotlib library, specifically affecting versions 3.4.0 and 3.4.2. The problem manifests as various memory-related errors when running scripts that create and save a large number of figures. Users encounter inconsistent outcomes when executing the same script multiple times, with errors ranging from inability to allocate sufficient memory to TclError and MemoryError exceptions. The affected system components include memory allocation processes within Matplotlib, particularly involving the TkAgg backend and figure rendering functions. The severity of the issue is significant for users relying on these versions for generating numerous figures, as it results in script termination and unpredictable behavior. The problem does not occur in version 3.3.4, suggesting a regression in later versions. Technical details include the memory allocation failures in rendering figures and saving them using the TkAgg backend, highlighting the need for improved memory management in these versions. The fixed code elements in the patch involve modifications to functions responsible for figure destruction and subplot configuration within the Tk backend, aiming to address these memory leaks.",
      "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: Memory leaks on matplotlib 3.4.2 (and 3.4.0)\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\r\n**Bug summary**\r\n\r\nMultiple different memory related errors when running as a part of script creating and saving lots of figures.\r\n\r\n\r\n**Code for reproduction**\r\n\r\nSorry, could not create a minimal example that reproduces this. Just wanted to leave a note. \r\n\r\n\r\n\r\n**Actual outcome**\r\n\r\nThere are multiple different errors that happen. Running the same script will produce different results randomly.\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n**Example 1**\r\nJust prints this. No Exceptions, nothing. Script stops running.\r\n```\r\nunable to alloc 4320000 bytes\r\n```\r\n\r\n**Example 2** \r\n\r\n```python\r\n  File \"c:\\myapp\\calculations\\myscript.py\", line 422, in create_figure\r\n    fig, ax = plt.subplots(nrows=1, figsize=(16, 9))\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\_api\\deprecation.py\", line 471, in wrapper\r\n    return func(*args, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\pyplot.py\", line 1439, in subplots\r\n    fig = figure(**fig_kw)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\pyplot.py\", line 797, in figure\r\n    manager = new_figure_manager(\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\pyplot.py\", line 316, in new_figure_manager\r\n    return _backend_mod.new_figure_manager(*args, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backend_bases.py\", line 3545, in new_figure_manager\r\n    return cls.new_figure_manager_given_figure(num, fig)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\_backend_tk.py\", line 899, in new_figure_manager_given_figure\r\n    canvas = cls.FigureCanvas(figure, master=window)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\_api\\deprecation.py\", line 431, in wrapper\r\n    return func(*inner_args, **inner_kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\_backend_tk.py\", line 174, in __init__\r\n    self._tkphoto = tk.PhotoImage(\r\n  File \"C:\\Python\\Python 3.8.6-32\\lib\\tkinter\\__init__.py\", line 4061, in __init__\r\n    Image.__init__(self, 'photo', name, cnf, master, **kw)\r\n  File \"C:\\Python\\Python 3.8.6-32\\lib\\tkinter\\__init__.py\", line 4006, in __init__\r\n    self.tk.call(('image', 'create', imgtype, name,) + options)\r\n_tkinter.TclError: not enough free memory for image buffer\r\n```\r\n\r\n**Example 3**\r\n\r\n```python\r\n  File \"c:\\myapp\\calculations\\myscript.py\", line 467, in create_some_figures\r\n    plt.savefig(self.folder / \"myfig.png\")\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\pyplot.py\", line 966, in savefig\r\n    res = fig.savefig(*args, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\figure.py\", line 3005, in savefig\r\n    self.canvas.print_figure(fname, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backend_bases.py\", line 2255, in print_figure\r\n    result = print_method(\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backend_bases.py\", line 1669, in wrapper\r\n    return func(*args, **kwargs)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\backend_agg.py\", line 508, in print_png\r\n    FigureCanvasAgg.draw(self)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\backend_agg.py\", line 401, in draw\r\n    self.renderer = self.get_renderer(cleared=True)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\backend_agg.py\", line 417, in get_renderer\r\n    self.renderer = RendererAgg(w, h, self.figure.dpi)\r\n  File \"C:\\Python\\venvs\\adiapp\\lib\\site-packages\\matplotlib\\backends\\backend_agg.py\", line 91, in __init__\r\n    self._renderer = _RendererAgg(int(width), int(height), dpi)\r\nMemoryError: In RendererAgg: Out of memory\r\n```\r\n\r\n**Expected outcome**\r\n\r\n<!--A description of the expected outcome from the code snippet-->\r\n<!--If this used to work in an earlier version of Matplotlib, please note the version it used to work on-->\r\nNo errors. \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:  Windows 10\r\n  * Matplotlib version (`import matplotlib; print(matplotlib.__version__)`): 3.4.2\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg \r\n  * Python version: 32-bit 3.8.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\r\n## Workaround\r\n\r\nAs a side note, tried on **version 3.3.4** and everything works. Does not work on 3.4.0. I'm calling \r\n\r\n```python\r\n        plt.close(\"all\")\r\n        plt.close()\r\n        gc.collect()\r\n```\r\nafter every `plt.savefig()` just to be sure.\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/backends/_backend_tk.py\n  function: ConfigureSubplotsTk.__init__\n  function: ConfigureSubplotsTk.destroy\n"
    }
  ]
}