{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-24149",
    "repo": "matplotlib/matplotlib",
    "created_at": "2022-10-12T22:00:54Z",
    "problem_statement": "[Bug]: ax.bar raises for all-nan data on matplotlib 3.6.1 \n### Bug summary\n\n`ax.bar` raises an exception in 3.6.1 when passed only nan data. This irrevocably breaks seaborn's histogram function (which draws and then removes a \"phantom\" bar to trip the color cycle).\n\n### Code for reproduction\n\n```python\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\nf, ax = plt.subplots()\r\nax.bar([np.nan], [np.nan])\n```\n\n\n### Actual outcome\n\n```python-traceback\r\n---------------------------------------------------------------------------\r\nStopIteration                             Traceback (most recent call last)\r\nCell In [1], line 4\r\n      2 import matplotlib.pyplot as plt\r\n      3 f, ax = plt.subplots()\r\n----> 4 ax.bar([np.nan], [np.nan])[0].get_x()\r\n\r\nFile ~/miniconda/envs/py310/lib/python3.10/site-packages/matplotlib/__init__.py:1423, in _preprocess_data.<locals>.inner(ax, data, *args, **kwargs)\r\n   1420 @functools.wraps(func)\r\n   1421 def inner(ax, *args, data=None, **kwargs):\r\n   1422     if data is None:\r\n-> 1423         return func(ax, *map(sanitize_sequence, args), **kwargs)\r\n   1425     bound = new_sig.bind(ax, *args, **kwargs)\r\n   1426     auto_label = (bound.arguments.get(label_namer)\r\n   1427                   or bound.kwargs.get(label_namer))\r\n\r\nFile ~/miniconda/envs/py310/lib/python3.10/site-packages/matplotlib/axes/_axes.py:2373, in Axes.bar(self, x, height, width, bottom, align, **kwargs)\r\n   2371 x0 = x\r\n   2372 x = np.asarray(self.convert_xunits(x))\r\n-> 2373 width = self._convert_dx(width, x0, x, self.convert_xunits)\r\n   2374 if xerr is not None:\r\n   2375     xerr = self._convert_dx(xerr, x0, x, self.convert_xunits)\r\n\r\nFile ~/miniconda/envs/py310/lib/python3.10/site-packages/matplotlib/axes/_axes.py:2182, in Axes._convert_dx(dx, x0, xconv, convert)\r\n   2170 try:\r\n   2171     # attempt to add the width to x0; this works for\r\n   2172     # datetime+timedelta, for instance\r\n   (...)\r\n   2179     # removes the units from unit packages like `pint` that\r\n   2180     # wrap numpy arrays.\r\n   2181     try:\r\n-> 2182         x0 = cbook._safe_first_finite(x0)\r\n   2183     except (TypeError, IndexError, KeyError):\r\n   2184         pass\r\n\r\nFile ~/miniconda/envs/py310/lib/python3.10/site-packages/matplotlib/cbook/__init__.py:1749, in _safe_first_finite(obj, skip_nonfinite)\r\n   1746     raise RuntimeError(\"matplotlib does not \"\r\n   1747                        \"support generators as input\")\r\n   1748 else:\r\n-> 1749     return next(val for val in obj if safe_isfinite(val))\r\n\r\nStopIteration: \r\n```\n\n### Expected outcome\n\nOn 3.6.0 this returns a `BarCollection` with one Rectangle, having `nan` for `x` and `height`.\n\n### Additional information\n\nI assume it's related to this bullet in the release notes:\r\n\r\n- Fix barplot being empty when first element is NaN\r\n\r\nBut I don't know the context for it to investigate further (could these link to PRs?)\r\n\r\nFurther debugging:\r\n\r\n```python\r\nax.bar([np.nan], [0])  # Raises\r\nax.bar([0], [np.nan])  # Works\r\n```\r\n\r\nSo it's about the x position specifically.\n\n### Operating system\n\nMacos\n\n### Matplotlib Version\n\n3.6.1\n\n### Matplotlib Backend\n\n_No response_\n\n### Python version\n\n_No response_\n\n### Jupyter version\n\n_No response_\n\n### Installation\n\npip\n",
    "patch": "diff --git a/lib/matplotlib/axes/_axes.py b/lib/matplotlib/axes/_axes.py\n--- a/lib/matplotlib/axes/_axes.py\n+++ b/lib/matplotlib/axes/_axes.py\n@@ -2182,11 +2182,19 @@ def _convert_dx(dx, x0, xconv, convert):\n                 x0 = cbook._safe_first_finite(x0)\n             except (TypeError, IndexError, KeyError):\n                 pass\n+            except StopIteration:\n+                # this means we found no finite element, fall back to first\n+                # element unconditionally\n+                x0 = cbook.safe_first_element(x0)\n \n             try:\n                 x = cbook._safe_first_finite(xconv)\n             except (TypeError, IndexError, KeyError):\n                 x = xconv\n+            except StopIteration:\n+                # this means we found no finite element, fall back to first\n+                # element unconditionally\n+                x = cbook.safe_first_element(xconv)\n \n             delist = False\n             if not np.iterable(dx):\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_14011",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves argument conflicts in function calls, which is unrelated to handling NaN values in data processing."
      },
      {
        "idx": 2,
        "id": "similar_4537",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with inconsistent output due to parameter handling, not relevant to NaN data handling or exception management."
      },
      {
        "idx": 3,
        "id": "similar_17114",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about deprecation warnings and argument handling, which does not relate to NaN data processing or exception handling."
      },
      {
        "idx": 4,
        "id": "similar_12458",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves rendering inaccuracies, which is unrelated to handling NaN values or exception management in data processing."
      },
      {
        "idx": 5,
        "id": "similar_8046",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about rendering inaccuracies in arcs, which does not relate to handling NaN values or exception management."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "TypeError on plt.subplot(figure=plt.figure())",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\nWhen calling `plt.subplot` with a `figure` argument, we get:\r\n```\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\nThe argument 'figure' is specified in the [doc](https://matplotlib.org/api/_as_gen/matplotlib.pyplot.subplot.html)\r\n\r\nThe function `plt.subplot` uses `plt.gcf()` to get the current figure. It should check whether a figure was provided, eg. `fig = kwargs.pop('figure') if kwargs.get('figure') else plt.gcf()`\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nplt.subplot(figure=plt.figure())\r\n# OR EVEN\r\nplt.subplot(figure=None)\r\n```\r\n\r\n**Actual outcome**\r\n```                              \r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n<ipython-input-30-bdfa817205a7> in <module>\r\n----> 1 plt.subplot(figure=None)\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/pyplot.py in subplot(*args, **kwargs)\r\n   1082 \r\n   1083     fig = gcf()\r\n-> 1084     a = fig.add_subplot(*args, **kwargs)\r\n   1085     bbox = a.bbox\r\n   1086     byebye = []\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/figure.py in add_subplot(self, *args, **kwargs)\r\n   1347         else:\r\n   1348             projection_class, kwargs, key = process_projection_requirements(\r\n-> 1349                 self, *args, **kwargs)\r\n   1350 \r\n   1351             # try to find the axes with this key in the stack\r\n\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\n\r\n**Matplotlib version**\r\n  * Operating system: Linux\r\n  * Matplotlib version: 3.0.2 (with conda and with pip)\r\n  * Matplotlib backend: Qt5Agg\r\n  * Python version: tested on 3.7.2 and 3.5\r\n\r\n",
        "issue_id": 14011,
        "pr_number": 14014,
        "pr_title": "Disallow figure argument for pyplot.subplot() and Figure.add_subplot()",
        "pr_body": "## PR Summary\r\n\r\nCloses #14011.\r\n\r\n`Figure.add_subplot()` and `pyplot.subplot()` have technically accepted a `figure` keyword argument by allowing all keywords from the `Axes` constructor.\r\n\r\nIn this context, supplying a figure does not make sense since the axes should be bound to `self` or the current figure respecively.\r\n\r\nI'm daring to go without a deprecation since this anyway did only work so far if the user supplied the same figure that would have been used without the parameter. Please let me know if that's too bold and we should deprecate this first.",
        "issue_closed_at": "2019-05-28T22:25:29Z",
        "base_commit": "559925e3ec43a5cbe1697a4496482d38d8489f68"
      },
      "summary": "### Summary:\n\nThis issue involves a TypeError encountered when using the `plt.subplot` function from the Matplotlib library with a specific argument configuration. The error arises when the `figure` parameter is supplied explicitly to `plt.subplot`, which conflicts with an internal function call that also attempts to set the `figure` parameter. This results in the `process_projection_requirements` function receiving multiple values for the `figure` argument, leading to a TypeError. \n\nKey symptoms include the inability to create subplots when the `figure` argument is used explicitly, causing the program to halt with an error traceback. The issue affects the Matplotlib library, particularly the `subplot` function in `pyplot.py` and the `add_subplot` function in `figure.py`. The potential impact of this bug is significant for users who rely on explicit figure management when creating subplots, as it disrupts normal plotting workflows and may necessitate workarounds or code changes.\n\nThe problem is rooted in the way the current figure is determined and passed within the `subplot` function. Specifically, there is a need for a mechanism to correctly handle an explicitly provided figure, defaulting to the current figure only when none is supplied. This ensures that internal function calls do not conflict with user-specified arguments.",
      "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": "Confusion about the number of contour levels",
        "issue_body": "According to the docstring, `plt.contour(X, Y, Z, N)` should \"contour _N_ automatically-chosen levels\".\n\nThe actual results are somewhat surprising:\n\n``` python\nimport numpy as np\nimport matplotlib.pyplot as plt\n\nnp.random.seed(0)\nxx, yy = np.mgrid[-3:3:, -3:3]\n\nfor _ in xrange(10):\n    zz = np.random.randn(6, 6)\n    cset = plt.contour(xx, yy,  zz, 9)\n    print(len(cset.levels)),\n```\n\nprints `9 9 8 8 9 9 8 8 9 9`.\n\nAdditionally, the docstring for `plt.contourf` has the same prose, but adds some more confusing behavior:\n\n``` python\nfor _ in xrange(10):\n    zz = np.random.randn(6, 6)\n    cset = plt.contourf(xx, yy,  zz, 9)\n    print(len(cset.levels)),\n```\n\nprints `11 10 11 10 10 11 10 11 11 11` (note that the `N` is the same as for the `contour` call above).\n\nAm I missing something, or is this is a bug?\n",
        "issue_id": 4537,
        "pr_number": 4587,
        "pr_title": "DOC: clairify auto-level behavior",
        "pr_body": "closes #4537\n",
        "issue_closed_at": "2015-07-05T08:05:19Z",
        "base_commit": "aad1619a2ea8d9f2cd41dcee12a059623c744984"
      },
      "summary": "### Summary:\nThis issue pertains to the unexpected behavior of the contour plotting functions `plt.contour` and `plt.contourf` in Matplotlib, where the number of contour levels generated does not consistently match the specified parameter. The problem arises when users specify a certain number of contour levels, but the functions return varying numbers of levels across different runs, leading to user confusion and potential misinterpretation of data visualizations.\n\nKey symptoms and behaviors observed include the inconsistency in the number of contour levels generated by both `plt.contour` and `plt.contourf` functions, as demonstrated by the varying output lengths of contour levels across multiple iterations. This inconsistent behavior was noted when the parameter `N`, which is supposed to dictate the number of contour levels, did not produce a consistent number of levels as described in the function's docstring.\n\nThe affected components are the `plt.contour` and `plt.contourf` functions within the Matplotlib library, specifically in the `lib/matplotlib/contour.py` file, under the function `QuadContourSet._initialize_x_y`.\n\nThe potential impact of this issue is significant for users relying on these functions for accurate data visualization, as it could lead to incorrect interpretations of graphical data due to unexpected contour levels. This inconsistency can be particularly problematic in scientific and engineering fields where precise data representation is crucial.\n\nRelevant technical details include the observation that despite setting a fixed parameter for contour levels, the functions show variability in their output, suggesting a flaw in the level initialization logic of the contour plotting functions. The patch addresses this issue by ensuring the functions adhere to the specified number of contour levels, as documented.",
      "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: Confusion about the number of contour levels\n\nBody:\nAccording to the docstring, `plt.contour(X, Y, Z, N)` should \"contour _N_ automatically-chosen levels\".\n\nThe actual results are somewhat surprising:\n\n``` python\nimport numpy as np\nimport matplotlib.pyplot as plt\n\nnp.random.seed(0)\nxx, yy = np.mgrid[-3:3:, -3:3]\n\nfor _ in xrange(10):\n    zz = np.random.randn(6, 6)\n    cset = plt.contour(xx, yy,  zz, 9)\n    print(len(cset.levels)),\n```\n\nprints `9 9 8 8 9 9 8 8 9 9`.\n\nAdditionally, the docstring for `plt.contourf` has the same prose, but adds some more confusing behavior:\n\n``` python\nfor _ in xrange(10):\n    zz = np.random.randn(6, 6)\n    cset = plt.contourf(xx, yy,  zz, 9)\n    print(len(cset.levels)),\n```\n\nprints `11 10 11 10 10 11 10 11 11 11` (note that the `N` is the same as for the `contour` call above).\n\nAm I missing something, or is this is a bug?\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/contour.py\n  function: QuadContourSet._initialize_x_y\n"
    },
    {
      "similar_issue": {
        "issue_title": "`add_axes` shows deprecation warning when called with only `kwarg`s",
        "issue_body": "<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nCalling `add_axes` without args is deprecated. However, if a kwarg is passed, the deprecation warning still shows.\r\n\r\n\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug.\r\nPlease make sure to minimize the number of dependencies required, and provide\r\nany necessary plotted data.\r\nAvoid using threads, as Matplotlib is (explicitly) not thread-safe.-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nfig = plt.figure()\r\nax = fig.add_axes(rect=[0, 0, 1, 1])\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n<ipython-input-128-1ef4234f1c1f>:3: MatplotlibDeprecationWarning: Calling add_axes() without argument is deprecated. You may want to use add_subplot() instead.\r\n  ax = fig.add_axes(rect=[0, 0, 1, 1])\r\n```\r\n\r\n**Expected outcome**\r\n\r\n<!--A description of the expected outcome from the code snippet-->\r\n<!--If this used to work in an earlier version of Matplotlib, please note the version it used to work on-->\r\n\r\nNo warning should be shown.\r\n\r\n**Discussion**\r\n\r\n`figure.add_axes` currently starts with\r\n\r\n```\r\n        if not len(args):\r\n            cbook.warn_deprecated(\r\n                \"3.3\",\r\n                message=\"Calling add_axes() without argument is \"\r\n                \"deprecated. You may want to use add_subplot() \"\r\n                \"instead.\")\r\n            return\r\n```\r\n\r\nBecause the function forwards `kwargs`, the intended behavior is a bit ambiguous to me, but I'm assuming from the docstring that the intention is to force the user to pass `rect` specifically? \r\n\r\n```\r\nif not len(args) and 'rect' not in kwargs:\r\n    ...\r\n```\r\n\r\nI can make this a PR if necessary, but if I'm not sure if we continue to update 3.2...And I don't know what the deprecation schedule even looks like for removing the \"ability to use no args\", so I don't know if this will even be an issue after 3.3....just wanted to point it out.\r\n\r\nFeel free to close if this is a non-issue.",
        "issue_id": 17114,
        "pr_number": 17142,
        "pr_title": "BUGFIX: conditional for add_axes arg deprecation",
        "pr_body": "## PR Summary\r\n\r\nFixes #17114.\r\n\r\n## PR Checklist\r\n\r\n- [ ] Has Pytest style unit tests\r\n- [ ] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/api_changes.rst if API changed in a backward-incompatible way\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Do not create the PR out of master, but out of a separate branch.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->\r\n",
        "issue_closed_at": "2020-04-15T08:44:02Z",
        "base_commit": "e55e79b97d0b3ff772a4f7aaa0fb15193d84300c"
      },
      "summary": "### Summary:\n\nThis issue is related to a deprecation warning in the `matplotlib` library when using the `add_axes` method of the `Figure` class. The problem arises when this method is called using only keyword arguments (kwargs), specifically the `rect` argument, without any positional arguments. Despite providing the necessary `kwargs`, a deprecation warning is still generated, indicating that calling `add_axes` without any arguments is deprecated, and suggesting the use of `add_subplot` instead.\n\nKey symptoms and behaviors include the generation of a deprecation warning even when the function is used with the intended keyword argument. This creates confusion for users, as they receive a warning despite following what appears to be the correct usage pattern according to the method's documentation.\n\nThe affected component is the `add_axes` function within the `Figure` class in the `matplotlib` library. The severity of the issue is relatively low, as it does not prevent functionality but may cause unnecessary concern or confusion for users who are adhering to the documented usage.\n\nThe technical detail involves the current implementation of `add_axes`, which checks for the absence of positional arguments and immediately triggers a deprecation warning without considering if the necessary keyword argument `rect` is supplied. The proposed resolution suggests modifying the function's logic to check for the presence of a `rect` keyword argument before issuing a deprecation warning, thus aligning the behavior with user expectations and documentation.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: `add_axes` shows deprecation warning when called with only `kwarg`s\n\nBody:\n<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nCalling `add_axes` without args is deprecated. However, if a kwarg is passed, the deprecation warning still shows.\r\n\r\n\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug.\r\nPlease make sure to minimize the number of dependencies required, and provide\r\nany necessary plotted data.\r\nAvoid using threads, as Matplotlib is (explicitly) not thread-safe.-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nfig = plt.figure()\r\nax = fig.add_axes(rect=[0, 0, 1, 1])\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n<ipython-input-128-1ef4234f1c1f>:3: MatplotlibDeprecationWarning: Calling add_axes() without argument is deprecated. You may want to use add_subplot() instead.\r\n  ax = fig.add_axes(rect=[0, 0, 1, 1])\r\n```\r\n\r\n**Expected outcome**\r\n\r\n<!--A description of the expected outcome from the code snippet-->\r\n<!--If this used to work in an earlier version of Matplotlib, please note the version it used to work on-->\r\n\r\nNo warning should be shown.\r\n\r\n**Discussion**\r\n\r\n`figure.add_axes` currently starts with\r\n\r\n```\r\n        if not len(args):\r\n            cbook.warn_deprecated(\r\n                \"3.3\",\r\n                message=\"Calling add_axes() without argument is \"\r\n                \"deprecated. You may want to use add_subplot() \"\r\n                \"instead.\")\r\n            return\r\n```\r\n\r\nBecause the function forwards `kwargs`, the intended behavior is a bit ambiguous to me, but I'm assuming from the docstring that the intention is to force the user to pass `rect` specifically? \r\n\r\n```\r\nif not len(args) and 'rect' not in kwargs:\r\n    ...\r\n```\r\n\r\nI can make this a PR if necessary, but if I'm not sure if we continue to update 3.2...And I don't know what the deprecation schedule even looks like for removing the \"ability to use no args\", so I don't know if this will even be an issue after 3.3....just wanted to point it out.\r\n\r\nFeel free to close if this is a non-issue.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/figure.py\n  function: Figure.add_axes\n"
    },
    {
      "similar_issue": {
        "issue_title": "add_lines misses lines for matplotlib.colorbar.ColorbarBase",
        "issue_body": "<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nFor matplotlib.colorbar.ColorbarBase(...) usage of add_lines(...) may yield missing lines/poorly adjusted lines.\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport matplotlib as mpl\r\nimport numpy as np\r\n\r\nfig = plt.figure()\r\nax = fig.add_axes([0.05, 0.8, 0.9, 0.15])\r\ncmap = mpl.cm.cool\r\nnorm = mpl.colors.Normalize(vmin=-4, vmax=4)\r\nlevels = (-1.0, 1.0, 2.0, 3.0)\r\n\r\ncb = mpl.colorbar.ColorbarBase(ax, cmap=cmap, norm=norm)\r\ncolors_bg = np.tile(list((1.0, 1.0, 1.0, 1.0)), (len(levels), 1))\r\ncb.add_lines(levels=levels, colors=colors_bg, linewidths=7)\r\n\r\nplt.show()\r\n\r\n\r\n```\r\n\r\n**Expected outcome**\r\n\r\n4 white lines, crossing the colorbar.\r\nUsed to work on matplotlib 2.2.3!\r\n\r\n**Matplotlib version**\r\n  * Operating system: Ubuntu 18.04 LTS\r\n  * Matplotlib version: 3.0.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.0\r\n\r\nMiniconda install, fully updated.",
        "issue_id": 12458,
        "pr_number": 12461,
        "pr_title": "FIX: make add_lines work with new colorbar",
        "pr_body": "## PR Summary\r\n\r\nCloses #12458\r\n\r\nSee below for a less pathological example...\r\n\r\n`cbar.add_lines` was not operational after new colorbar changes in 3.0.0.  \r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport matplotlib as mpl\r\nimport numpy as np\r\n\r\nfig = plt.figure()\r\nax = fig.add_axes([0.05, 0.8, 0.9, 0.15])\r\ncmap = mpl.cm.cool\r\nnorm = mpl.colors.Normalize(vmin=-4, vmax=4)\r\nlevels = (-1.0, 1.0, 2.0, 3.0)\r\n\r\ncb = mpl.colorbar.ColorbarBase(ax, cmap=cmap, norm=norm)\r\ncolors_bg = np.tile(list((1.0, 1.0, 1.0, 1.0)), (len(levels), 1))\r\ncb.add_lines(levels=levels, colors=colors_bg, linewidths=1)\r\n\r\n```\r\n\r\n## Before\r\n![cbarold](https://user-images.githubusercontent.com/1562854/46681303-ce871d00-cb9f-11e8-8acd-e5defedfe90c.png)\r\n\r\n\r\n## After\r\n\r\n![cbarnew](https://user-images.githubusercontent.com/1562854/46681265-b3b4a880-cb9f-11e8-8efd-87b24d565751.png)\r\n\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\nfig, ax = plt.subplots()\r\nX = np.random.rand(10, 10)*10000\r\npcm = ax.pcolormesh(X)\r\n# add 1000 to make colors visible...\r\ncont = ax.contour(X+1000)\r\ncb = fig.colorbar(pcm)\r\ncb.add_lines(cont)\r\nplt.show()\r\n```\r\n\r\n## Before\r\n\r\n![before](https://user-images.githubusercontent.com/1562854/46701766-b4683180-cbd5-11e8-8c18-d994ba47e396.png)\r\n\r\n## After\r\n![new](https://user-images.githubusercontent.com/1562854/46701741-9d294400-cbd5-11e8-9006-708b7ef51fdc.png)\r\n\r\n\r\n## PR Checklist\r\n\r\n- [ ] Has Pytest style unit tests\r\n- [ ] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/api_changes.rst if API changed in a backward-incompatible way\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Do not create the PR out of master, but out of a separate branch.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->",
        "issue_closed_at": "2018-10-14T19:38:43Z",
        "base_commit": "f93222a555160bf967f02dae42cce39a03384774"
      },
      "summary": "### Summary:\nThis issue pertains to the `add_lines` method of the `matplotlib.colorbar.ColorbarBase` class, where the function fails to render lines or produces lines that are incorrectly aligned when used. This problem was identified after upgrading from Matplotlib version 2.2.3 to 3.0.0, where the feature previously worked as expected. The bug manifests as missing or poorly adjusted lines across a colorbar, which impacts the visual representation and accuracy of plotted data. The problem affects users operating on systems like Ubuntu 18.04 LTS using Python 3.7.0 and the Qt5Agg backend. The key technical detail is that the issue resides in the `Colorbar.add_lines` function, which is responsible for adding lines to a colorbar to indicate specific levels or thresholds. The severity of this issue is moderate, as it affects the graphical output accuracy but does not lead to system crashes or data loss. However, it can hinder the interpretation of data visualizations, especially in scientific and engineering applications where precise graphical representations are crucial.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: add_lines misses lines for matplotlib.colorbar.ColorbarBase\n\nBody:\n<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nFor matplotlib.colorbar.ColorbarBase(...) usage of add_lines(...) may yield missing lines/poorly adjusted lines.\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport matplotlib as mpl\r\nimport numpy as np\r\n\r\nfig = plt.figure()\r\nax = fig.add_axes([0.05, 0.8, 0.9, 0.15])\r\ncmap = mpl.cm.cool\r\nnorm = mpl.colors.Normalize(vmin=-4, vmax=4)\r\nlevels = (-1.0, 1.0, 2.0, 3.0)\r\n\r\ncb = mpl.colorbar.ColorbarBase(ax, cmap=cmap, norm=norm)\r\ncolors_bg = np.tile(list((1.0, 1.0, 1.0, 1.0)), (len(levels), 1))\r\ncb.add_lines(levels=levels, colors=colors_bg, linewidths=7)\r\n\r\nplt.show()\r\n\r\n\r\n```\r\n\r\n**Expected outcome**\r\n\r\n4 white lines, crossing the colorbar.\r\nUsed to work on matplotlib 2.2.3!\r\n\r\n**Matplotlib version**\r\n  * Operating system: Ubuntu 18.04 LTS\r\n  * Matplotlib version: 3.0.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.0\r\n\r\nMiniconda install, fully updated.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/colorbar.py\n  function: Colorbar.add_lines\n"
    },
    {
      "similar_issue": {
        "issue_title": "Arc patch with starting and ending angle",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\n\r\n- Arc patch does not behave as expected when drawing elliptical arcs between two angles specified by theta1 and theta2.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport matplotlib.pyplot as plt\r\nfrom matplotlib.patches import Arc\r\n\r\n# Ellipse parameters\r\nR = 1.0\r\nx, y = 0.0, 0.0\r\na, b = 2.0*R, R\r\n\r\n# Figure setup\r\nfig_width, fig_height = 3.30, 3.30\r\nfig = plt.figure(figsize=(fig_width, fig_height), frameon=False)\r\nax = fig.add_axes([0.0, 0.0, 1.0, 1.0], aspect='equal')\r\nax.set_axis_off()\r\nax.set_xlim(-R*1.05, R*1.05)\r\nax.set_ylim(-R*1.05, R*1.05)\r\n# Axes\r\nax.axhline(0.0)\r\nax.axvline(0.0)\r\n# 45 degree line\r\nax.plot([0.0, 1.0], [0.0, 1.0], 'k--')\r\n# Arcs\r\nax.add_patch(Arc((x, y), a, b, \r\n                 theta1=0.0, theta2=360.0, edgecolor='k'))\r\nax.add_patch(Arc((x, y), a, b,\r\n                 theta1=0.0, theta2=45.0, edgecolor='r', lw=1.5))\r\nfig.savefig('Arc_patch_bug.png')\r\n```\r\n\r\n**Actual outcome**\r\n\r\n![arc_patch_bug](https://cloud.githubusercontent.com/assets/20580126/22736007/3d8cc2bc-edf4-11e6-85ef-3e042599b626.png)\r\n\r\n**Expected outcome**\r\n\r\n- Red elliptical arc between the x-axis (0 degrees) and the dashed line (45 degrees), following the black ellipse.\r\n\r\n**Matplotlib version**\r\n\r\n- Matplotlib 2.0.0, Python 2.7.13, OSX\r\n- Installed with MacPorts\r\n\r\n",
        "issue_id": 8046,
        "pr_number": 8047,
        "pr_title": "Correct theta values when drawing a non-circular arc",
        "pr_body": "Fixes #8046. I'm not sure if this is the right place to do the correction, so a second opinion would be good. I've checked this works with a full range of angles.",
        "issue_closed_at": "2017-03-10T23:28:10Z",
        "base_commit": "1f173ddfdbe44a978df7126c606588a0fc75fbd9"
      },
      "summary": "### Summary:\nThis issue is related to the 'Arc' patch component within the Matplotlib library, specifically when rendering elliptical arcs. The problem arises when drawing arcs between two specified angles, theta1 and theta2, which do not produce the expected visual outcome. The red arc intended to appear between the 0-degree x-axis and a 45-degree line deviates from its expected path along the black ellipse.\n\nKey symptoms include incorrect rendering of elliptical arcs, particularly noticeable in the discrepancy between the expected and actual graphical output. This issue affects users employing the 'Arc' patch functionality for visualizations requiring precise angle-based rendering.\n\nThe affected components are primarily within the Matplotlib library's patches module, specifically in the functions responsible for initializing and drawing connection patches and calculating intersections of circular paths with line segments.\n\nThe potential impact of this issue is significant for users relying on accurate graphical representations of data, as it could lead to misleading interpretations of visualizations. This is particularly critical in fields where precise graphical depiction is necessary for data analysis and decision-making.\n\nRelevant technical details include the modification of code elements in 'lib/matplotlib/patches.py', specifically the functions 'ConnectionPatch.__init__', 'ConnectionPatch.draw', and 'Arc.iter_circle_intersect_on_line_seg', which were adjusted to address the rendering inaccuracies. This indicates a need for improvements in the logic governing arc rendering and intersection calculations.",
      "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: Arc patch with starting and ending angle\n\nBody:\n### Bug report\r\n\r\n**Bug summary**\r\n\r\n- Arc patch does not behave as expected when drawing elliptical arcs between two angles specified by theta1 and theta2.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport matplotlib.pyplot as plt\r\nfrom matplotlib.patches import Arc\r\n\r\n# Ellipse parameters\r\nR = 1.0\r\nx, y = 0.0, 0.0\r\na, b = 2.0*R, R\r\n\r\n# Figure setup\r\nfig_width, fig_height = 3.30, 3.30\r\nfig = plt.figure(figsize=(fig_width, fig_height), frameon=False)\r\nax = fig.add_axes([0.0, 0.0, 1.0, 1.0], aspect='equal')\r\nax.set_axis_off()\r\nax.set_xlim(-R*1.05, R*1.05)\r\nax.set_ylim(-R*1.05, R*1.05)\r\n# Axes\r\nax.axhline(0.0)\r\nax.axvline(0.0)\r\n# 45 degree line\r\nax.plot([0.0, 1.0], [0.0, 1.0], 'k--')\r\n# Arcs\r\nax.add_patch(Arc((x, y), a, b, \r\n                 theta1=0.0, theta2=360.0, edgecolor='k'))\r\nax.add_patch(Arc((x, y), a, b,\r\n                 theta1=0.0, theta2=45.0, edgecolor='r', lw=1.5))\r\nfig.savefig('Arc_patch_bug.png')\r\n```\r\n\r\n**Actual outcome**\r\n\r\n![arc_patch_bug](https://cloud.githubusercontent.com/assets/20580126/22736007/3d8cc2bc-edf4-11e6-85ef-3e042599b626.png)\r\n\r\n**Expected outcome**\r\n\r\n- Red elliptical arc between the x-axis (0 degrees) and the dashed line (45 degrees), following the black ellipse.\r\n\r\n**Matplotlib version**\r\n\r\n- Matplotlib 2.0.0, Python 2.7.13, OSX\r\n- Installed with MacPorts\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/patches.py\n  function: ConnectionPatch.__init__\n  function: ConnectionPatch.draw\n  function: Arc.iter_circle_intersect_on_line_seg\n"
    }
  ]
}