{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-24265",
    "repo": "matplotlib/matplotlib",
    "created_at": "2022-10-25T02:03:19Z",
    "problem_statement": "[Bug]: Setting matplotlib.pyplot.style.library['seaborn-colorblind'] result in key error on matplotlib v3.6.1\n### Bug summary\n\nI have code that executes:\r\n```\r\nimport matplotlib.pyplot as plt\r\nthe_rc = plt.style.library[\"seaborn-colorblind\"]\r\n```\r\n\r\nUsing version 3.4.3 of matplotlib, this works fine. I recently installed my code on a machine with matplotlib version 3.6.1 and upon importing my code, this generated a key error for line `the_rc = plt.style.library[\"seaborn-colorblind\"]` saying \"seaborn-colorblind\" was a bad key.\n\n### Code for reproduction\n\n```python\nimport matplotlib.pyplot as plt\r\nthe_rc = plt.style.library[\"seaborn-colorblind\"]\n```\n\n\n### Actual outcome\n\nTraceback (most recent call last):\r\nKeyError: 'seaborn-colorblind'\n\n### Expected outcome\n\nseaborn-colorblind should be set as the matplotlib library style and I should be able to continue plotting with that style.\n\n### Additional information\n\n- Bug occurs with matplotlib version 3.6.1\r\n- Bug does not occur with matplotlib version 3.4.3\r\n- Tested on MacOSX and Ubuntu (same behavior on both)\n\n### Operating system\n\nOS/X\n\n### Matplotlib Version\n\n3.6.1\n\n### Matplotlib Backend\n\nMacOSX\n\n### Python version\n\n3.9.7\n\n### Jupyter version\n\n_No response_\n\n### Installation\n\npip\n",
    "patch": "diff --git a/lib/matplotlib/style/core.py b/lib/matplotlib/style/core.py\n--- a/lib/matplotlib/style/core.py\n+++ b/lib/matplotlib/style/core.py\n@@ -43,6 +43,32 @@ class __getattr__:\n     'toolbar', 'timezone', 'figure.max_open_warning',\n     'figure.raise_window', 'savefig.directory', 'tk.window_focus',\n     'docstring.hardcopy', 'date.epoch'}\n+_DEPRECATED_SEABORN_STYLES = {\n+    s: s.replace(\"seaborn\", \"seaborn-v0_8\")\n+    for s in [\n+        \"seaborn\",\n+        \"seaborn-bright\",\n+        \"seaborn-colorblind\",\n+        \"seaborn-dark\",\n+        \"seaborn-darkgrid\",\n+        \"seaborn-dark-palette\",\n+        \"seaborn-deep\",\n+        \"seaborn-muted\",\n+        \"seaborn-notebook\",\n+        \"seaborn-paper\",\n+        \"seaborn-pastel\",\n+        \"seaborn-poster\",\n+        \"seaborn-talk\",\n+        \"seaborn-ticks\",\n+        \"seaborn-white\",\n+        \"seaborn-whitegrid\",\n+    ]\n+}\n+_DEPRECATED_SEABORN_MSG = (\n+    \"The seaborn styles shipped by Matplotlib are deprecated since %(since)s, \"\n+    \"as they no longer correspond to the styles shipped by seaborn. However, \"\n+    \"they will remain available as 'seaborn-v0_8-<style>'. Alternatively, \"\n+    \"directly use the seaborn API instead.\")\n \n \n def _remove_blacklisted_style_params(d, warn=True):\n@@ -113,31 +139,9 @@ def use(style):\n     def fix_style(s):\n         if isinstance(s, str):\n             s = style_alias.get(s, s)\n-            if s in [\n-                \"seaborn\",\n-                \"seaborn-bright\",\n-                \"seaborn-colorblind\",\n-                \"seaborn-dark\",\n-                \"seaborn-darkgrid\",\n-                \"seaborn-dark-palette\",\n-                \"seaborn-deep\",\n-                \"seaborn-muted\",\n-                \"seaborn-notebook\",\n-                \"seaborn-paper\",\n-                \"seaborn-pastel\",\n-                \"seaborn-poster\",\n-                \"seaborn-talk\",\n-                \"seaborn-ticks\",\n-                \"seaborn-white\",\n-                \"seaborn-whitegrid\",\n-            ]:\n-                _api.warn_deprecated(\n-                    \"3.6\", message=\"The seaborn styles shipped by Matplotlib \"\n-                    \"are deprecated since %(since)s, as they no longer \"\n-                    \"correspond to the styles shipped by seaborn. However, \"\n-                    \"they will remain available as 'seaborn-v0_8-<style>'. \"\n-                    \"Alternatively, directly use the seaborn API instead.\")\n-                s = s.replace(\"seaborn\", \"seaborn-v0_8\")\n+            if s in _DEPRECATED_SEABORN_STYLES:\n+                _api.warn_deprecated(\"3.6\", message=_DEPRECATED_SEABORN_MSG)\n+                s = _DEPRECATED_SEABORN_STYLES[s]\n         return s\n \n     for style in map(fix_style, styles):\n@@ -244,17 +248,26 @@ def update_nested_dict(main_dict, new_dict):\n     return main_dict\n \n \n+class _StyleLibrary(dict):\n+    def __getitem__(self, key):\n+        if key in _DEPRECATED_SEABORN_STYLES:\n+            _api.warn_deprecated(\"3.6\", message=_DEPRECATED_SEABORN_MSG)\n+            key = _DEPRECATED_SEABORN_STYLES[key]\n+\n+        return dict.__getitem__(self, key)\n+\n+\n # Load style library\n # ==================\n _base_library = read_style_directory(BASE_LIBRARY_PATH)\n-library = None\n+library = _StyleLibrary()\n available = []\n \n \n def reload_library():\n     \"\"\"Reload the style library.\"\"\"\n-    global library\n-    library = update_user_library(_base_library)\n+    library.clear()\n+    library.update(update_user_library(_base_library))\n     available[:] = sorted(library.keys())\n \n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_10769",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves a type mismatch error due to incorrect API usage, which is unrelated to the deprecation and key error in the current issue."
      },
      {
        "idx": 2,
        "id": "similar_12853",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about shared axes behavior, which does not relate to the deprecation and key error handling in the current issue."
      },
      {
        "idx": 3,
        "id": "similar_4185",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with vector graphics rendering, which is unrelated to the style deprecation and key error in the current issue."
      },
      {
        "idx": 4,
        "id": "similar_9118",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves LaTeX configuration conflicts, which do not share reasoning patterns with the style deprecation and key error in the current issue."
      },
      {
        "idx": 5,
        "id": "similar_12675",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about date labeling errors, which does not relate to the style deprecation and key error handling in the current issue."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "DOC: set_major_locator could check that its getting a Locator (was EngFormatter broken?)",
        "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`matplotlib.ticker.EngFormatter` seems to be broken:\r\n\r\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n```\r\nf, ax = plt.subplots(1, 1, figsize=(15, 10))\r\nplt.plot([10**4, 11*10**4], [100, 150])\r\nax.xaxis.set_major_locator(matplotlib.ticker.EngFormatter())\r\n```\r\n```\r\nError in callback <function install_repl_displayhook.<locals>.post_execute at 0x7f60a9b120d0> (for post_execute):\r\n\r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/pyplot.py in post_execute()\r\n    147             def post_execute():\r\n    148                 if matplotlib.is_interactive():\r\n--> 149                     draw_all()\r\n    150 \r\n    151             # IPython >= 2\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/_pylab_helpers.py in draw_all(cls, force)\r\n    134         for f_mgr in cls.get_all_fig_managers():\r\n    135             if force or f_mgr.canvas.figure.stale:\r\n--> 136                 f_mgr.canvas.draw_idle()\r\n    137 \r\n    138 atexit.register(Gcf.destroy_all)\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backend_bases.py in draw_idle(self, *args, **kwargs)\r\n   2053         if not self._is_idle_drawing:\r\n   2054             with self._idle_draw_cntx():\r\n-> 2055                 self.draw(*args, **kwargs)\r\n   2056 \r\n   2057     def draw_cursor(self, event):\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backends/backend_agg.py in draw(self)\r\n    429             # if toolbar:\r\n    430             #     toolbar.set_cursor(cursors.WAIT)\r\n--> 431             self.figure.draw(self.renderer)\r\n    432             # A GUI class may be need to update a window using this draw, so\r\n    433             # don't forget to call the superclass.\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/figure.py in draw(self, renderer)\r\n   1473 \r\n   1474             mimage._draw_list_compositing_images(\r\n-> 1475                 renderer, self, artists, self.suppressComposite)\r\n   1476 \r\n   1477             renderer.close_group('figure')\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/image.py in _draw_list_compositing_images(renderer, parent, artists, suppress_composite)\r\n    139     if not_composite or not has_images:\r\n    140         for a in artists:\r\n--> 141             a.draw(renderer)\r\n    142     else:\r\n    143         # Composite any adjacent images together\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axes/_base.py in draw(self, renderer, inframe)\r\n   2605             renderer.stop_rasterizing()\r\n   2606 \r\n-> 2607         mimage._draw_list_compositing_images(renderer, self, artists)\r\n   2608 \r\n   2609         renderer.close_group('axes')\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/image.py in _draw_list_compositing_images(renderer, parent, artists, suppress_composite)\r\n    139     if not_composite or not has_images:\r\n    140         for a in artists:\r\n--> 141             a.draw(renderer)\r\n    142     else:\r\n    143         # Composite any adjacent images together\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in draw(self, renderer, *args, **kwargs)\r\n   1185         renderer.open_group(__name__)\r\n   1186 \r\n-> 1187         ticks_to_draw = self._update_ticks(renderer)\r\n   1188         ticklabelBoxes, ticklabelBoxes2 = self._get_tick_bboxes(ticks_to_draw,\r\n   1189                                                                 renderer)\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in _update_ticks(self, renderer)\r\n   1023 \r\n   1024         interval = self.get_view_interval()\r\n-> 1025         tick_tups = list(self.iter_ticks())  # iter_ticks calls the locator\r\n   1026         if self._smart_bounds and tick_tups:\r\n   1027             # handle inverted limits\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in iter_ticks(self)\r\n    966         Iterate through all of the major and minor ticks.\r\n    967         \"\"\"\r\n--> 968         majorLocs = self.major.locator()\r\n    969         majorTicks = self.get_major_ticks(len(majorLocs))\r\n    970         self.major.formatter.set_locs(majorLocs)\r\n\r\nTypeError: __call__() missing 1 required positional argument: 'x'\r\n\r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n/usr/local/lib/python3.5/dist-packages/IPython/core/formatters.py in __call__(self, obj)\r\n    339                 pass\r\n    340             else:\r\n--> 341                 return printer(obj)\r\n    342             # Finally look for special method names\r\n    343             method = get_real_method(obj, self.print_method)\r\n\r\n/usr/local/lib/python3.5/dist-packages/IPython/core/pylabtools.py in <lambda>(fig)\r\n    236 \r\n    237     if 'png' in formats:\r\n--> 238         png_formatter.for_type(Figure, lambda fig: print_figure(fig, 'png', **kwargs))\r\n    239     if 'retina' in formats or 'png2x' in formats:\r\n    240         png_formatter.for_type(Figure, lambda fig: retina_figure(fig, **kwargs))\r\n\r\n/usr/local/lib/python3.5/dist-packages/IPython/core/pylabtools.py in print_figure(fig, fmt, bbox_inches, **kwargs)\r\n    120 \r\n    121     bytes_io = BytesIO()\r\n--> 122     fig.canvas.print_figure(bytes_io, **kw)\r\n    123     data = bytes_io.getvalue()\r\n    124     if fmt == 'svg':\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backend_bases.py in print_figure(self, filename, dpi, facecolor, edgecolor, orientation, format, **kwargs)\r\n   2208                     orientation=orientation,\r\n   2209                     dryrun=True,\r\n-> 2210                     **kwargs)\r\n   2211                 renderer = self.figure._cachedRenderer\r\n   2212                 bbox_inches = self.figure.get_tightbbox(renderer)\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backends/backend_agg.py in print_png(self, filename_or_obj, *args, **kwargs)\r\n    509 \r\n    510     def print_png(self, filename_or_obj, *args, **kwargs):\r\n--> 511         FigureCanvasAgg.draw(self)\r\n    512         renderer = self.get_renderer()\r\n    513         original_dpi = renderer.dpi\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backends/backend_agg.py in draw(self)\r\n    429             # if toolbar:\r\n    430             #     toolbar.set_cursor(cursors.WAIT)\r\n--> 431             self.figure.draw(self.renderer)\r\n    432             # A GUI class may be need to update a window using this draw, so\r\n    433             # don't forget to call the superclass.\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/figure.py in draw(self, renderer)\r\n   1473 \r\n   1474             mimage._draw_list_compositing_images(\r\n-> 1475                 renderer, self, artists, self.suppressComposite)\r\n   1476 \r\n   1477             renderer.close_group('figure')\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/image.py in _draw_list_compositing_images(renderer, parent, artists, suppress_composite)\r\n    139     if not_composite or not has_images:\r\n    140         for a in artists:\r\n--> 141             a.draw(renderer)\r\n    142     else:\r\n    143         # Composite any adjacent images together\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axes/_base.py in draw(self, renderer, inframe)\r\n   2605             renderer.stop_rasterizing()\r\n   2606 \r\n-> 2607         mimage._draw_list_compositing_images(renderer, self, artists)\r\n   2608 \r\n   2609         renderer.close_group('axes')\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/image.py in _draw_list_compositing_images(renderer, parent, artists, suppress_composite)\r\n    139     if not_composite or not has_images:\r\n    140         for a in artists:\r\n--> 141             a.draw(renderer)\r\n    142     else:\r\n    143         # Composite any adjacent images together\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in draw(self, renderer, *args, **kwargs)\r\n   1185         renderer.open_group(__name__)\r\n   1186 \r\n-> 1187         ticks_to_draw = self._update_ticks(renderer)\r\n   1188         ticklabelBoxes, ticklabelBoxes2 = self._get_tick_bboxes(ticks_to_draw,\r\n   1189                                                                 renderer)\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in _update_ticks(self, renderer)\r\n   1023 \r\n   1024         interval = self.get_view_interval()\r\n-> 1025         tick_tups = list(self.iter_ticks())  # iter_ticks calls the locator\r\n   1026         if self._smart_bounds and tick_tups:\r\n   1027             # handle inverted limits\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in iter_ticks(self)\r\n    966         Iterate through all of the major and minor ticks.\r\n    967         \"\"\"\r\n--> 968         majorLocs = self.major.locator()\r\n    969         majorTicks = self.get_major_ticks(len(majorLocs))\r\n    970         self.major.formatter.set_locs(majorLocs)\r\n\r\nTypeError: __call__() missing 1 required positional argument: 'x'\r\n\r\n<Figure size 1080x720 with 1 Axes>\r\n```\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\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\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: Ubuntu 16.04\r\n  * Matplotlib version: 2.2.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): module://ipykernel.pylab.backend_inline\r\n  * Python version: 3.5.2 (IPython 6.2.1)\r\n  * Jupyter version (if applicable): Jupyter Lab beta 0.31.8\r\n\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\n",
        "issue_id": 10769,
        "pr_number": 10772,
        "pr_title": "API: check locator and formatter args when passed",
        "pr_body": "## PR Summary\r\n\r\nRight now, `ax.set_major_formatter` and `ax.set_major_locator` throw pretty deep error messages if the wrong type of data is passed to them.  This catches at entry. \r\n\r\nCloses #10769\r\n\r\n```python\r\nimport matplotlib\r\nimport matplotlib.pyplot as plt\r\n\r\nf, ax = plt.subplots(1, 1, figsize=(15, 10))\r\nplt.plot([10**4, 11*10**4], [100, 150])\r\nax.xaxis.set_major_formatter(matplotlib.ticker.LogLocator())\r\nplt.show()\r\n```\r\nNow returns:\r\n```\r\nTraceback (most recent call last):\r\n  File \"testEngTicker.py\", line 6, in <module>\r\n    ax.xaxis.set_major_formatter(matplotlib.ticker.LogLocator())\r\n  File \"/Users/jklymak/matplotlib/lib/matplotlib/axis.py\", line 1573, in set_major_formatter\r\n    \"formatter argument must be matplotlib.ticker.Formatter\")\r\nValueError: formatter argument must be matplotlib.ticker.Formatter\r\n```\r\ninstead of something down in the bowels of drawing the ticker...\r\n\r\n## PR Checklist\r\n\r\n- [x] Code is PEP 8 compliant\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-03-14T06:41:19Z",
        "base_commit": "8af1fac8baf9bbf06160d8a91575d3d6d8fdca04"
      },
      "summary": "### Summary:\nThis issue is related to the improper use of the `matplotlib.ticker.EngFormatter` as a locator instead of a formatter in the Matplotlib library. The problem arises when attempting to set the `EngFormatter` as a major locator on an axis, which is not its intended use. This misconfiguration leads to a `TypeError` because the `EngFormatter` lacks the required callable behavior expected from a locator.\n\n1. **Problem Description in General Terms:** The issue involves a type mismatch error when using Matplotlib's `EngFormatter` in a context where a locator is expected. The `EngFormatter` is mistakenly used to set the major locator for axis ticks, leading to execution failure.\n\n2. **Key Symptoms and Behaviors Observed:** The main symptom is a `TypeError` indicating a missing required positional argument, which occurs during the rendering of a plot. This error arises when the code attempts to iterate through ticks using the `iter_ticks` method, expecting a locator object with callable functionality, which `EngFormatter` does not provide.\n\n3. **Affected Components or Systems:** The components affected are Matplotlib's axis and ticker functionalities, specifically within the `set_major_locator` and `iter_ticks` methods in the `axis.py` module. The error impacts plotting operations that necessitate correct tick location setting.\n\n4. **Potential Impact or Severity:** The impact of this issue is significant for users attempting to customize tick formatting in plots. It prevents the successful rendering of plots, potentially disrupting data visualization tasks that rely on precise tick formatting and location.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:** In technical terms, the issue stems from incorrect API usage where a formatter is set in place of a locator, leading to method invocation failures. The fix involves ensuring that only valid locator objects are assigned to the axis locator properties, thereby preventing type-related execution errors.",
      "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: DOC: set_major_locator could check that its getting a Locator (was EngFormatter broken?)\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`matplotlib.ticker.EngFormatter` seems to be broken:\r\n\r\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n```\r\nf, ax = plt.subplots(1, 1, figsize=(15, 10))\r\nplt.plot([10**4, 11*10**4], [100, 150])\r\nax.xaxis.set_major_locator(matplotlib.ticker.EngFormatter())\r\n```\r\n```\r\nError in callback <function install_repl_displayhook.<locals>.post_execute at 0x7f60a9b120d0> (for post_execute):\r\n\r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/pyplot.py in post_execute()\r\n    147             def post_execute():\r\n    148                 if matplotlib.is_interactive():\r\n--> 149                     draw_all()\r\n    150 \r\n    151             # IPython >= 2\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/_pylab_helpers.py in draw_all(cls, force)\r\n    134         for f_mgr in cls.get_all_fig_managers():\r\n    135             if force or f_mgr.canvas.figure.stale:\r\n--> 136                 f_mgr.canvas.draw_idle()\r\n    137 \r\n    138 atexit.register(Gcf.destroy_all)\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backend_bases.py in draw_idle(self, *args, **kwargs)\r\n   2053         if not self._is_idle_drawing:\r\n   2054             with self._idle_draw_cntx():\r\n-> 2055                 self.draw(*args, **kwargs)\r\n   2056 \r\n   2057     def draw_cursor(self, event):\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backends/backend_agg.py in draw(self)\r\n    429             # if toolbar:\r\n    430             #     toolbar.set_cursor(cursors.WAIT)\r\n--> 431             self.figure.draw(self.renderer)\r\n    432             # A GUI class may be need to update a window using this draw, so\r\n    433             # don't forget to call the superclass.\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/figure.py in draw(self, renderer)\r\n   1473 \r\n   1474             mimage._draw_list_compositing_images(\r\n-> 1475                 renderer, self, artists, self.suppressComposite)\r\n   1476 \r\n   1477             renderer.close_group('figure')\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/image.py in _draw_list_compositing_images(renderer, parent, artists, suppress_composite)\r\n    139     if not_composite or not has_images:\r\n    140         for a in artists:\r\n--> 141             a.draw(renderer)\r\n    142     else:\r\n    143         # Composite any adjacent images together\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axes/_base.py in draw(self, renderer, inframe)\r\n   2605             renderer.stop_rasterizing()\r\n   2606 \r\n-> 2607         mimage._draw_list_compositing_images(renderer, self, artists)\r\n   2608 \r\n   2609         renderer.close_group('axes')\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/image.py in _draw_list_compositing_images(renderer, parent, artists, suppress_composite)\r\n    139     if not_composite or not has_images:\r\n    140         for a in artists:\r\n--> 141             a.draw(renderer)\r\n    142     else:\r\n    143         # Composite any adjacent images together\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in draw(self, renderer, *args, **kwargs)\r\n   1185         renderer.open_group(__name__)\r\n   1186 \r\n-> 1187         ticks_to_draw = self._update_ticks(renderer)\r\n   1188         ticklabelBoxes, ticklabelBoxes2 = self._get_tick_bboxes(ticks_to_draw,\r\n   1189                                                                 renderer)\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in _update_ticks(self, renderer)\r\n   1023 \r\n   1024         interval = self.get_view_interval()\r\n-> 1025         tick_tups = list(self.iter_ticks())  # iter_ticks calls the locator\r\n   1026         if self._smart_bounds and tick_tups:\r\n   1027             # handle inverted limits\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in iter_ticks(self)\r\n    966         Iterate through all of the major and minor ticks.\r\n    967         \"\"\"\r\n--> 968         majorLocs = self.major.locator()\r\n    969         majorTicks = self.get_major_ticks(len(majorLocs))\r\n    970         self.major.formatter.set_locs(majorLocs)\r\n\r\nTypeError: __call__() missing 1 required positional argument: 'x'\r\n\r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n/usr/local/lib/python3.5/dist-packages/IPython/core/formatters.py in __call__(self, obj)\r\n    339                 pass\r\n    340             else:\r\n--> 341                 return printer(obj)\r\n    342             # Finally look for special method names\r\n    343             method = get_real_method(obj, self.print_method)\r\n\r\n/usr/local/lib/python3.5/dist-packages/IPython/core/pylabtools.py in <lambda>(fig)\r\n    236 \r\n    237     if 'png' in formats:\r\n--> 238         png_formatter.for_type(Figure, lambda fig: print_figure(fig, 'png', **kwargs))\r\n    239     if 'retina' in formats or 'png2x' in formats:\r\n    240         png_formatter.for_type(Figure, lambda fig: retina_figure(fig, **kwargs))\r\n\r\n/usr/local/lib/python3.5/dist-packages/IPython/core/pylabtools.py in print_figure(fig, fmt, bbox_inches, **kwargs)\r\n    120 \r\n    121     bytes_io = BytesIO()\r\n--> 122     fig.canvas.print_figure(bytes_io, **kw)\r\n    123     data = bytes_io.getvalue()\r\n    124     if fmt == 'svg':\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backend_bases.py in print_figure(self, filename, dpi, facecolor, edgecolor, orientation, format, **kwargs)\r\n   2208                     orientation=orientation,\r\n   2209                     dryrun=True,\r\n-> 2210                     **kwargs)\r\n   2211                 renderer = self.figure._cachedRenderer\r\n   2212                 bbox_inches = self.figure.get_tightbbox(renderer)\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backends/backend_agg.py in print_png(self, filename_or_obj, *args, **kwargs)\r\n    509 \r\n    510     def print_png(self, filename_or_obj, *args, **kwargs):\r\n--> 511         FigureCanvasAgg.draw(self)\r\n    512         renderer = self.get_renderer()\r\n    513         original_dpi = renderer.dpi\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/backends/backend_agg.py in draw(self)\r\n    429             # if toolbar:\r\n    430             #     toolbar.set_cursor(cursors.WAIT)\r\n--> 431             self.figure.draw(self.renderer)\r\n    432             # A GUI class may be need to update a window using this draw, so\r\n    433             # don't forget to call the superclass.\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/figure.py in draw(self, renderer)\r\n   1473 \r\n   1474             mimage._draw_list_compositing_images(\r\n-> 1475                 renderer, self, artists, self.suppressComposite)\r\n   1476 \r\n   1477             renderer.close_group('figure')\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/image.py in _draw_list_compositing_images(renderer, parent, artists, suppress_composite)\r\n    139     if not_composite or not has_images:\r\n    140         for a in artists:\r\n--> 141             a.draw(renderer)\r\n    142     else:\r\n    143         # Composite any adjacent images together\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axes/_base.py in draw(self, renderer, inframe)\r\n   2605             renderer.stop_rasterizing()\r\n   2606 \r\n-> 2607         mimage._draw_list_compositing_images(renderer, self, artists)\r\n   2608 \r\n   2609         renderer.close_group('axes')\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/image.py in _draw_list_compositing_images(renderer, parent, artists, suppress_composite)\r\n    139     if not_composite or not has_images:\r\n    140         for a in artists:\r\n--> 141             a.draw(renderer)\r\n    142     else:\r\n    143         # Composite any adjacent images together\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/artist.py in draw_wrapper(artist, renderer, *args, **kwargs)\r\n     53                 renderer.start_filter()\r\n     54 \r\n---> 55             return draw(artist, renderer, *args, **kwargs)\r\n     56         finally:\r\n     57             if artist.get_agg_filter() is not None:\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in draw(self, renderer, *args, **kwargs)\r\n   1185         renderer.open_group(__name__)\r\n   1186 \r\n-> 1187         ticks_to_draw = self._update_ticks(renderer)\r\n   1188         ticklabelBoxes, ticklabelBoxes2 = self._get_tick_bboxes(ticks_to_draw,\r\n   1189                                                                 renderer)\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in _update_ticks(self, renderer)\r\n   1023 \r\n   1024         interval = self.get_view_interval()\r\n-> 1025         tick_tups = list(self.iter_ticks())  # iter_ticks calls the locator\r\n   1026         if self._smart_bounds and tick_tups:\r\n   1027             # handle inverted limits\r\n\r\n/usr/local/lib/python3.5/dist-packages/matplotlib/axis.py in iter_ticks(self)\r\n    966         Iterate through all of the major and minor ticks.\r\n    967         \"\"\"\r\n--> 968         majorLocs = self.major.locator()\r\n    969         majorTicks = self.get_major_ticks(len(majorLocs))\r\n    970         self.major.formatter.set_locs(majorLocs)\r\n\r\nTypeError: __call__() missing 1 required positional argument: 'x'\r\n\r\n<Figure size 1080x720 with 1 Axes>\r\n```\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\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\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: Ubuntu 16.04\r\n  * Matplotlib version: 2.2.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): module://ipykernel.pylab.backend_inline\r\n  * Python version: 3.5.2 (IPython 6.2.1)\r\n  * Jupyter version (if applicable): Jupyter Lab beta 0.31.8\r\n\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/axis.py\n  function: Axis.set_major_formatter\n  function: Axis.set_minor_formatter\n  function: Axis.set_major_locator\n  function: Axis.set_minor_locator\n"
    },
    {
      "similar_issue": {
        "issue_title": "Remove()ing a shared axes prevents the remaining axes from using unit-provided formatters",
        "issue_body": "Consider\r\n```\r\nfrom pylab import *\r\nfrom datetime import date\r\n\r\nfig, axs = plt.subplots(1, 2, sharex=True)\r\naxs[1].remove()\r\naxs[0].plot([date(2000, 1, 1), date(2000, 2, 1)], [0, 1])\r\nplt.show()\r\n```\r\n\r\nOne gets\r\n![test](https://user-images.githubusercontent.com/1322974/48794454-4c3f5c00-ecfa-11e8-9e1f-83ff6015782c.png)\r\n\r\ni.e. the call to `axs[1].remove()` prevented the axs[0] from acquiring the correct tick formatter and locator.\r\n\r\nInterestingly, using `fig.delaxes(axs[1])` doesn't exhibit the same bug.\r\n\r\nLooks like the problem comes from\r\n```\r\n    def _remove_ax(self, ax):\r\n        def _reset_loc_form(axis):\r\n            axis.set_major_formatter(axis.get_major_formatter())\r\n            axis.set_major_locator(axis.get_major_locator())\r\n            axis.set_minor_formatter(axis.get_minor_formatter())\r\n            axis.set_minor_locator(axis.get_minor_locator())\r\n\r\n        def _break_share_link(ax, grouper):\r\n            siblings = grouper.get_siblings(ax)\r\n            if len(siblings) > 1:\r\n                grouper.remove(ax)\r\n                for last_ax in siblings:\r\n                    if ax is not last_ax:\r\n                        return last_ax\r\n            return None\r\n\r\n        self.delaxes(ax)\r\n        last_ax = _break_share_link(ax, ax._shared_y_axes)\r\n        if last_ax is not None:\r\n            _reset_loc_form(last_ax.yaxis)\r\n\r\n        last_ax = _break_share_link(ax, ax._shared_x_axes)\r\n        if last_ax is not None:\r\n            _reset_loc_form(last_ax.xaxis)\r\n```\r\nwhere the call to `set_major_formatter` (etc.), which basically call `formatter.set_axis(axis)` (to update the axis seen by the formatter) also make Matplotlib believe that we had a user-provided formatter (isDefault_majloc = False, etc.) which should not be overridden by the unit framework.\r\n\r\nmpl master (ca. 3.0.2)",
        "issue_id": 12853,
        "pr_number": 13983,
        "pr_title": "Fix locator/formatter setting when removing shared Axes",
        "pr_body": "When a shared Axes was removed from a plot, any other Axes it was shared with had their Axis locators/formatters set to the locator/formatter on the removed Axes. This PR makes sure that setting only happens if the locator/formatter has previously been manually set. This allows the locator/formatter to be automatically set in the future by e.g. units being plotted.\r\n\r\n\r\nFixes  #12853",
        "issue_closed_at": "2019-04-20T20:29:01Z",
        "base_commit": "76db50151a65927c19c83a8c3c195c87dbcc0556"
      },
      "summary": "### Summary:\n\nThis issue pertains to the behavior of shared axes in Matplotlib, a plotting library in Python, when one of the axes is removed. In general terms, the problem arises when removing a shared axis from a set of subplots, which inadvertently prevents the remaining axes from utilizing unit-provided formatters for their tick marks. \n\nKey symptoms include the remaining axis not displaying the correct tick format after the removal of its counterpart. This anomaly occurs specifically when using the `remove()` method on one of the axes. Conversely, using the alternative method `fig.delaxes()` does not trigger the same issue, indicating a discrepancy between these two approaches.\n\nThe components affected are primarily within the axis configuration of Matplotlib, specifically the mechanisms responsible for managing shared axes and their formatters. This includes functions related to setting and resetting major and minor formatters and locators, which are key to determining how axis ticks are displayed.\n\nThe potential impact of this issue is significant for users who rely on shared axes for their plots, as it may lead to incorrect or unexpected plotting results, thereby affecting data visualization accuracy and interpretability.\n\nRelevant technical details abstracted for broader understanding include the interaction between axis formatters and the unit framework within Matplotlib. The problem lies in the way Matplotlib handles formatter assignments, mistakenly interpreting them as user-defined, which subsequently prevents the default unit framework from overriding them as intended. This behavior is observed in Matplotlib version 3.0.2 and potentially affects subsequent versions until resolved. \n\nThe problem was addressed by modifying code elements in `lib/matplotlib/axis.py` and `lib/matplotlib/figure.py`, specifically functions related to axis formatting and subplot creation, to ensure consistent behavior regardless of how axes are removed.",
      "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: Remove()ing a shared axes prevents the remaining axes from using unit-provided formatters\n\nBody:\nConsider\r\n```\r\nfrom pylab import *\r\nfrom datetime import date\r\n\r\nfig, axs = plt.subplots(1, 2, sharex=True)\r\naxs[1].remove()\r\naxs[0].plot([date(2000, 1, 1), date(2000, 2, 1)], [0, 1])\r\nplt.show()\r\n```\r\n\r\nOne gets\r\n![test](https://user-images.githubusercontent.com/1322974/48794454-4c3f5c00-ecfa-11e8-9e1f-83ff6015782c.png)\r\n\r\ni.e. the call to `axs[1].remove()` prevented the axs[0] from acquiring the correct tick formatter and locator.\r\n\r\nInterestingly, using `fig.delaxes(axs[1])` doesn't exhibit the same bug.\r\n\r\nLooks like the problem comes from\r\n```\r\n    def _remove_ax(self, ax):\r\n        def _reset_loc_form(axis):\r\n            axis.set_major_formatter(axis.get_major_formatter())\r\n            axis.set_major_locator(axis.get_major_locator())\r\n            axis.set_minor_formatter(axis.get_minor_formatter())\r\n            axis.set_minor_locator(axis.get_minor_locator())\r\n\r\n        def _break_share_link(ax, grouper):\r\n            siblings = grouper.get_siblings(ax)\r\n            if len(siblings) > 1:\r\n                grouper.remove(ax)\r\n                for last_ax in siblings:\r\n                    if ax is not last_ax:\r\n                        return last_ax\r\n            return None\r\n\r\n        self.delaxes(ax)\r\n        last_ax = _break_share_link(ax, ax._shared_y_axes)\r\n        if last_ax is not None:\r\n            _reset_loc_form(last_ax.yaxis)\r\n\r\n        last_ax = _break_share_link(ax, ax._shared_x_axes)\r\n        if last_ax is not None:\r\n            _reset_loc_form(last_ax.xaxis)\r\n```\r\nwhere the call to `set_major_formatter` (etc.), which basically call `formatter.set_axis(axis)` (to update the axis seen by the formatter) also make Matplotlib believe that we had a user-provided formatter (isDefault_majloc = False, etc.) which should not be overridden by the unit framework.\r\n\r\nmpl master (ca. 3.0.2)\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/axis.py\n  function: Axis.set_major_formatter\n\nlib/matplotlib/figure.py\n  function: Figure.subplots\n"
    },
    {
      "similar_issue": {
        "issue_title": "Colorbar outline has broken path in vector backends",
        "issue_body": "Hi again,\nIn all of the vector graphics backends that I tested (pdf, eps, ps, svg), the colorbar outline is drawn with a broken path at the corner where the path starts and ends.  This does not happen with the raster graphic or interactive backends.  Here is a minimal working example:\n\n``` python\nimport numpy as np\nimport matplotlib as mpl\nimport matplotlib.pyplot as plt\n\nmpl.rcParams.update({'axes.linewidth':10})\n\nfig = plt.figure(figsize=(8,6))\nax1 = fig.add_axes([0.05, 0.85, 0.9, 0.1])\nax2 = fig.add_axes([0.05, 0.65, 0.9, 0.1])\nax3 = fig.add_axes([0.05, 0.45, 0.9, 0.1])\nax4 = fig.add_axes([0.05, 0.25, 0.9, 0.1])\nax5 = fig.add_axes([0.05, 0.05, 0.9, 0.1])\n\ncmap = mpl.cm.jet\ncmap.set_under('w')\ncmap.set_over('w')\n\nim = ax1.pcolormesh(np.linspace(0,10,16).reshape((4,4)))\n\nplt.colorbar(im,cax=ax2,cmap=cmap,orientation='horizontal',\n             extend='both',extendfrac=0.5)\nplt.colorbar(im,cax=ax3,cmap=cmap,orientation='horizontal',\n             extend='both',)\nplt.colorbar(im,cax=ax4,cmap=cmap,orientation='horizontal',\n             extend='both',extendrect=True)\nplt.colorbar(im,cax=ax5,cmap=cmap,orientation='horizontal',\n             extend='neither')\n\nplt.savefig('colorbar_tip.pdf')\nplt.savefig('colorbar_tip.eps')\nplt.savefig('colorbar_tip.svg')\n```\n\nTested with matplotlib 1.4.3, and python 2.7, on Linux and Windows. I have exaggerated the axes linewidth to make the problem more visible.  Here is a screenshot of the PDF output:\n\n![colorbar_tip](https://cloud.githubusercontent.com/assets/8595627/6471312/c556da04-c1b7-11e4-8711-25ba893eb043.png)\n\nI have been able to fix this by making the following change to the `ColorbarBase` class in colorbar.py:\n\n``` python\ndef _config_axes(self, X, Y):\n\n    ...\n\n    if self.outline is not None:\n        self.outline.remove()\n\n    xy2 = np.append(xy,xy[1:2,:],axis=0) # <-- added\n\n    self.outline = mpatches.Polygon(\n        xy2, edgecolor=mpl.rcParams['axes.edgecolor'], # <-- modified\n        facecolor='none',\n        linewidth=mpl.rcParams['axes.linewidth'],\n        closed=True,\n        zorder=2)\n\n    ...\n```\n\nThis essentially just copies the second point of the path to the end of the path.  However, I don't know if this is the best fix.  I don't know anything about vector graphics drawing directives, but it seems to me that there should be a builtin function to have paths wrap-around enough so that it creates a closed loop, including drawing the correct corner.  Clearly the `closed=True` option of the `mpatches.Polygon` is not doing this.\n\nAgain, thanks to anyone who looks into this.\n",
        "issue_id": 4185,
        "pr_number": 4186,
        "pr_title": "Close clipped paths",
        "pr_body": "Fix #4185.\n",
        "issue_closed_at": "2015-03-04T22:48:51Z",
        "base_commit": "6387fcaaeeff4777373429a54d79ca270cbd2522"
      },
      "summary": "### Summary:\nThis issue is related to the rendering of colorbar outlines in vector graphics backends within the Matplotlib library. Specifically, when generating vector graphics files such as PDF, EPS, PS, and SVG, the colorbar outline appears with a broken path at the corner where the path starts and ends, resulting in an incomplete outline. This problem does not manifest in raster or interactive backends where the outline appears correctly. The issue was observed on both Linux and Windows platforms using Matplotlib version 1.4.3 and Python 2.7.\n\nKey symptoms include the visible discontinuity in the colorbar outline when saved as a vector file, which is exacerbated by increasing the axes linewidth. The affected components are the vector graphics backends of Matplotlib, particularly the `ColorbarBase` class within the `colorbar.py` module. The problem impacts the visual quality of vector graphics outputs, which could be significant for users requiring precise and professional quality graphics for publication or presentation purposes.\n\nA technical investigation revealed that appending the second point of the path to its end in the `ColorbarBase` class can resolve the issue, although this solution may not be optimal or in line with vector graphics standards. The problem seems to stem from the vector graphics path not closing properly despite the `closed=True` setting in the `mpatches.Polygon` function, indicating a possible deficiency in the handling of path closure within the library's vector rendering implementation.\n\nThe changes made to address this issue involved modifying the vector backend implementations, specifically functions within `backend_ps.py` and `backend_svg.py`, to ensure proper path closure and rendering of colorbar outlines in vector outputs.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Colorbar outline has broken path in vector backends\n\nBody:\nHi again,\nIn all of the vector graphics backends that I tested (pdf, eps, ps, svg), the colorbar outline is drawn with a broken path at the corner where the path starts and ends.  This does not happen with the raster graphic or interactive backends.  Here is a minimal working example:\n\n``` python\nimport numpy as np\nimport matplotlib as mpl\nimport matplotlib.pyplot as plt\n\nmpl.rcParams.update({'axes.linewidth':10})\n\nfig = plt.figure(figsize=(8,6))\nax1 = fig.add_axes([0.05, 0.85, 0.9, 0.1])\nax2 = fig.add_axes([0.05, 0.65, 0.9, 0.1])\nax3 = fig.add_axes([0.05, 0.45, 0.9, 0.1])\nax4 = fig.add_axes([0.05, 0.25, 0.9, 0.1])\nax5 = fig.add_axes([0.05, 0.05, 0.9, 0.1])\n\ncmap = mpl.cm.jet\ncmap.set_under('w')\ncmap.set_over('w')\n\nim = ax1.pcolormesh(np.linspace(0,10,16).reshape((4,4)))\n\nplt.colorbar(im,cax=ax2,cmap=cmap,orientation='horizontal',\n             extend='both',extendfrac=0.5)\nplt.colorbar(im,cax=ax3,cmap=cmap,orientation='horizontal',\n             extend='both',)\nplt.colorbar(im,cax=ax4,cmap=cmap,orientation='horizontal',\n             extend='both',extendrect=True)\nplt.colorbar(im,cax=ax5,cmap=cmap,orientation='horizontal',\n             extend='neither')\n\nplt.savefig('colorbar_tip.pdf')\nplt.savefig('colorbar_tip.eps')\nplt.savefig('colorbar_tip.svg')\n```\n\nTested with matplotlib 1.4.3, and python 2.7, on Linux and Windows. I have exaggerated the axes linewidth to make the problem more visible.  Here is a screenshot of the PDF output:\n\n![colorbar_tip](https://cloud.githubusercontent.com/assets/8595627/6471312/c556da04-c1b7-11e4-8711-25ba893eb043.png)\n\nI have been able to fix this by making the following change to the `ColorbarBase` class in colorbar.py:\n\n``` python\ndef _config_axes(self, X, Y):\n\n    ...\n\n    if self.outline is not None:\n        self.outline.remove()\n\n    xy2 = np.append(xy,xy[1:2,:],axis=0) # <-- added\n\n    self.outline = mpatches.Polygon(\n        xy2, edgecolor=mpl.rcParams['axes.edgecolor'], # <-- modified\n        facecolor='none',\n        linewidth=mpl.rcParams['axes.linewidth'],\n        closed=True,\n        zorder=2)\n\n    ...\n```\n\nThis essentially just copies the second point of the path to the end of the path.  However, I don't know if this is the best fix.  I don't know anything about vector graphics drawing directives, but it seems to me that there should be a builtin function to have paths wrap-around enough so that it creates a closed loop, including drawing the correct corner.  Clearly the `closed=True` option of the `mpatches.Polygon` is not doing this.\n\nAgain, thanks to anyone who looks into this.\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_ps.py\n  function: print_figure_impl\n  function: NullWriter.write\n\nlib/matplotlib/backends/backend_svg.py\n  function: RendererSVG._write_default_style\n"
    },
    {
      "similar_issue": {
        "issue_title": "make TeXManager more user-configurable",
        "issue_body": "### Bug report\r\n\r\nMatplotlib cannot be used with the LaTeX font NewTX. Matplotlib loads the LaTeX `texcomp` package, without any options, while the `newtxtext` package requires the `full` option.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\nfrom matplotlib import rc\r\n\r\nrc('text', usetex=True)\r\nrc('mathtext', fontset='custom')\r\nrc('text.latex', preamble=r'\\usepackage{newtxtext}\\usepackage{newtxmath}')\r\n\r\nx = np.linspace(0, 10, 100)\r\nplt.plot(x, np.sin(x))\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n! LaTeX Error: Option clash for package textcomp.\r\n```\r\n\r\n**Expected outcome**\r\n\r\nTo be able to use the newtxtex package. Maybe to have the ability to override the default packages or set their options in some ways.\r\n\r\n**Matplotlib version**\r\n\r\n  * Operating System: Debian GNU/Linux 8\r\n  * Matplotlib Version: 2.0\r\n  * Python Version: 3.5\r\n\r\nInstalled matplotlib as Debian package.\r\n",
        "issue_id": 9118,
        "pr_number": 17569,
        "pr_title": "Delay \\usepackage{textcomp} until after the custom tex preamble.",
        "pr_body": "... and only load textcomp if it hasn't already been loaded.  This\r\navoids option clashes in case the custom preamble loads textcomp with\r\nother options.\r\n\r\nCloses #9118.  Simpler than to #17563, I guess.\r\n\r\n## PR Summary\r\n\r\n## PR Checklist\r\n\r\n- [ ] Has Pytest style unit tests\r\n- [ ] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/api_changes.rst if API changed in a backward-incompatible way\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Do not create the PR out of master, but out of a separate branch.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->\r\n",
        "issue_closed_at": "2020-06-17T16:23:11Z",
        "base_commit": "89fa0e43b63512c595387a37bdfd37196ced69be"
      },
      "summary": "### Summary:\nThis issue pertains to the configurability of the TeXManager component within the Matplotlib library, specifically regarding the integration of LaTeX fonts. The problem arises because Matplotlib, by default, loads the LaTeX `texcomp` package without any options, which conflicts with the `newtxtext` package that requires a specific option (`full`). This results in an option clash error when users attempt to customize their plots using the `newtxtext` font package.\n\nKey symptoms include the inability to use certain LaTeX font packages with Matplotlib, resulting in LaTeX errors that prevent successful rendering of plots using these fonts. The error message encountered is \"Option clash for package textcomp,\" which indicates a conflict in package options during LaTeX compilation.\n\nThe affected component is the TeXManager within Matplotlib, particularly the methods responsible for managing LaTeX preamble settings and font configurations. This issue impacts users who rely on specific LaTeX fonts for their visualizations, potentially limiting the flexibility and aesthetic customization of plots.\n\nThe severity of the issue can be considered moderate, as it hinders the ability to use certain fonts and could disrupt workflows for users who depend on these customizations. The technical solution involves making the TeXManager more user-configurable, allowing users to override default package settings and specify necessary options for LaTeX packages.\n\nIn terms of technical details, the resolution involves updates to the `TexManager.get_font_config` and `TexManager._get_preamble` functions, enabling them to accommodate user-defined LaTeX package options and configurations, thus preventing option clashes and improving overall usability.",
      "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: make TeXManager more user-configurable\n\nBody:\n### Bug report\r\n\r\nMatplotlib cannot be used with the LaTeX font NewTX. Matplotlib loads the LaTeX `texcomp` package, without any options, while the `newtxtext` package requires the `full` option.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\nfrom matplotlib import rc\r\n\r\nrc('text', usetex=True)\r\nrc('mathtext', fontset='custom')\r\nrc('text.latex', preamble=r'\\usepackage{newtxtext}\\usepackage{newtxmath}')\r\n\r\nx = np.linspace(0, 10, 100)\r\nplt.plot(x, np.sin(x))\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n! LaTeX Error: Option clash for package textcomp.\r\n```\r\n\r\n**Expected outcome**\r\n\r\nTo be able to use the newtxtex package. Maybe to have the ability to override the default packages or set their options in some ways.\r\n\r\n**Matplotlib version**\r\n\r\n  * Operating System: Debian GNU/Linux 8\r\n  * Matplotlib Version: 2.0\r\n  * Python Version: 3.5\r\n\r\nInstalled matplotlib as Debian package.\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/texmanager.py\n  function: TexManager.get_font_config\n  function: TexManager._get_preamble\n"
    },
    {
      "similar_issue": {
        "issue_title": "Off-by-one bug in annual axis labels when localized time crosses year boundary",
        "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\nWhen plotting dates with time zone information on the x-axis, under certain circumstances, the wrong year will be displayed as the label.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport pytz\r\nfrom datetime import datetime, timedelta\r\n\r\nx = [datetime(2010, 1, 1, tzinfo=pytz.timezone('America/New_York')) + timedelta(i) for i in range(2000)]\r\nplt.plot(x, [0] * len(x));\r\n```\r\n\r\n**Actual outcome**\r\n\r\nThe first label on the plot is 2009.\r\n\r\n**Expected outcome**\r\n\r\nThe first label on the plot is 2010.\r\n\r\n**Matplotlib version**\r\n\r\nBuilt this morning from master. Also confirmed the issue on 3.0.0 and confirmed that 2.2.2 does not have the issue (or at least not with the reproduction steps I found.)\r\n\r\n  * Operating system: Debian 7.11\r\n  * Matplotlib version: from source\r\n  * Matplotlib backend module://ipykernel.pylab.backend_inline\r\n  * Python version: 3.7.0\r\n  * Jupyter version (if applicable): 4.4.0\r\n  * Other libraries: pytz 2018.5\r\n\r\nI built matplotlib from source to verify that this bug affects master. The checks against 3.0.0 and 2.2.2 were done on a conda install of those versions and may have had different versions of pytz and jupyter.",
        "issue_id": 12675,
        "pr_number": 12678,
        "pr_title": "FIX: properly set tz for YearLocator",
        "pr_body": "## PR Summary\r\n\r\n`dates.YearLocator` was not always being called with the timezone info.  Now it is...\r\n\r\nCloses #12675:\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport pytz\r\nfrom datetime import datetime, timedelta, timezone\r\n\r\nx = [datetime(2010, 1, 1).astimezone(pytz.timezone('America/New_York')) + timedelta(i) for i in range(2000)]\r\nplt.plot(x, [0] * len(x));\r\nplt.show()\r\n```\r\n\r\nNow has the first tick at 2010 instead of 2009....\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-01-28T20:12:28Z",
        "base_commit": "c22847b0ce518be6b58908f5dacf946c92855168"
      },
      "summary": "### Summary:\nThis issue is related to an off-by-one error that occurs when plotting time series data with timezone information on a date axis using the Matplotlib library. Specifically, when the plotted dates span a transition between years, the year label displayed at the start of the plot is incorrect. This problem is evident when using localized times that cross the boundary into a new year, leading to the display of the previous year on the x-axis label.\n\n1. **Problem Description in General Terms:**\n   The problem involves incorrect date labeling on plots when handling localized time data that transitions across year boundaries. This mislabeling results in an off-by-one error where the year shown does not match the actual date.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - When plotting dates with timezone information, the first label on the x-axis displays the incorrect year.\n   - The expected label should reflect the start of the year, but instead, it shows the previous year.\n\n3. **Affected Components or Systems:**\n   - The issue affects the Matplotlib library, specifically the date handling and labeling functions.\n   - The problem arises in various functions responsible for date conversion, locator determination, and tick value calculation.\n\n4. **Potential Impact or Severity:**\n   - This bug can lead to misleading data visualizations, especially in time series analysis where accurate date representation is critical.\n   - It can affect users who rely on Matplotlib for plotting localized time data, potentially leading to incorrect interpretations of the plotted data.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The issue is introduced in newer versions of Matplotlib (3.0.0 and master branch) and was not present in older versions (such as 2.2.2).\n   - The problem is confirmed to occur when using the 'America/New_York' timezone, but it may affect other timezones similarly.\n   - The resolution involves adjustments in key functions within `lib/matplotlib/dates.py`, addressing how date conversions and locator selections are handled to ensure correct year labeling across year transitions.",
      "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: Off-by-one bug in annual axis labels when localized time crosses year boundary\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\nWhen plotting dates with time zone information on the x-axis, under certain circumstances, the wrong year will be displayed as the label.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport pytz\r\nfrom datetime import datetime, timedelta\r\n\r\nx = [datetime(2010, 1, 1, tzinfo=pytz.timezone('America/New_York')) + timedelta(i) for i in range(2000)]\r\nplt.plot(x, [0] * len(x));\r\n```\r\n\r\n**Actual outcome**\r\n\r\nThe first label on the plot is 2009.\r\n\r\n**Expected outcome**\r\n\r\nThe first label on the plot is 2010.\r\n\r\n**Matplotlib version**\r\n\r\nBuilt this morning from master. Also confirmed the issue on 3.0.0 and confirmed that 2.2.2 does not have the issue (or at least not with the reproduction steps I found.)\r\n\r\n  * Operating system: Debian 7.11\r\n  * Matplotlib version: from source\r\n  * Matplotlib backend module://ipykernel.pylab.backend_inline\r\n  * Python version: 3.7.0\r\n  * Jupyter version (if applicable): 4.4.0\r\n  * Other libraries: pytz 2018.5\r\n\r\nI built matplotlib from source to verify that this bug affects master. The checks against 3.0.0 and 2.2.2 were done on a conda install of those versions and may have had different versions of pytz and jupyter.\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/dates.py\n  function: ConciseDateConverter.__init__\n  function: AutoDateLocator.get_locator\n  function: ConciseDateConverter.__init__\n  function: MicrosecondLocator.tick_values\n  function: YearLocator.autoscale\n"
    }
  ]
}