{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-23563",
    "repo": "matplotlib/matplotlib",
    "created_at": "2022-08-05T15:52:55Z",
    "problem_statement": "[Bug]: 'Line3D' object has no attribute '_verts3d'\n### Bug summary\n\nI use matplotlib 3D to visualize some lines in 3D. When I first run the following code, the code can run right. But, if I give `x_s_0[n]` a numpy array, it will report the error 'input operand has more dimensions than allowed by the axis remapping'. The point is when next I give  `x_s_0[n]` and other variables an int number, the AttributeError: 'Line3D' object has no attribute '_verts3d' will appear and can not be fixed whatever I change the variables or delete them. The error can be only fixed when I restart the kernel of ipython console. I don't know why it happens, so I come here for help.\n\n### Code for reproduction\n\n```python\nx_s_0 = np.array(['my int number list'])\r\nx_e_0 = np.array(['my int number list'])\r\ny_s_0 = np.array(['my int number list'])\r\ny_e_0 = np.array(['my int number list'])\r\nz_s_0 = np.array(['my int number list'])\r\nz_e_0 = np.array(['my int number list'])\r\n\r\nfig = plt.figure()\r\n        ax = fig.gca(projection='3d')\r\n        ax.view_init(elev=90, azim=0)\r\n        ax.set_zlim3d(-10, 10)\r\n        clr_list = 'r-'\r\n\r\n        for n in range(np.size(z_s_0, axis=0)):\r\n            ax.plot([int(x_s_0[n]), int(x_e_0[n])],\r\n                    [int(y_s_0[n]), int(y_e_0[n])],\r\n                    [int(z_s_0[n]), int(z_e_0[n])], clr_list)\r\n\r\n        plt.xlabel('x')\r\n        plt.ylabel('y')\r\n        # ax.zlabel('z')\r\n        plt.title('90-0')\r\n        plt.show()\n```\n\n\n### Actual outcome\n\nTraceback (most recent call last):\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/IPython/core/interactiveshell.py\", line 3444, in run_code\r\n    exec(code_obj, self.user_global_ns, self.user_ns)\r\n  File \"<ipython-input-80-e04907066a16>\", line 20, in <module>\r\n    plt.show()\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/pyplot.py\", line 368, in show\r\n    return _backend_mod.show(*args, **kwargs)\r\n  File \"/home/hanyaning/.pycharm_helpers/pycharm_matplotlib_backend/backend_interagg.py\", line 29, in __call__\r\n    manager.show(**kwargs)\r\n  File \"/home/hanyaning/.pycharm_helpers/pycharm_matplotlib_backend/backend_interagg.py\", line 112, in show\r\n    self.canvas.show()\r\n  File \"/home/hanyaning/.pycharm_helpers/pycharm_matplotlib_backend/backend_interagg.py\", line 68, in show\r\n    FigureCanvasAgg.draw(self)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/backends/backend_agg.py\", line 436, in draw\r\n    self.figure.draw(self.renderer)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/artist.py\", line 73, in draw_wrapper\r\n    result = draw(artist, renderer, *args, **kwargs)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/artist.py\", line 50, in draw_wrapper\r\n    return draw(artist, renderer)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/figure.py\", line 2803, in draw\r\n    mimage._draw_list_compositing_images(\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/image.py\", line 132, in _draw_list_compositing_images\r\n    a.draw(renderer)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/artist.py\", line 50, in draw_wrapper\r\n    return draw(artist, renderer)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/mpl_toolkits/mplot3d/axes3d.py\", line 469, in draw\r\n    super().draw(renderer)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/artist.py\", line 50, in draw_wrapper\r\n    return draw(artist, renderer)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/axes/_base.py\", line 3082, in draw\r\n    mimage._draw_list_compositing_images(\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/image.py\", line 132, in _draw_list_compositing_images\r\n    a.draw(renderer)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/matplotlib/artist.py\", line 50, in draw_wrapper\r\n    return draw(artist, renderer)\r\n  File \"/home/hanyaning/anaconda3/envs/SBeA/lib/python3.8/site-packages/mpl_toolkits/mplot3d/art3d.py\", line 215, in draw\r\n    xs3d, ys3d, zs3d = self._verts3d\r\nAttributeError: 'Line3D' object has no attribute '_verts3d'\n\n### Expected outcome\n\nSome 3D lines\n\n### Additional information\n\n_No response_\n\n### Operating system\n\nLocal: windows + pycharm, Remote: Ubuntu 20.04\n\n### Matplotlib Version\n\n3.5.0\n\n### Matplotlib Backend\n\nmodule://backend_interagg\n\n### Python version\n\n3.8.12\n\n### Jupyter version\n\n_No response_\n\n### Installation\n\npip\n",
    "patch": "diff --git a/lib/mpl_toolkits/mplot3d/art3d.py b/lib/mpl_toolkits/mplot3d/art3d.py\n--- a/lib/mpl_toolkits/mplot3d/art3d.py\n+++ b/lib/mpl_toolkits/mplot3d/art3d.py\n@@ -171,6 +171,7 @@ def __init__(self, xs, ys, zs, *args, **kwargs):\n     def set_3d_properties(self, zs=0, zdir='z'):\n         xs = self.get_xdata()\n         ys = self.get_ydata()\n+        zs = cbook._to_unmasked_float_array(zs).ravel()\n         zs = np.broadcast_to(zs, len(xs))\n         self._verts3d = juggle_axes(xs, ys, zs, zdir)\n         self.stale = True\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_9380",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about a missing class definition in a backend, unrelated to attribute errors or state persistence."
      },
      {
        "idx": 2,
        "id": "similar_12458",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves rendering problems with a specific function, not related to attribute errors or state persistence."
      },
      {
        "idx": 3,
        "id": "similar_15730",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about unintended style inheritance, not related to attribute errors or state persistence."
      },
      {
        "idx": 4,
        "id": "similar_9829",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about rendering discrepancies between formats, not related to attribute errors or state persistence."
      },
      {
        "idx": 5,
        "id": "similar_19223",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves type errors due to unhashable parameters, unrelated to attribute errors or state persistence."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Cannot import pyplot. NameError:  'FigureManagerWebAgg' is not defined",
        "issue_body": "\r\n### Bug report\r\n\r\nWhen using the webagg backend on 2.1.0, importing pyplot fails with a NameError.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport matplotlib\r\nmatplotlib.use('WebAgg')\r\nfrom matplotlib import pyplot\r\n```\r\n\r\n**Actual outcome**\r\n\r\nI get a name error. traceback excerpt:\r\n```\r\n.../python3.6/site-packages/matplotlib/backends/__init__.py in pylab_setup(name)\r\n     58     # imports. 0 means only perform absolute imports.\r\n     59     backend_mod = __import__(backend_name, globals(), locals(),\r\n---> 60                              [backend_name], 0)\r\n     61 \r\n     62     # Things we pull in from all backends\r\n\r\n.../python3.6/site-packages/matplotlib/backends/backend_webagg.py in <module>()\r\n    325 \r\n    326 @_Backend.export\r\n--> 327 class _BackendWebAgg(_Backend):\r\n    328     FigureCanvas = FigureCanvasWebAgg\r\n    329     FigureManager = FigureManagerWebAgg\r\n\r\n.../python3.6/site-packages/matplotlib/backends/backend_webagg.py in _BackendWebAgg()\r\n    327 class _BackendWebAgg(_Backend):\r\n    328     FigureCanvas = FigureCanvasWebAgg\r\n--> 329     FigureManager = FigureManagerWebAgg\r\n    330 \r\n    331     @staticmethod\r\n\r\nNameError: name 'FigureManagerWebAgg' is not defined\r\n```\r\n\r\n\r\n**Matplotlib version**\r\n  * Operating system:  Mac OS 10.12.6\r\n  * Matplotlib version: 2.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): WebAgg\r\n  * Python version: Python 3.6.2 \r\n  * Jupyter version (if applicable): -\r\n  * Other libraries: \r\n\r\n\r\nI installed matplotlib via pip.\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": 9380,
        "pr_number": 9534,
        "pr_title": "Fix webagg",
        "pr_body": "Adjust where the various js files are stored.\r\n\r\nFixes #9380.",
        "issue_closed_at": "2017-11-01T18:25:59Z",
        "base_commit": "473409e2ddea7ccacb4823ff4cfbf19759cf987a"
      },
      "summary": "### Summary:\nThis issue is a bug related to the matplotlib library, specifically when attempting to use the 'WebAgg' backend in version 2.1.0. The problem arises when importing the 'pyplot' module, resulting in a NameError due to the 'FigureManagerWebAgg' class not being defined. This issue manifests when the backend attempts to set up the necessary components for rendering figures in a web application using the WebAgg backend, but it fails because a key class reference is missing. The affected components include the WebAgg backend of matplotlib, which is used for rendering visualizations in web applications. The potential impact is significant for users relying on the WebAgg backend for their visualizations, as it prevents them from importing and using the pyplot module, thus disrupting workflows that depend on this functionality. The issue highlights a missing definition in the backend module, pointing to a need for proper class definition and import handling within the backend system of matplotlib. The fixed code elements suggest that the solution involved adjustments in the backend modules, specifically in the functions responsible for handling JavaScript in the backend_nbagg and backend_webagg_core modules, ensuring that the necessary class definitions are present and correctly implemented.",
      "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: Cannot import pyplot. NameError:  'FigureManagerWebAgg' is not defined\n\nBody:\n\r\n### Bug report\r\n\r\nWhen using the webagg backend on 2.1.0, importing pyplot fails with a NameError.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport matplotlib\r\nmatplotlib.use('WebAgg')\r\nfrom matplotlib import pyplot\r\n```\r\n\r\n**Actual outcome**\r\n\r\nI get a name error. traceback excerpt:\r\n```\r\n.../python3.6/site-packages/matplotlib/backends/__init__.py in pylab_setup(name)\r\n     58     # imports. 0 means only perform absolute imports.\r\n     59     backend_mod = __import__(backend_name, globals(), locals(),\r\n---> 60                              [backend_name], 0)\r\n     61 \r\n     62     # Things we pull in from all backends\r\n\r\n.../python3.6/site-packages/matplotlib/backends/backend_webagg.py in <module>()\r\n    325 \r\n    326 @_Backend.export\r\n--> 327 class _BackendWebAgg(_Backend):\r\n    328     FigureCanvas = FigureCanvasWebAgg\r\n    329     FigureManager = FigureManagerWebAgg\r\n\r\n.../python3.6/site-packages/matplotlib/backends/backend_webagg.py in _BackendWebAgg()\r\n    327 class _BackendWebAgg(_Backend):\r\n    328     FigureCanvas = FigureCanvasWebAgg\r\n--> 329     FigureManager = FigureManagerWebAgg\r\n    330 \r\n    331     @staticmethod\r\n\r\nNameError: name 'FigureManagerWebAgg' is not defined\r\n```\r\n\r\n\r\n**Matplotlib version**\r\n  * Operating system:  Mac OS 10.12.6\r\n  * Matplotlib version: 2.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): WebAgg\r\n  * Python version: Python 3.6.2 \r\n  * Jupyter version (if applicable): -\r\n  * Other libraries: \r\n\r\n\r\nI installed matplotlib via pip.\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/backends/backend_nbagg.py\n  function: FigureManagerNbAgg.get_javascript\n\nlib/matplotlib/backends/backend_webagg_core.py\n  function: FigureManagerWebAgg.get_javascript\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 a defect in the `matplotlib` library, specifically within the `ColorbarBase` class of the `colorbar` module, where the function `add_lines` fails to correctly render lines over a color bar. This defect results in missing or poorly adjusted lines when the `add_lines` method is used with specific parameters. The problem is observed with a particular configuration involving custom levels and background colors, which previously functioned correctly in an older version of the library (2.2.3) but exhibits issues in version 3.0.0. The issue is noticeable when running on an Ubuntu 18.04 LTS system using Python 3.7.0 and is particularly tied to the rendering backend specified as `Qt5Agg`. The impact of this issue is significant for users relying on the visual accuracy of plot annotations, particularly when these lines serve a critical role in data interpretation or presentation. The necessary fix involves modifications to the `Colorbar.add_lines` function within the `colorbar.py` file to ensure proper line rendering as expected in previous library versions.",
      "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": "Setting lines.marker = s in matplotlibrc also sets markers in boxplots",
        "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\nSetting this line\r\n    lines.marker      : s    ## the default marker\r\nin the matplotlibrc leads to an unexpected result:\r\n\r\n```\r\n%pylab inline\r\nboxplot(range(100))\r\n\r\n```\r\n\r\n![fig](https://user-images.githubusercontent.com/3391614/69190942-b0982580-0ade-11ea-903e-8f59e3f5e70d.jpg)\r\n",
        "issue_id": 15730,
        "pr_number": 15798,
        "pr_title": "Better default behavior for boxplots when rcParams['lines.marker'] is set",
        "pr_body": "## PR Summary\r\ncloses #15730\r\navoid using rcParams['lines.marker'] for boxplots.\r\n\r\n**Code snippet for reproducing the issue:**\r\n```\r\nplt.rcParams['lines.marker'] = 's'\r\nplt.boxplot(range(100))\r\n```\r\n**Before this PR:**\r\n![test](https://user-images.githubusercontent.com/15175620/69918581-ee337180-1441-11ea-9937-dfe8c5005946.png)\r\n\r\n**After this PR:**\r\n![test1](https://user-images.githubusercontent.com/15175620/69918585-f4295280-1441-11ea-9e35-bfc4b07c07d8.png)\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": "2019-12-30T18:06:35Z",
        "base_commit": "22ac46006fa8ea9dfb5b37941ffa7980f0447d8a"
      },
      "summary": "### Summary:\n\nThis issue is related to unexpected behavior in the Matplotlib library when configuring default plot settings through the `matplotlibrc` configuration file. Specifically, setting the `lines.marker` attribute to a specific marker style (e.g., 's' for square markers) inadvertently affects the appearance of boxplots, causing them to display with markers, which is not the intended or typical behavior.\n\nKey symptoms include the appearance of markers on boxplots when the `lines.marker` setting is specified. This issue likely arises because the boxplot rendering function in Matplotlib unintentionally inherits the global marker style from the `matplotlibrc` file, which is meant for line plots rather than boxplots.\n\nThe affected components include the `boxplot` function within the Matplotlib library, particularly the `Axes.bxp` and `Axes.line_props_with_rcdefaults` functions, which are responsible for rendering boxplot elements and inheriting default style properties.\n\nThe potential impact of this issue is moderate. While it does not prevent the creation of boxplots, it leads to visual inconsistencies and can confuse users who rely on default settings for plot appearances. This may affect data visualization accuracy and readability.\n\nRelevant technical details abstracted for a broader understanding include the configuration of global plot settings via `matplotlibrc` and the inheritance of these settings by different plot types within the library. The resolution involves ensuring that boxplot rendering logic does not inadvertently apply marker styles intended for line plots.",
      "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: Setting lines.marker = s in matplotlibrc also sets markers in boxplots\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\nSetting this line\r\n    lines.marker      : s    ## the default marker\r\nin the matplotlibrc leads to an unexpected result:\r\n\r\n```\r\n%pylab inline\r\nboxplot(range(100))\r\n\r\n```\r\n\r\n![fig](https://user-images.githubusercontent.com/3391614/69190942-b0982580-0ade-11ea-903e-8f59e3f5e70d.jpg)\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.bxp\n  function: Axes.line_props_with_rcdefaults\n"
    },
    {
      "similar_issue": {
        "issue_title": "Vertices clipped for certain markers when plotting more than two points and saving as pdf",
        "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\nThe vertices on certain markers ('^', 'D', 'v') are clipped when using `plot()` to plot data with more than two points and saving the plot as a PDF.\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\nsize = 256, 16\r\nfig,ax = plt.subplots()\r\nnum = 3\r\n\r\nfig,ax = plt.subplots()\r\nax.plot([i+1 for i in range(num)],[1 for i in range(num)], '^', markersize=3, markeredgewidth=0.7, color='green', markeredgecolor='black')\r\nax.set_xlim(0, num +1)\r\nax.set_xticks(())\r\nax.set_yticks(())\r\nfig.savefig('test.pdf') # This doesn't work properly.\r\nfig.savefig('test.svg')\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![pdfmarker](https://user-images.githubusercontent.com/8723338/33104959-e7cacfd6-cef8-11e7-880a-0e8aa8643454.png)\r\n![svgmarker](https://user-images.githubusercontent.com/8723338/33104963-ea6f906e-cef8-11e7-8742-ce5b2421c337.png)\r\n\r\nThe top image is of the marker from the .pdf file. The bottom image is of the marker from the .svg file.\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\nThe marker in the .pdf file should look like the marker in the .svg file.\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 17.04\r\n  * Matplotlib version: 2.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: Python 3.5.3\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: \r\n\r\nI installed matplotlib via pip.\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": 9829,
        "pr_number": 17163,
        "pr_title": "Fix clipping of markers in PDF backend.",
        "pr_body": "The bbox only contains the points of the marker, but the line will extend outside by half the line width. This was handled before, except when the line is at an angle to the edge, as then the line outside is wider than half a line width. The maximum is at 45°, or √2.\r\n\r\nThis fixes corners on 'v', '^', '<', '>', 'p', 'h', 'H', 'D', 'd', 'X'.\r\n\r\nFixes #9829.\r\n\r\n## PR Summary\r\n\r\n## PR Checklist\r\n\r\n- [x] Has Pytest style unit tests\r\n- [x] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [n/a] New features are documented, with examples if plot related\r\n- [n/a] Documentation is sphinx and numpydoc compliant\r\n- [n/a] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [n/a] Documented in doc/api/api_changes.rst if API changed in a backward-incompatible way",
        "issue_closed_at": "2020-06-10T20:38:57Z",
        "base_commit": "f42b24f534ce5d9eb89d95387695bb2cee017829"
      },
      "summary": "### Summary:\nThis issue is related to the rendering of specific markers in plots when they are saved as PDF files using the `matplotlib` library. The problem arises when plotting data with more than two points using certain marker shapes ('^', 'D', 'v'), as these markers appear clipped in the generated PDF files, whereas they render correctly in SVG files.\n\n1. **Problem description in general terms**: There is a discrepancy in the rendering of plot markers between different output formats, specifically PDF and SVG, which leads to visual inconsistencies.\n\n2. **Key symptoms and behaviors observed**: When using `matplotlib` to generate plots with specific markers, the markers appear clipped or partially rendered in the PDF output, while they are correctly displayed in the SVG format. This behavior is observed when plotting more than two data points.\n\n3. **Affected components or systems**: The issue affects the PDF rendering backend of the `matplotlib` library, specifically in the `PdfFile.markerObject` function within the `backend_pdf.py` file. The problem is platform-independent but was reported on an Ubuntu 17.04 system using Matplotlib version 2.1.0.\n\n4. **Potential impact or severity**: The impact is primarily on the visual fidelity of plots, which could be significant for users who rely on PDF exports for publications or presentations. The severity is moderate, as it affects the usability of PDF outputs for certain plots.\n\n5. **Relevant technical details abstracted for broader understanding**: The issue is related to how the `matplotlib` library handles the drawing of marker vertices when generating PDF files. The discrepancy does not affect the SVG format, suggesting that the issue is specific to the PDF backend's handling of marker rendering. The problem was observed using the `TkAgg` backend on Python 3.5.3, and Matplotlib was installed via pip.\n\nIn summary, this issue highlights a bug in the PDF output functionality of the `matplotlib` library affecting the rendering of specific plot markers, necessitating a fix to ensure consistent visual representation across different file formats.",
      "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: Vertices clipped for certain markers when plotting more than two points and saving as pdf\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\nThe vertices on certain markers ('^', 'D', 'v') are clipped when using `plot()` to plot data with more than two points and saving the plot as a PDF.\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\nsize = 256, 16\r\nfig,ax = plt.subplots()\r\nnum = 3\r\n\r\nfig,ax = plt.subplots()\r\nax.plot([i+1 for i in range(num)],[1 for i in range(num)], '^', markersize=3, markeredgewidth=0.7, color='green', markeredgecolor='black')\r\nax.set_xlim(0, num +1)\r\nax.set_xticks(())\r\nax.set_yticks(())\r\nfig.savefig('test.pdf') # This doesn't work properly.\r\nfig.savefig('test.svg')\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![pdfmarker](https://user-images.githubusercontent.com/8723338/33104959-e7cacfd6-cef8-11e7-880a-0e8aa8643454.png)\r\n![svgmarker](https://user-images.githubusercontent.com/8723338/33104963-ea6f906e-cef8-11e7-8742-ce5b2421c337.png)\r\n\r\nThe top image is of the marker from the .pdf file. The bottom image is of the marker from the .svg file.\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\nThe marker in the .pdf file should look like the marker in the .svg file.\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 17.04\r\n  * Matplotlib version: 2.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: Python 3.5.3\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: \r\n\r\nI installed matplotlib via pip.\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/backends/backend_pdf.py\n  function: PdfFile.markerObject\n"
    },
    {
      "similar_issue": {
        "issue_title": "Certain non-hashable parameters to text() give cryptic error messages",
        "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\nPer the title.  See https://discourse.matplotlib.org/t/cryptic-exception-when-axes-parameters-are-not-as-expected/ as well.\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\nfigtext(.5, .5, \"foo\", rotation=[90])\r\n# or\r\nfigtext(.5, .5, \"foo\", transform_rotates_text=[0])\r\n# or\r\nfigtext(.5, .5, \"foo\", linespacing=[0])\r\n```\r\nall fail with\r\n```\r\nTypeError: unhashable type: 'list'\r\n```\r\n\r\n**Actual outcome**\r\n\r\nsee above\r\n\r\n**Expected outcome**\r\n\r\nError out in the setter instead.\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: linux\r\n  * Matplotlib version: (`import matplotlib; print(matplotlib.__version__)`): master\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): any\r\n  * Python version: 38\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: \r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\n",
        "issue_id": 19223,
        "pr_number": 23332,
        "pr_title": "Validate Text linespacing on input.",
        "pr_body": "... and also tweak test_two_2line_texts to not set up an axes (just a\r\nfigure), as it doesn't need that.\r\n\r\nCloses #19223 (transform_rotates_text is no longer a problem since #19575).\r\n\r\n## PR Summary\r\n\r\n## PR Checklist\r\n\r\n<!-- Please mark any checkboxes that do not apply to this PR as [N/A]. -->\r\n**Tests and Styling**\r\n- [ ] Has pytest style unit tests (and `pytest` passes).\r\n- [ ] Is [Flake 8](https://flake8.pycqa.org/en/latest/) compliant (install `flake8-docstrings` and run `flake8 --docstring-convention=all`).\r\n\r\n**Documentation**\r\n- [ ] New features are documented, with examples if plot related.\r\n- [ ] New features have an entry in `doc/users/next_whats_new/` (follow instructions in README.rst there).\r\n- [ ] API changes documented in `doc/api/next_api_changes/` (follow instructions in README.rst there).\r\n- [ ] Documentation is sphinx and numpydoc compliant (the docs should [build](https://matplotlib.org/devel/documenting_mpl.html#building-the-docs) without error).\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 main, 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": "2022-06-24T22:25:33Z",
        "base_commit": "6e5a5415ddc513606eac5c116fde492370a3f7f6"
      },
      "summary": "### Summary:\nThis issue is related to the handling of non-hashable parameters passed to the `text()` function in Matplotlib, which results in cryptic error messages. Specifically, when certain parameters such as `rotation`, `transform_rotates_text`, or `linespacing` are provided as lists to the `figtext()` function, a `TypeError` is raised, indicating an \"unhashable type: 'list'\". This error occurs because the parameters are expected to be hashable types, and lists are inherently unhashable due to their mutable nature.\n\nKey symptoms and behaviors observed include the failure of code snippets that involve specifying these parameters as lists, leading to a confusing error message that does not clearly indicate the source of the problem. The affected components are primarily the functions within `matplotlib.text.py`, specifically `Annotation.__init__`, `Text.set_linespacing`, and `Text.set_rotation`, where these parameters are processed.\n\nThe potential impact of this issue is moderate, affecting users who may attempt to use non-standard types for these parameters and face difficulty in diagnosing the resulting errors. The severity is somewhat mitigated by the fact that properly hashable types can be used to avoid the issue, but the lack of clear error messaging can lead to confusion.\n\nRelevant technical details include the need for these parameters to be hashable, which is a constraint that should be clearly communicated to users. To address this issue, the error handling should be improved to provide more informative messages when non-hashable types are used, ideally checking and reporting the error in the setter methods themselves rather than allowing the cryptic `TypeError` to propagate.",
      "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: Certain non-hashable parameters to text() give cryptic error messages\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\nPer the title.  See https://discourse.matplotlib.org/t/cryptic-exception-when-axes-parameters-are-not-as-expected/ as well.\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\nfigtext(.5, .5, \"foo\", rotation=[90])\r\n# or\r\nfigtext(.5, .5, \"foo\", transform_rotates_text=[0])\r\n# or\r\nfigtext(.5, .5, \"foo\", linespacing=[0])\r\n```\r\nall fail with\r\n```\r\nTypeError: unhashable type: 'list'\r\n```\r\n\r\n**Actual outcome**\r\n\r\nsee above\r\n\r\n**Expected outcome**\r\n\r\nError out in the setter instead.\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: linux\r\n  * Matplotlib version: (`import matplotlib; print(matplotlib.__version__)`): master\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): any\r\n  * Python version: 38\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: \r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/text.py\n  line: line 5\n  function: Annotation.__init__\n  function: Text.set_linespacing\n  function: Text.set_rotation\n"
    }
  ]
}