{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-25498",
    "repo": "matplotlib/matplotlib",
    "created_at": "2023-03-18T17:01:11Z",
    "problem_statement": "Update colorbar after changing mappable.norm\nHow can I update a colorbar, after I changed the norm instance of the colorbar?\n\n`colorbar.update_normal(mappable)` has now effect and `colorbar.update_bruteforce(mappable)` throws a `ZeroDivsionError`-Exception.\n\nConsider this example:\n\n``` python\nimport matplotlib.pyplot as plt\nfrom matplotlib.colors import LogNorm\nimport numpy as np\n\nimg = 10**np.random.normal(1, 1, size=(50, 50))\n\nfig, ax = plt.subplots(1, 1)\nplot = ax.imshow(img, cmap='gray')\ncb = fig.colorbar(plot, ax=ax)\nplot.norm = LogNorm()\ncb.update_normal(plot)  # no effect\ncb.update_bruteforce(plot)  # throws ZeroDivisionError\nplt.show()\n```\n\nOutput for `cb.update_bruteforce(plot)`:\n\n```\nTraceback (most recent call last):\n  File \"test_norm.py\", line 12, in <module>\n    cb.update_bruteforce(plot)\n  File \"/home/maxnoe/.local/anaconda3/lib/python3.4/site-packages/matplotlib/colorbar.py\", line 967, in update_bruteforce\n    self.draw_all()\n  File \"/home/maxnoe/.local/anaconda3/lib/python3.4/site-packages/matplotlib/colorbar.py\", line 342, in draw_all\n    self._process_values()\n  File \"/home/maxnoe/.local/anaconda3/lib/python3.4/site-packages/matplotlib/colorbar.py\", line 664, in _process_values\n    b = self.norm.inverse(self._uniform_y(self.cmap.N + 1))\n  File \"/home/maxnoe/.local/anaconda3/lib/python3.4/site-packages/matplotlib/colors.py\", line 1011, in inverse\n    return vmin * ma.power((vmax / vmin), val)\nZeroDivisionError: division by zero\n```\n\n",
    "patch": "diff --git a/lib/matplotlib/colorbar.py b/lib/matplotlib/colorbar.py\n--- a/lib/matplotlib/colorbar.py\n+++ b/lib/matplotlib/colorbar.py\n@@ -301,11 +301,6 @@ def __init__(self, ax, mappable=None, *, cmap=None,\n         if mappable is None:\n             mappable = cm.ScalarMappable(norm=norm, cmap=cmap)\n \n-        # Ensure the given mappable's norm has appropriate vmin and vmax\n-        # set even if mappable.draw has not yet been called.\n-        if mappable.get_array() is not None:\n-            mappable.autoscale_None()\n-\n         self.mappable = mappable\n         cmap = mappable.cmap\n         norm = mappable.norm\n@@ -1101,7 +1096,10 @@ def _process_values(self):\n             b = np.hstack((b, b[-1] + 1))\n \n         # transform from 0-1 to vmin-vmax:\n+        if self.mappable.get_array() is not None:\n+            self.mappable.autoscale_None()\n         if not self.norm.scaled():\n+            # If we still aren't scaled after autoscaling, use 0, 1 as default\n             self.norm.vmin = 0\n             self.norm.vmax = 1\n         self.norm.vmin, self.norm.vmax = mtransforms.nonsingular(\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_9659",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves rendering logic for arcs, which is unrelated to colorbar normalization or update logic."
      },
      {
        "idx": 2,
        "id": "similar_2885",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about rendering errors in a specific backend, not related to colorbar normalization or update methods."
      },
      {
        "idx": 3,
        "id": "similar_2688",
        "decision": "Useful",
        "confidence": "High",
        "reason": "This issue involves colorbar updates and layout management, similar to the current issue's focus on colorbar normalization and update methods."
      },
      {
        "idx": 4,
        "id": "similar_12458",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about rendering lines on a colorbar, which does not directly relate to normalization or update logic."
      },
      {
        "idx": 5,
        "id": "similar_9829",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue pertains to marker rendering in PDF outputs, unrelated to colorbar normalization or update methods."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "patches.Arc objects randomly drawing the full ellipse",
        "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\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n\r\nProviding theta1 and theta2 to the Arc constructor sometimes causes the arc to be drawn as the full ellipse.\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\nfrom matplotlib.patches import Arc\r\nimport matplotlib.pyplot as plt\r\n\r\npatches = [\r\n    Arc((143954140, 374), 476, 476, theta1=0, theta2=180),\r\n    Arc((143954902, 374), 2001, 749, theta1=0, theta2=180),\r\n    Arc((143955137, 374), 2471, 749, theta1=0, theta2=180),\r\n    Arc((143955276, 374), 2748, 749, theta1=0, theta2=180),\r\n    Arc((143955362, 374), 2022, 749, theta1=0, theta2=180),\r\n    Arc((143955500, 374), 2299, 749, theta1=0, theta2=180),\r\n    Arc((143955641, 374), 488, 488, theta1=0, theta2=180),\r\n    Arc((143955650, 374), 506, 506, theta1=0, theta2=180),\r\n    Arc((143955885, 374), 976, 749, theta1=0, theta2=180),\r\n    Arc((143956128, 374), 489, 489, theta1=0, theta2=180),\r\n    Arc((143956135, 374), 467, 467, theta1=0, theta2=180),\r\n    Arc((143956137, 374), 471, 471, theta1=0, theta2=180),\r\n    Arc((143956276, 374), 748, 748, theta1=0, theta2=180),\r\n    Arc((143956515, 374), 1226, 749, theta1=0, theta2=180),\r\n    Arc((143956167, 374), 412, 412, theta1=0, theta2=180),\r\n    Arc((143956170, 374), 402, 402, theta1=0, theta2=180),\r\n    Arc((143956172, 374), 401, 401, theta1=0, theta2=180),\r\n    Arc((143956183, 374), 380, 380, theta1=0, theta2=180),\r\n    Arc((143956321, 374), 657, 657, theta1=0, theta2=180),\r\n    Arc((143956610, 374), 80, 80, theta1=0, theta2=180),\r\n    Arc((143956849, 374), 558, 558, theta1=0, theta2=180),\r\n    Arc((143956928, 374), 400, 400, theta1=0, theta2=180),\r\n    Arc((143956960, 374), 335, 335, theta1=0, theta2=180),\r\n    Arc((143956962, 374), 331, 331, theta1=0, theta2=180),\r\n    Arc((143957055, 374), 146, 146, theta1=0, theta2=180),\r\n    Arc((143957346, 374), 105, 105, theta1=0, theta2=180),\r\n    Arc((143957397, 374), 207, 207, theta1=0, theta2=180),\r\n    Arc((143957448, 374), 308, 308, theta1=0, theta2=180),\r\n    Arc((143957459, 374), 331, 331, theta1=0, theta2=180),\r\n    Arc((143957475, 374), 363, 363, theta1=0, theta2=180),\r\n    Arc((143957696, 374), 804, 749, theta1=0, theta2=180),\r\n    Arc((143958871, 374), 3154, 749, theta1=0, theta2=180),\r\n    Arc((143957954, 374), 287, 287, theta1=0, theta2=180),\r\n    Arc((143957957, 374), 292, 292, theta1=0, theta2=180),\r\n    Arc((143958125, 374), 628, 628, theta1=0, theta2=180),\r\n    Arc((143958305, 374), 268, 268, theta1=0, theta2=180),\r\n    Arc((143958313, 374), 251, 251, theta1=0, theta2=180),\r\n    Arc((143958368, 374), 142, 142, theta1=0, theta2=180),\r\n    Arc((143958369, 374), 136, 136, theta1=0, theta2=180),\r\n    Arc((143958370, 374), 138, 138, theta1=0, theta2=180),\r\n    Arc((143958905, 374), 535, 535, theta1=0, theta2=180),\r\n    Arc((143959528, 374), 1780, 749, theta1=0, theta2=180),\r\n    Arc((143959543, 374), 1810, 749, theta1=0, theta2=180),\r\n    Arc((143959544, 374), 1813, 749, theta1=0, theta2=180),\r\n    Arc((143959849, 374), 1198, 749, theta1=0, theta2=180),\r\n    Arc((143960119, 374), 658, 658, theta1=0, theta2=180),\r\n    Arc((143960678, 374), 151, 151, theta1=0, theta2=180),\r\n    Arc((143960682, 374), 158, 158, theta1=0, theta2=180),\r\n    Arc((143960682, 374), 159, 159, theta1=0, theta2=180),\r\n    Arc((143960723, 374), 241, 241, theta1=0, theta2=180),\r\n    Arc((143960797, 374), 388, 388, theta1=0, theta2=180),\r\n    Arc((143960845, 374), 484, 484, theta1=0, theta2=180),\r\n    Arc((143960809, 374), 363, 363, theta1=0, theta2=180),\r\n    Arc((143960943, 374), 95, 95, theta1=0, theta2=180),\r\n    Arc((143960945, 374), 92, 92, theta1=0, theta2=180)\r\n]\r\n\r\nplt.figure()\r\nax = plt.gca()\r\nmap(ax.add_patch, patches)\r\nplt.xlim(143953697, 143961337)\r\nplt.ylim(-150, 900)\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n![image](https://user-images.githubusercontent.com/17572426/32301746-967dedf2-bf35-11e7-8263-102883c3a99a.png)\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\nAll the arcs should be half-ellipses above the line `y = 0.5`.\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: Mac OS Sierra\r\n  * Matplotlib version: 2.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): MacOSX\r\n  * Python version: 2.7.14 (Homebrew)\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: numpy 13.3.3\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\npython 2.7.14 from homebrew (`brew install python`); matplotlib from pip (`sudo -H pip install matplotlib`)\r\n",
        "issue_id": 9659,
        "pr_number": 9661,
        "pr_title": "Fix arcs with very large width/height.",
        "pr_body": "## PR Summary\r\n\r\nLarge width/height triggers a different code path that didn't correctly\r\ndraw limited arcs instead of the whole ellipse.\r\n\r\nFixes #9659.\r\n\r\n## PR Checklist\r\n\r\n- [x] Has Pytest style unit tests\r\n- [x] Code is PEP 8 compliant\r\n- [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": "2017-11-02T10:07:32Z",
        "base_commit": "c46599356379b148afe331ad8bc05fb343cf7e85"
      },
      "summary": "### Summary:\n\nThis issue pertains to a bug in the Matplotlib library, specifically in the rendering of `Arc` objects. The problem arises when users attempt to create arc segments using the `Arc` constructor by specifying angular parameters `theta1` and `theta2`. Instead of rendering partial arcs as intended, the library sometimes erroneously draws full ellipses. This behavior is inconsistent and appears to occur randomly, affecting the graphical output.\n\n1. **Problem Description**: The bug involves the incorrect rendering of arc shapes in Matplotlib where arcs are supposed to be partial segments defined by start and end angles, but are instead drawn as complete ellipses.\n\n2. **Key Symptoms and Behaviors Observed**: Users observe that arcs, which are intended to be half-ellipses, are rendered as full ellipses. This visual discrepancy is evident in the graphical output when using the `Arc` class with specific angular parameters.\n\n3. **Affected Components or Systems**: The issue affects the `Arc` class within the `matplotlib.patches` module of the Matplotlib library. The problem is specifically tied to the method responsible for calculating and rendering arc segments.\n\n4. **Potential Impact or Severity**: The severity of this issue is moderate as it affects the visual accuracy of plots generated using Matplotlib. This could lead to misinterpretations of data where partial arcs are significant visual elements. It primarily affects users relying on precise rendering of arc segments in their graphical presentations.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The issue lies in the logic that calculates the intersection of arc paths, potentially within the `Arc.iter_circle_intersect_on_line_seg` method. The problem may stem from incorrect calculations or conditions that fail to properly constrain arcs to the specified angular range, leading to the unintentional rendering of full ellipses.\n\nThe fixed code elements indicate that modifications were made to the `Arc.iter_circle_intersect_on_line_seg` function within the `lib/matplotlib/patches.py` file, addressing the calculation logic responsible for rendering arc segments accurately.",
      "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: patches.Arc objects randomly drawing the full ellipse\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\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n\r\nProviding theta1 and theta2 to the Arc constructor sometimes causes the arc to be drawn as the full ellipse.\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\nfrom matplotlib.patches import Arc\r\nimport matplotlib.pyplot as plt\r\n\r\npatches = [\r\n    Arc((143954140, 374), 476, 476, theta1=0, theta2=180),\r\n    Arc((143954902, 374), 2001, 749, theta1=0, theta2=180),\r\n    Arc((143955137, 374), 2471, 749, theta1=0, theta2=180),\r\n    Arc((143955276, 374), 2748, 749, theta1=0, theta2=180),\r\n    Arc((143955362, 374), 2022, 749, theta1=0, theta2=180),\r\n    Arc((143955500, 374), 2299, 749, theta1=0, theta2=180),\r\n    Arc((143955641, 374), 488, 488, theta1=0, theta2=180),\r\n    Arc((143955650, 374), 506, 506, theta1=0, theta2=180),\r\n    Arc((143955885, 374), 976, 749, theta1=0, theta2=180),\r\n    Arc((143956128, 374), 489, 489, theta1=0, theta2=180),\r\n    Arc((143956135, 374), 467, 467, theta1=0, theta2=180),\r\n    Arc((143956137, 374), 471, 471, theta1=0, theta2=180),\r\n    Arc((143956276, 374), 748, 748, theta1=0, theta2=180),\r\n    Arc((143956515, 374), 1226, 749, theta1=0, theta2=180),\r\n    Arc((143956167, 374), 412, 412, theta1=0, theta2=180),\r\n    Arc((143956170, 374), 402, 402, theta1=0, theta2=180),\r\n    Arc((143956172, 374), 401, 401, theta1=0, theta2=180),\r\n    Arc((143956183, 374), 380, 380, theta1=0, theta2=180),\r\n    Arc((143956321, 374), 657, 657, theta1=0, theta2=180),\r\n    Arc((143956610, 374), 80, 80, theta1=0, theta2=180),\r\n    Arc((143956849, 374), 558, 558, theta1=0, theta2=180),\r\n    Arc((143956928, 374), 400, 400, theta1=0, theta2=180),\r\n    Arc((143956960, 374), 335, 335, theta1=0, theta2=180),\r\n    Arc((143956962, 374), 331, 331, theta1=0, theta2=180),\r\n    Arc((143957055, 374), 146, 146, theta1=0, theta2=180),\r\n    Arc((143957346, 374), 105, 105, theta1=0, theta2=180),\r\n    Arc((143957397, 374), 207, 207, theta1=0, theta2=180),\r\n    Arc((143957448, 374), 308, 308, theta1=0, theta2=180),\r\n    Arc((143957459, 374), 331, 331, theta1=0, theta2=180),\r\n    Arc((143957475, 374), 363, 363, theta1=0, theta2=180),\r\n    Arc((143957696, 374), 804, 749, theta1=0, theta2=180),\r\n    Arc((143958871, 374), 3154, 749, theta1=0, theta2=180),\r\n    Arc((143957954, 374), 287, 287, theta1=0, theta2=180),\r\n    Arc((143957957, 374), 292, 292, theta1=0, theta2=180),\r\n    Arc((143958125, 374), 628, 628, theta1=0, theta2=180),\r\n    Arc((143958305, 374), 268, 268, theta1=0, theta2=180),\r\n    Arc((143958313, 374), 251, 251, theta1=0, theta2=180),\r\n    Arc((143958368, 374), 142, 142, theta1=0, theta2=180),\r\n    Arc((143958369, 374), 136, 136, theta1=0, theta2=180),\r\n    Arc((143958370, 374), 138, 138, theta1=0, theta2=180),\r\n    Arc((143958905, 374), 535, 535, theta1=0, theta2=180),\r\n    Arc((143959528, 374), 1780, 749, theta1=0, theta2=180),\r\n    Arc((143959543, 374), 1810, 749, theta1=0, theta2=180),\r\n    Arc((143959544, 374), 1813, 749, theta1=0, theta2=180),\r\n    Arc((143959849, 374), 1198, 749, theta1=0, theta2=180),\r\n    Arc((143960119, 374), 658, 658, theta1=0, theta2=180),\r\n    Arc((143960678, 374), 151, 151, theta1=0, theta2=180),\r\n    Arc((143960682, 374), 158, 158, theta1=0, theta2=180),\r\n    Arc((143960682, 374), 159, 159, theta1=0, theta2=180),\r\n    Arc((143960723, 374), 241, 241, theta1=0, theta2=180),\r\n    Arc((143960797, 374), 388, 388, theta1=0, theta2=180),\r\n    Arc((143960845, 374), 484, 484, theta1=0, theta2=180),\r\n    Arc((143960809, 374), 363, 363, theta1=0, theta2=180),\r\n    Arc((143960943, 374), 95, 95, theta1=0, theta2=180),\r\n    Arc((143960945, 374), 92, 92, theta1=0, theta2=180)\r\n]\r\n\r\nplt.figure()\r\nax = plt.gca()\r\nmap(ax.add_patch, patches)\r\nplt.xlim(143953697, 143961337)\r\nplt.ylim(-150, 900)\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n![image](https://user-images.githubusercontent.com/17572426/32301746-967dedf2-bf35-11e7-8263-102883c3a99a.png)\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\nAll the arcs should be half-ellipses above the line `y = 0.5`.\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: Mac OS Sierra\r\n  * Matplotlib version: 2.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): MacOSX\r\n  * Python version: 2.7.14 (Homebrew)\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: numpy 13.3.3\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\npython 2.7.14 from homebrew (`brew install python`); matplotlib from pip (`sudo -H pip install matplotlib`)\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: Arc.iter_circle_intersect_on_line_seg\n"
    },
    {
      "similar_issue": {
        "issue_title": "PGF backend messes up fill",
        "issue_body": "I have a figure that I need to compile using PGF backend because the \\Game symbol is incorrect (another issue will be opened for that problem).\n\nBut when I do, the curves bounding the fill seem to get cropped to the visible window, which breaks the fill, as seen here:\n\n![ddlabeled](https://f.cloud.github.com/assets/1859947/2372461/caffe8b6-a83a-11e3-96a1-6fbc26fbdefb.jpg)\n\nWhen using the other backends, this behavior is not seen, for instance, \n![ddlabeled](https://f.cloud.github.com/assets/1859947/2372475/e6b08f70-a83a-11e3-9eaf-8f13e9886077.png)\n",
        "issue_id": 2885,
        "pr_number": 4308,
        "pr_title": "fixes #2885, #3935, #3693, for hatched fill",
        "pr_body": "The last patch only removed clipping for the colour fill, hatches in fill_between were still clipped. Passing through rgbFace fixes this.\n",
        "issue_closed_at": "2015-03-19T21:09:05Z",
        "base_commit": "a488cbc3926d8409270a7c79b7923268fdc93dce"
      },
      "summary": "### Summary: This issue is related to the rendering of graphical elements when using a specific backend in a software application. The problem is observed when employing the PGF backend to compile figures, where the fill of certain graphical elements is incorrectly displayed due to the bounding curves being cropped to the visible window. This results in an incomplete or broken appearance of the fill in the graphical output. Such behavior is not observed when using other available backends, indicating a specific issue with the PGF backend's rendering process.\n\n1. **Problem Description in General Terms**: The issue involves incorrect rendering of filled graphical elements due to clipping or cropping errors in the rendering process, specific to a particular backend used for compiling figures.\n\n2. **Key Symptoms and Behaviors Observed**: The primary symptom is the incorrect display of filled areas in graphical outputs, where the fill appears incomplete or broken. This is due to the bounding curves of these filled areas being cropped, leading to an incorrect visual representation.\n\n3. **Affected Components or Systems**: The problem specifically affects the PGF backend, a component responsible for rendering figures in a specific format within the software.\n\n4. **Potential Impact or Severity**: The severity can vary depending on the use case, but it primarily affects the visual fidelity of graphical outputs, which can be critical for users relying on accurate visual representations for presentations, publications, or data analysis.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The issue lies within the rendering logic of the PGF backend, particularly within the `RendererPgf.draw_path` function. The fix involves adjustments to ensure that the bounding curves of filled areas are correctly rendered without being improperly clipped or cropped.",
      "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: PGF backend messes up fill\n\nBody:\nI have a figure that I need to compile using PGF backend because the \\Game symbol is incorrect (another issue will be opened for that problem).\n\nBut when I do, the curves bounding the fill seem to get cropped to the visible window, which breaks the fill, as seen here:\n\n![ddlabeled](https://f.cloud.github.com/assets/1859947/2372461/caffe8b6-a83a-11e3-96a1-6fbc26fbdefb.jpg)\n\nWhen using the other backends, this behavior is not seen, for instance, \n![ddlabeled](https://f.cloud.github.com/assets/1859947/2372475/e6b08f70-a83a-11e3-9eaf-8f13e9886077.png)\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/backends/backend_pgf.py\n  function: RendererPgf.draw_path\n"
    },
    {
      "similar_issue": {
        "issue_title": "Deleting axis in matplotlib > v1.2.1 does not work similar to v1.1.1",
        "issue_body": "This issue is described in this Stackoverflow question:\n\nhttp://stackoverflow.com/questions/17052380/deleting-axis-in-matplotlib-v1-2-1-does-not-work-similar-to-v1-1-1\n\nI am using matplotlib (python win32 v2.7.5) to plot contour plots with color bars that are animated or the contour gets updated. In order to update the plot, I delete the color bar axis while keeping the original plot axis untouched. In version 1.1.1 of matplotlib, the program was working okay, however, when I upgraded to 1.2.1 (and higher) of matplotlib I started to notice my plot is getting squashed to the left.\n\nThe following code demos the issues.  Run it in version 1.1.1 and then in 1.2.1 to see the differences. \n\n``` python\nimport matplotlib.pyplot as plt\nimport numpy as np\nfrom matplotlib.mlab import bivariate_normal\nfrom matplotlib.colors import LogNorm\n\ndelta = 0.5\nx = np.arange(-3.0, 4.001, delta)\ny = np.arange(-4.0, 3.001, delta)\nX, Y = np.meshgrid(x, y)\nZ = bivariate_normal(X, Y, 1.0, 1.0, 0.0, 0.0)\nfig  = plt.figure()\nfig.subplots_adjust(left=0.1, bottom=0.1, right=0.97, top=0.92)\nax   = fig.add_subplot(1,1,1)\naxim = ax.imshow(Z,norm = LogNorm())\ncb   = fig.colorbar(axim)\n\n##Note:  These are not replicated, I put them here to show how a refresh of the \n##          contour plot multiple times will look like\nfig.delaxes(fig.axes[1])\nfig.subplots_adjust(left=0.1, bottom=0.1, right=0.97, top=0.92)\ncb   = fig.colorbar(axim)\n\nfig.delaxes(fig.axes[1])\nfig.subplots_adjust(left=0.1, bottom=0.1, right=0.97, top=0.92)\ncb   = fig.colorbar(axim)\n\nplt.show()\n```\n\nIf i delete ALL axis and re-create them each time, then it looks ok even in new version, but I am thinking that this is not efficient process with animation. \n",
        "issue_id": 2688,
        "pr_number": 3110,
        "pr_title": "BUG: Add Figure.delcolorbar() to fully delete a colorbar",
        "pr_body": "Closes #2688.\n\nThis creates a new Figure.delcolorbar() function, named to mimic Figure.delaxes().  The new function will delete a colorbar.  If that colorbar was creating with `use_gridspec=True`, the function will also reset the gridspec.  I added two tests to confirm that the function works as intended for colorbars creating with `use_gridspec` set to either `True` or `False`.\n",
        "issue_closed_at": "2014-06-11T16:58:27Z",
        "base_commit": "0b481b579e31c630813667321e1f022190f7a200"
      },
      "summary": "### Summary:\nThis issue highlights a regression in behavior observed when upgrading from version 1.1.1 to 1.2.1 and later versions of the matplotlib library, a popular plotting library for Python. The problem specifically arises in the context of updating plots that involve contour plots with color bars, often used in animated visualizations or dynamically updated plots. In the newer versions of matplotlib, attempts to delete and re-add color bar axes while preserving the original plot axes result in the plot being compressed or squashed to the left, altering the intended visual representation. \n\nKey symptoms include unexpected layout changes in plots, particularly a shift or compression of the entire plot when the color bar axis is deleted and recreated. This issue primarily affects users who rely on efficient updates to animated or dynamic plots, as the workaround of deleting and recreating all axes, while resolving the layout issue, is not optimal for performance.\n\nThe affected components are primarily within the matplotlib library, specifically in the handling of color bar axes and the layout management of plots when axes are modified. The severity of the issue is significant for users who need to maintain efficient and visually accurate plotting capabilities in their applications, especially those utilizing animations or frequent updates.\n\nTechnical details abstracted from this issue indicate that the problem may reside in the underlying methods responsible for managing axes and layout adjustments in the code base of matplotlib. The patch addresses these concerns by modifying functions related to color bar management and layout adjustments, such as `ColorbarBase._locate`, `Colorbar.update_bruteforce`, and `colorbar_factory` in the `colorbar.py` module. These changes aim to restore expected plot behaviors and visual consistency across different versions of the library.",
      "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: Deleting axis in matplotlib > v1.2.1 does not work similar to v1.1.1\n\nBody:\nThis issue is described in this Stackoverflow question:\n\nhttp://stackoverflow.com/questions/17052380/deleting-axis-in-matplotlib-v1-2-1-does-not-work-similar-to-v1-1-1\n\nI am using matplotlib (python win32 v2.7.5) to plot contour plots with color bars that are animated or the contour gets updated. In order to update the plot, I delete the color bar axis while keeping the original plot axis untouched. In version 1.1.1 of matplotlib, the program was working okay, however, when I upgraded to 1.2.1 (and higher) of matplotlib I started to notice my plot is getting squashed to the left.\n\nThe following code demos the issues.  Run it in version 1.1.1 and then in 1.2.1 to see the differences. \n\n``` python\nimport matplotlib.pyplot as plt\nimport numpy as np\nfrom matplotlib.mlab import bivariate_normal\nfrom matplotlib.colors import LogNorm\n\ndelta = 0.5\nx = np.arange(-3.0, 4.001, delta)\ny = np.arange(-4.0, 3.001, delta)\nX, Y = np.meshgrid(x, y)\nZ = bivariate_normal(X, Y, 1.0, 1.0, 0.0, 0.0)\nfig  = plt.figure()\nfig.subplots_adjust(left=0.1, bottom=0.1, right=0.97, top=0.92)\nax   = fig.add_subplot(1,1,1)\naxim = ax.imshow(Z,norm = LogNorm())\ncb   = fig.colorbar(axim)\n\n##Note:  These are not replicated, I put them here to show how a refresh of the \n##          contour plot multiple times will look like\nfig.delaxes(fig.axes[1])\nfig.subplots_adjust(left=0.1, bottom=0.1, right=0.97, top=0.92)\ncb   = fig.colorbar(axim)\n\nfig.delaxes(fig.axes[1])\nfig.subplots_adjust(left=0.1, bottom=0.1, right=0.97, top=0.92)\ncb   = fig.colorbar(axim)\n\nplt.show()\n```\n\nIf i delete ALL axis and re-create them each time, then it looks ok even in new version, but I am thinking that this is not efficient process with animation. \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/colorbar.py\n  function: ColorbarBase._locate\n  function: Colorbar.update_bruteforce\n  function: colorbar_factory\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 problem encountered in the `matplotlib` library, specifically with the `ColorbarBase` class from the `colorbar` module. The problem arises when using the `add_lines` method, where it fails to render lines correctly on a colorbar. Users have observed missing or poorly adjusted lines when they attempt to overlay lines on a colorbar using this method. Notably, this functionality behaved as expected in an earlier version of the library (version 2.2.3) but appears to be malfunctioning in version 3.0.0.\n\nThe key symptoms include the absence of expected lines and incorrect alignment or adjustment of these lines, which are supposed to be visible across the colorbar. The issue affects the colorbar's visual representation, which is crucial for users relying on precise data visualization, such as scientific plots requiring accurate demarcation with lines.\n\nThe affected component is the `add_lines` function within the `Colorbar` class in `matplotlib`. The severity of the issue is significant, especially for users who require reliable visualization tools for their work. The technical details involve discrepancies between the intended visual output (four white lines crossing the colorbar) and what is actually rendered, which suggests a regression from previous functionality.\n\nThe patch addresses this by modifying the function `Colorbar.add_lines` in the `lib/matplotlib/colorbar.py` file, ensuring that the lines are rendered as expected in the updated library version.",
      "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": "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:\n\nThis issue involves a rendering problem in the Matplotlib library when plotting data points with specific markers and saving the plot as a PDF file. Specifically, certain markers ('^', 'D', 'v') are being clipped, or partially cut off, when plotting more than two data points and exporting the plot to a PDF format. The problem does not occur when saving the plot in SVG format, indicating a discrepancy in how different file formats handle marker rendering.\n\nKey symptoms and behaviors observed include the visual difference between the markers in the PDF output compared to the SVG output, where the latter renders correctly. This issue specifically affects the PDF backend of Matplotlib, which is responsible for generating PDF files from plots.\n\nThe severity of the issue could vary depending on the user's reliance on accurate PDF outputs for their visualizations. For users who need consistent and correct marker rendering across different formats, this can be a significant problem, especially if PDF is a preferred or required format for documentation or presentation.\n\nTechnically, the issue was traced to the 'PdfFile.markerObject' function within the backend_pdf.py file of the Matplotlib library. The fix likely involves adjusting how the marker vertices are calculated or rendered for PDF outputs to ensure they are not clipped. This requires understanding the nuances of rendering processes in different file formats and making appropriate adjustments in the Matplotlib codebase.",
      "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"
    }
  ]
}