{
  "instance_id": "matplotlib__matplotlib-25079",
  "repo": "matplotlib/matplotlib",
  "created_at": "2023-01-25T15:24:44Z",
  "problem_statement": "[Bug]: Setting norm with existing colorbar fails with 3.6.3\n### Bug summary\r\n\r\nSetting the norm to a `LogNorm` after the colorbar has been created (e.g. in interactive code) fails with an `Invalid vmin` value in matplotlib 3.6.3.\r\n\r\nThe same code worked in previous matplotlib versions.\r\n\r\nNot that vmin and vmax are explicitly set to values valid for `LogNorm` and no negative values (or values == 0) exist in the input data.\r\n\r\n### Code for reproduction\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nfrom matplotlib.colors import LogNorm\r\nimport numpy as np\r\n\r\n# create some random data to fill a 2d plot\r\nrng = np.random.default_rng(0)\r\nimg = rng.uniform(1, 5, (25, 25))\r\n\r\n# plot it\r\nfig, ax = plt.subplots(layout=\"constrained\")\r\nplot = ax.pcolormesh(img)\r\ncbar = fig.colorbar(plot, ax=ax)\r\n\r\nvmin = 1\r\nvmax = 5\r\n\r\nplt.ion()\r\nfig.show()\r\nplt.pause(0.5)\r\n\r\nplot.norm = LogNorm(vmin, vmax)\r\nplot.autoscale()\r\nplt.pause(0.5)\r\n```\r\n\r\n\r\n### Actual outcome\r\n\r\n```\r\nTraceback (most recent call last):\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/backends/backend_qt.py\", line 454, in _draw_idle\r\n    self.draw()\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/backends/backend_agg.py\", line 405, in draw\r\n    self.figure.draw(self.renderer)\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/artist.py\", line 74, in draw_wrapper\r\n    result = draw(artist, renderer, *args, **kwargs)\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/artist.py\", line 51, in draw_wrapper\r\n    return draw(artist, renderer)\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/figure.py\", line 3082, in draw\r\n    mimage._draw_list_compositing_images(\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/image.py\", line 131, in _draw_list_compositing_images\r\n    a.draw(renderer)\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/artist.py\", line 51, in draw_wrapper\r\n    return draw(artist, renderer)\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/axes/_base.py\", line 3100, in draw\r\n    mimage._draw_list_compositing_images(\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/image.py\", line 131, in _draw_list_compositing_images\r\n    a.draw(renderer)\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/artist.py\", line 51, in draw_wrapper\r\n    return draw(artist, renderer)\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/collections.py\", line 2148, in draw\r\n    self.update_scalarmappable()\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/collections.py\", line 891, in update_scalarmappable\r\n    self._mapped_colors = self.to_rgba(self._A, self._alpha)\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/cm.py\", line 511, in to_rgba\r\n    x = self.norm(x)\r\n  File \"/home/mnoethe/.local/conda/envs/cta-dev/lib/python3.9/site-packages/matplotlib/colors.py\", line 1694, in __call__\r\n    raise ValueError(\"Invalid vmin or vmax\")\r\nValueError: Invalid vmin or vmax\r\n```\r\n\r\n### Expected outcome\r\n\r\nWorks, colorbar and mappable are updated with new norm.\r\n\r\n### Additional information\r\n\r\n_No response_\r\n\r\n### Operating system\r\n\r\nLinux\r\n\r\n### Matplotlib Version\r\n\r\n3.6.3 (works with 3.6.2)\r\n\r\n### Matplotlib Backend\r\n\r\nMultpiple backends tested, same error in all (Qt5Agg, TkAgg, agg, ...)\r\n\r\n### Python version\r\n\r\n3.9.15\r\n\r\n### Jupyter version\r\n\r\nnot in jupyter\r\n\r\n### Installation\r\n\r\nconda\n",
  "patch": "diff --git a/lib/matplotlib/colors.py b/lib/matplotlib/colors.py\n--- a/lib/matplotlib/colors.py\n+++ b/lib/matplotlib/colors.py\n@@ -1362,8 +1362,12 @@ def inverse(self, value):\n \n     def autoscale(self, A):\n         \"\"\"Set *vmin*, *vmax* to min, max of *A*.\"\"\"\n-        self.vmin = self.vmax = None\n-        self.autoscale_None(A)\n+        with self.callbacks.blocked():\n+            # Pause callbacks while we are updating so we only get\n+            # a single update signal at the end\n+            self.vmin = self.vmax = None\n+            self.autoscale_None(A)\n+        self._changed()\n \n     def autoscale_None(self, A):\n         \"\"\"If vmin or vmax are not set, use the min/max of *A* to set them.\"\"\"\n",
  "similar_bug_items": [
    {
      "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_id": 9659,
      "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_closed_at": "2017-11-02T10:07:32Z",
      "base_commit": "c46599356379b148afe331ad8bc05fb343cf7e85",
      "changes": [
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "iter_circle_intersect_on_line_seg",
          "class_name": "Arc",
          "code": "def iter_circle_intersect_on_line_seg(x0, y0, x1, y1):\n            epsilon = 1e-9\n            if x1 < x0:\n                x0e, x1e = x1, x0\n            else:\n                x0e, x1e = x0, x1\n            if y1 < y0:\n                y0e, y1e = y1, y0\n            else:\n                y0e, y1e = y0, y1\n            x0e -= epsilon\n            y0e -= epsilon\n            x1e += epsilon\n            y1e += epsilon\n            for x, y in iter_circle_intersect_on_line(x0, y0, x1, y1):\n                if x >= x0e and x <= x1e and y >= y0e and y <= y1e:\n                    yield x, y"
        }
      ]
    },
    {
      "pr_number": 15798,
      "pr_title": "Better default behavior for boxplots when rcParams['lines.marker'] is set",
      "pr_body": "## PR Summary\r\ncloses #15730\r\navoid using rcParams['lines.marker'] for boxplots.\r\n\r\n**Code snippet for reproducing the issue:**\r\n```\r\nplt.rcParams['lines.marker'] = 's'\r\nplt.boxplot(range(100))\r\n```\r\n**Before this PR:**\r\n![test](https://user-images.githubusercontent.com/15175620/69918581-ee337180-1441-11ea-9937-dfe8c5005946.png)\r\n\r\n**After this PR:**\r\n![test1](https://user-images.githubusercontent.com/15175620/69918585-f4295280-1441-11ea-9e35-bfc4b07c07d8.png)\r\n\r\n## PR Checklist\r\n\r\n- [ ] Has Pytest style unit tests\r\n- [ ] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/api_changes.rst if API changed in a backward-incompatible way\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Do not create the PR out of master, but out of a separate branch.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->\r\n",
      "issue_id": 15730,
      "issue_title": "Setting lines.marker = s in matplotlibrc also sets markers in boxplots",
      "issue_body": "<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\nSetting this line\r\n    lines.marker      : s    ## the default marker\r\nin the matplotlibrc leads to an unexpected result:\r\n\r\n```\r\n%pylab inline\r\nboxplot(range(100))\r\n\r\n```\r\n\r\n![fig](https://user-images.githubusercontent.com/3391614/69190942-b0982580-0ade-11ea-903e-8f59e3f5e70d.jpg)\r\n",
      "issue_closed_at": "2019-12-30T18:06:35Z",
      "base_commit": "22ac46006fa8ea9dfb5b37941ffa7980f0447d8a",
      "changes": [
        {
          "file": "lib/matplotlib/axes/_axes.py",
          "type": "function",
          "name": "bxp",
          "class_name": "Axes",
          "code": "def bxp(self, bxpstats, positions=None, widths=None, vert=True,\n            patch_artist=False, shownotches=False, showmeans=False,\n            showcaps=True, showbox=True, showfliers=True,\n            boxprops=None, whiskerprops=None, flierprops=None,\n            medianprops=None, capprops=None, meanprops=None,\n            meanline=False, manage_ticks=True, zorder=None):\n        \"\"\"\n        Drawing function for box and whisker plots.\n\n        Make a box and whisker plot for each column of *x* or each\n        vector in sequence *x*.  The box extends from the lower to\n        upper quartile values of the data, with a line at the median.\n        The whiskers extend from the box to show the range of the\n        data.  Flier points are those past the end of the whiskers.\n\n        Parameters\n        ----------\n        bxpstats : list of dicts\n          A list of dictionaries containing stats for each boxplot.\n          Required keys are:\n\n          - ``med``: The median (scalar float).\n\n          - ``q1``: The first quartile (25th percentile) (scalar\n            float).\n\n          - ``q3``: The third quartile (75th percentile) (scalar\n            float).\n\n          - ``whislo``: Lower bound of the lower whisker (scalar\n            float).\n\n          - ``whishi``: Upper bound of the upper whisker (scalar\n            float).\n\n          Optional keys are:\n\n          - ``mean``: The mean (scalar float). Needed if\n            ``showmeans=True``.\n\n          - ``fliers``: Data beyond the whiskers (sequence of floats).\n            Needed if ``showfliers=True``.\n\n          - ``cilo`` & ``cihi``: Lower and upper confidence intervals\n            about the median. Needed if ``shownotches=True``.\n\n          - ``label``: Name of the dataset (string). If available,\n            this will be used a tick label for the boxplot\n\n        positions : array-like, default: [1, 2, ..., n]\n          Sets the positions of the boxes. The ticks and limits\n          are automatically set to match the positions.\n\n        widths : array-like, default: None\n          Either a scalar or a vector and sets the width of each\n          box. The default is ``0.15*(distance between extreme\n          positions)``, clipped to no less than 0.15 and no more than\n          0.5.\n\n        vert : bool, default: True\n          If `True` (default), makes the boxes vertical.  If `False`,\n          makes horizontal boxes.\n\n        patch_artist : bool, default: False\n          If `False` produces boxes with the `.Line2D` artist.\n          If `True` produces boxes with the `~matplotlib.patches.Patch` artist.\n\n        shownotches : bool, default: False\n          If `False` (default), produces a rectangular box plot.\n          If `True`, will produce a notched box plot\n\n        showmeans : bool, default: False\n          If `True`, will toggle on the rendering of the means\n\n        showcaps  : bool, default: True\n          If `True`, will toggle on the rendering of the caps\n\n        showbox  : bool, default: True\n          If `True`, will toggle on the rendering of the box\n\n        showfliers : bool, default: True\n          If `True`, will toggle on the rendering of the fliers\n\n        boxprops : dict or None (default)\n          If provided, will set the plotting style of the boxes\n\n        whiskerprops : dict or None (default)\n          If provided, will set the plotting style of the whiskers\n\n        capprops : dict or None (default)\n          If provided, will set the plotting style of the caps\n\n        flierprops : dict or None (default)\n          If provided will set the plotting style of the fliers\n\n        medianprops : dict or None (default)\n          If provided, will set the plotting style of the medians\n\n        meanprops : dict or None (default)\n          If provided, will set the plotting style of the means\n\n        meanline : bool, default: False\n          If `True` (and *showmeans* is `True`), will try to render the mean\n          as a line spanning the full width of the box according to\n          *meanprops*. Not recommended if *shownotches* is also True.\n          Otherwise, means will be shown as points.\n\n        manage_ticks : bool, default: True\n          If True, the tick locations and labels will be adjusted to match the\n          boxplot positions.\n\n        zorder : scalar, default: None\n          The zorder of the resulting boxplot.\n\n        Returns\n        -------\n        result : dict\n          A dictionary mapping each component of the boxplot to a list\n          of the `.Line2D` instances created. That dictionary has the\n          following keys (assuming vertical boxplots):\n\n          - ``boxes``: the main body of the boxplot showing the\n            quartiles and the median's confidence intervals if\n            enabled.\n\n          - ``medians``: horizontal lines at the median of each box.\n\n          - ``whiskers``: the vertical lines extending to the most\n            extreme, non-outlier data points.\n\n          - ``caps``: the horizontal lines at the ends of the\n            whiskers.\n\n          - ``fliers``: points representing data that extend beyond\n            the whiskers (fliers).\n\n          - ``means``: points or lines representing the means.\n\n        Examples\n        --------\n        .. plot:: gallery/statistics/bxp.py\n\n        \"\"\"\n        # lists of artists to be output\n        whiskers = []\n        caps = []\n        boxes = []\n        medians = []\n        means = []\n        fliers = []\n\n        # empty list of xticklabels\n        datalabels = []\n\n        # Use default zorder if none specified\n        if zorder is None:\n            zorder = mlines.Line2D.zorder\n\n        zdelta = 0.1\n\n        def line_props_with_rcdefaults(subkey, explicit, zdelta=0):\n            d = {k.split('.')[-1]: v for k, v in rcParams.items()\n                 if k.startswith(f'boxplot.{subkey}')}\n            d['zorder'] = zorder + zdelta\n            if explicit is not None:\n                d.update(\n                    cbook.normalize_kwargs(explicit, mlines.Line2D._alias_map))\n            return d\n\n        # box properties\n        if patch_artist:\n            final_boxprops = dict(\n                linestyle=rcParams['boxplot.boxprops.linestyle'],\n                linewidth=rcParams['boxplot.boxprops.linewidth'],\n                edgecolor=rcParams['boxplot.boxprops.color'],\n                facecolor=('white' if rcParams['_internal.classic_mode'] else\n                           rcParams['patch.facecolor']),\n                zorder=zorder,\n            )\n            if boxprops is not None:\n                final_boxprops.update(\n                    cbook.normalize_kwargs(\n                        boxprops, mpatches.PathPatch._alias_map))\n        else:\n            final_boxprops = line_props_with_rcdefaults('boxprops', boxprops)\n        final_whiskerprops = line_props_with_rcdefaults(\n            'whiskerprops', whiskerprops)\n        final_capprops = line_props_with_rcdefaults(\n            'capprops', capprops)\n        final_flierprops = line_props_with_rcdefaults(\n            'flierprops', flierprops)\n        final_medianprops = line_props_with_rcdefaults(\n            'medianprops', medianprops, zdelta)\n        final_meanprops = line_props_with_rcdefaults(\n            'meanprops', meanprops, zdelta)\n        removed_prop = 'marker' if meanline else 'linestyle'\n        # Only remove the property if it's not set explicitly as a parameter.\n        if meanprops is None or removed_prop not in meanprops:\n            final_meanprops[removed_prop] = ''\n\n        def to_vc(xs, ys):\n            # convert arguments to verts and codes, append (0, 0) (ignored).\n            verts = np.append(np.column_stack([xs, ys]), [(0, 0)], 0)\n            codes = ([mpath.Path.MOVETO]\n                     + [mpath.Path.LINETO] * (len(verts) - 2)\n                     + [mpath.Path.CLOSEPOLY])\n            return verts, codes\n\n        def patch_list(xs, ys, **kwargs):\n            verts, codes = to_vc(xs, ys)\n            path = mpath.Path(verts, codes)\n            patch = mpatches.PathPatch(path, **kwargs)\n            self.add_artist(patch)\n            return [patch]\n\n        # vertical or horizontal plot?\n        if vert:\n            def doplot(*args, **kwargs):\n                return self.plot(*args, **kwargs)\n\n            def dopatch(xs, ys, **kwargs):\n                return patch_list(xs, ys, **kwargs)\n\n        else:\n            def doplot(*args, **kwargs):\n                shuffled = []\n                for i in range(0, len(args), 2):\n                    shuffled.extend([args[i + 1], args[i]])\n                return self.plot(*shuffled, **kwargs)\n\n            def dopatch(xs, ys, **kwargs):\n                xs, ys = ys, xs  # flip X, Y\n                return patch_list(xs, ys, **kwargs)\n\n        # input validation\n        N = len(bxpstats)\n        datashape_message = (\"List of boxplot statistics and `{0}` \"\n                             \"values must have same the length\")\n        # check position\n        if positions is None:\n            positions = list(range(1, N + 1))\n        elif len(positions) != N:\n            raise ValueError(datashape_message.format(\"positions\"))\n\n        positions = np.array(positions)\n        if len(positions) > 0 and not isinstance(positions[0], Number):\n            raise TypeError(\"positions should be an iterable of numbers\")\n\n        # width\n        if widths is None:\n            widths = [np.clip(0.15 * np.ptp(positions), 0.15, 0.5)] * N\n        elif np.isscalar(widths):\n            widths = [widths] * N\n        elif len(widths) != N:\n            raise ValueError(datashape_message.format(\"widths\"))\n\n        for pos, width, stats in zip(positions, widths, bxpstats):\n            # try to find a new label\n            datalabels.append(stats.get('label', pos))\n\n            # whisker coords\n            whisker_x = np.ones(2) * pos\n            whiskerlo_y = np.array([stats['q1'], stats['whislo']])\n            whiskerhi_y = np.array([stats['q3'], stats['whishi']])\n\n            # cap coords\n            cap_left = pos - width * 0.25\n            cap_right = pos + width * 0.25\n            cap_x = np.array([cap_left, cap_right])\n            cap_lo = np.ones(2) * stats['whislo']\n            cap_hi = np.ones(2) * stats['whishi']\n\n            # box and median coords\n            box_left = pos - width * 0.5\n            box_right = pos + width * 0.5\n            med_y = [stats['med'], stats['med']]\n\n            # notched boxes\n            if shownotches:\n                box_x = [box_left, box_right, box_right, cap_right, box_right,\n                         box_right, box_left, box_left, cap_left, box_left,\n                         box_left]\n                box_y = [stats['q1'], stats['q1'], stats['cilo'],\n                         stats['med'], stats['cihi'], stats['q3'],\n                         stats['q3'], stats['cihi'], stats['med'],\n                         stats['cilo'], stats['q1']]\n                med_x = cap_x\n\n            # plain boxes\n            else:\n                box_x = [box_left, box_right, box_right, box_left, box_left]\n                box_y = [stats['q1'], stats['q1'], stats['q3'], stats['q3'],\n                         stats['q1']]\n                med_x = [box_left, box_right]\n\n            # maybe draw the box:\n            if showbox:\n                if patch_artist:\n                    boxes.extend(dopatch(box_x, box_y, **final_boxprops))\n                else:\n                    boxes.extend(doplot(box_x, box_y, **final_boxprops))\n\n            # draw the whiskers\n            whiskers.extend(doplot(\n                whisker_x, whiskerlo_y, **final_whiskerprops\n            ))\n            whiskers.extend(doplot(\n                whisker_x, whiskerhi_y, **final_whiskerprops\n            ))\n\n            # maybe draw the caps:\n            if showcaps:\n                caps.extend(doplot(cap_x, cap_lo, **final_capprops))\n                caps.extend(doplot(cap_x, cap_hi, **final_capprops))\n\n            # draw the medians\n            medians.extend(doplot(med_x, med_y, **final_medianprops))\n\n            # maybe draw the means\n            if showmeans:\n                if meanline:\n                    means.extend(doplot(\n                        [box_left, box_right], [stats['mean'], stats['mean']],\n                        **final_meanprops\n                    ))\n                else:\n                    means.extend(doplot(\n                        [pos], [stats['mean']], **final_meanprops\n                    ))\n\n            # maybe draw the fliers\n            if showfliers:\n                # fliers coords\n                flier_x = np.full(len(stats['fliers']), pos, dtype=np.float64)\n                flier_y = stats['fliers']\n\n                fliers.extend(doplot(\n                    flier_x, flier_y, **final_flierprops\n                ))\n\n        if manage_ticks:\n            axis_name = \"x\" if vert else \"y\"\n            interval = getattr(self.dataLim, f\"interval{axis_name}\")\n            axis = getattr(self, f\"{axis_name}axis\")\n            positions = axis.convert_units(positions)\n            # The 0.5 additional padding ensures reasonable-looking boxes\n            # even when drawing a single box.  We set the sticky edge to\n            # prevent margins expansion, in order to match old behavior (back\n            # when separate calls to boxplot() would completely reset the axis\n            # limits regardless of what was drawn before).  The sticky edges\n            # are attached to the median lines, as they are always present.\n            interval[:] = (min(interval[0], min(positions) - .5),\n                           max(interval[1], max(positions) + .5))\n            for median, position in zip(medians, positions):\n                getattr(median.sticky_edges, axis_name).extend(\n                    [position - .5, position + .5])\n            # Modified from Axis.set_ticks and Axis.set_ticklabels.\n            locator = axis.get_major_locator()\n            if not isinstance(axis.get_major_locator(),\n                              mticker.FixedLocator):\n                locator = mticker.FixedLocator([])\n                axis.set_major_locator(locator)\n            locator.locs = np.array([*locator.locs, *positions])\n            formatter = axis.get_major_formatter()\n            if not isinstance(axis.get_major_formatter(),\n                              mticker.FixedFormatter):\n                formatter = mticker.FixedFormatter([])\n                axis.set_major_formatter(formatter)\n            formatter.seq = [*formatter.seq, *datalabels]\n\n            self._request_autoscale_view(\n                scalex=self._autoscaleXon, scaley=self._autoscaleYon)\n\n        return dict(whiskers=whiskers, caps=caps, boxes=boxes,\n                    medians=medians, fliers=fliers, means=means)"
        },
        {
          "file": "lib/matplotlib/axes/_axes.py",
          "type": "function",
          "name": "line_props_with_rcdefaults",
          "class_name": "Axes",
          "code": "def line_props_with_rcdefaults(subkey, explicit, zdelta=0):\n            d = {k.split('.')[-1]: v for k, v in rcParams.items()\n                 if k.startswith(f'boxplot.{subkey}')}\n            d['zorder'] = zorder + zdelta\n            if explicit is not None:\n                d.update(\n                    cbook.normalize_kwargs(explicit, mlines.Line2D._alias_map))\n            return d"
        }
      ]
    },
    {
      "pr_number": 8047,
      "pr_title": "Correct theta values when drawing a non-circular arc",
      "pr_body": "Fixes #8046. I'm not sure if this is the right place to do the correction, so a second opinion would be good. I've checked this works with a full range of angles.",
      "issue_id": 8046,
      "issue_title": "Arc patch with starting and ending angle",
      "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\n\r\n- Arc patch does not behave as expected when drawing elliptical arcs between two angles specified by theta1 and theta2.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport matplotlib.pyplot as plt\r\nfrom matplotlib.patches import Arc\r\n\r\n# Ellipse parameters\r\nR = 1.0\r\nx, y = 0.0, 0.0\r\na, b = 2.0*R, R\r\n\r\n# Figure setup\r\nfig_width, fig_height = 3.30, 3.30\r\nfig = plt.figure(figsize=(fig_width, fig_height), frameon=False)\r\nax = fig.add_axes([0.0, 0.0, 1.0, 1.0], aspect='equal')\r\nax.set_axis_off()\r\nax.set_xlim(-R*1.05, R*1.05)\r\nax.set_ylim(-R*1.05, R*1.05)\r\n# Axes\r\nax.axhline(0.0)\r\nax.axvline(0.0)\r\n# 45 degree line\r\nax.plot([0.0, 1.0], [0.0, 1.0], 'k--')\r\n# Arcs\r\nax.add_patch(Arc((x, y), a, b, \r\n                 theta1=0.0, theta2=360.0, edgecolor='k'))\r\nax.add_patch(Arc((x, y), a, b,\r\n                 theta1=0.0, theta2=45.0, edgecolor='r', lw=1.5))\r\nfig.savefig('Arc_patch_bug.png')\r\n```\r\n\r\n**Actual outcome**\r\n\r\n![arc_patch_bug](https://cloud.githubusercontent.com/assets/20580126/22736007/3d8cc2bc-edf4-11e6-85ef-3e042599b626.png)\r\n\r\n**Expected outcome**\r\n\r\n- Red elliptical arc between the x-axis (0 degrees) and the dashed line (45 degrees), following the black ellipse.\r\n\r\n**Matplotlib version**\r\n\r\n- Matplotlib 2.0.0, Python 2.7.13, OSX\r\n- Installed with MacPorts\r\n\r\n",
      "issue_closed_at": "2017-03-10T23:28:10Z",
      "base_commit": "1f173ddfdbe44a978df7126c606588a0fc75fbd9",
      "changes": [
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "__init__",
          "class_name": "ConnectionPatch",
          "code": "def __init__(self, xyA, xyB, coordsA, coordsB=None,\n                 axesA=None, axesB=None,\n                 arrowstyle=\"-\",\n                 arrow_transmuter=None,\n                 connectionstyle=\"arc3\",\n                 connector=None,\n                 patchA=None,\n                 patchB=None,\n                 shrinkA=0.,\n                 shrinkB=0.,\n                 mutation_scale=10.,\n                 mutation_aspect=None,\n                 clip_on=False,\n                 dpi_cor=1.,\n                 **kwargs):\n        \"\"\"\n        Connect point *xyA* in *coordsA* with point *xyB* in *coordsB*\n\n\n        Valid keys are\n\n\n        ===============  ======================================================\n        Key              Description\n        ===============  ======================================================\n        arrowstyle       the arrow style\n        connectionstyle  the connection style\n        relpos           default is (0.5, 0.5)\n        patchA           default is bounding box of the text\n        patchB           default is None\n        shrinkA          default is 2 points\n        shrinkB          default is 2 points\n        mutation_scale   default is text size (in points)\n        mutation_aspect  default is 1.\n        ?                any key for :class:`matplotlib.patches.PathPatch`\n        ===============  ======================================================\n\n\n        *coordsA* and *coordsB* are strings that indicate the\n        coordinates of *xyA* and *xyB*.\n\n        =================   ===================================================\n        Property            Description\n        =================   ===================================================\n        'figure points'     points from the lower left corner of the figure\n        'figure pixels'     pixels from the lower left corner of the figure\n        'figure fraction'   0,0 is lower left of figure and 1,1 is upper, right\n        'axes points'       points from lower left corner of axes\n        'axes pixels'       pixels from lower left corner of axes\n        'axes fraction'     0,1 is lower left of axes and 1,1 is upper right\n        'data'              use the coordinate system of the object being\n                            annotated (default)\n        'offset points'     Specify an offset (in points) from the *xy* value\n\n        'polar'             you can specify *theta*, *r* for the annotation,\n                            even in cartesian plots.  Note that if you\n                            are using a polar axes, you do not need\n                            to specify polar for the coordinate\n                            system since that is the native \"data\" coordinate\n                            system.\n        =================   ===================================================\n\n        \"\"\"\n        if coordsB is None:\n            coordsB = coordsA\n        # we'll draw ourself after the artist we annotate by default\n        self.xy1 = xyA\n        self.xy2 = xyB\n        self.coords1 = coordsA\n        self.coords2 = coordsB\n\n        self.axesA = axesA\n        self.axesB = axesB\n\n        FancyArrowPatch.__init__(self,\n                                 posA=(0, 0), posB=(1, 1),\n                                 arrowstyle=arrowstyle,\n                                 arrow_transmuter=arrow_transmuter,\n                                 connectionstyle=connectionstyle,\n                                 connector=connector,\n                                 patchA=patchA,\n                                 patchB=patchB,\n                                 shrinkA=shrinkA,\n                                 shrinkB=shrinkB,\n                                 mutation_scale=mutation_scale,\n                                 mutation_aspect=mutation_aspect,\n                                 clip_on=clip_on,\n                                 dpi_cor=dpi_cor,\n                                 **kwargs)\n\n        # if True, draw annotation only if self.xy is inside the axes\n        self._annotation_clip = None"
        },
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "draw",
          "class_name": "ConnectionPatch",
          "code": "def draw(self, renderer):\n        \"\"\"\n        Draw.\n        \"\"\"\n\n        if renderer is not None:\n            self._renderer = renderer\n        if not self.get_visible():\n            return\n\n        if not self._check_xy(renderer):\n            return\n\n        FancyArrowPatch.draw(self, renderer)"
        },
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "iter_circle_intersect_on_line_seg",
          "class_name": "Arc",
          "code": "def iter_circle_intersect_on_line_seg(x0, y0, x1, y1):\n            epsilon = 1e-9\n            if x1 < x0:\n                x0e, x1e = x1, x0\n            else:\n                x0e, x1e = x0, x1\n            if y1 < y0:\n                y0e, y1e = y1, y0\n            else:\n                y0e, y1e = y0, y1\n            x0e -= epsilon\n            y0e -= epsilon\n            x1e += epsilon\n            y1e += epsilon\n            for x, y in iter_circle_intersect_on_line(x0, y0, x1, y1):\n                if x >= x0e and x <= x1e and y >= y0e and y <= y1e:\n                    yield x, y"
        }
      ]
    },
    {
      "pr_number": 23340,
      "pr_title": "Set correct path for Arc",
      "pr_body": "## PR Summary\r\n\r\nNow, the correct path is set for `Arc` which should solve the following.\r\n* Closes #11266\r\n![image](https://user-images.githubusercontent.com/8114497/175537063-9f0b5f6c-6898-4700-9f8a-b1be59625702.png)\r\n\r\n![image](https://user-images.githubusercontent.com/8114497/175530928-729e5a28-8767-4026-9d79-a2eec97a5da3.png)\r\n* Closes #23329 \r\n![image](https://user-images.githubusercontent.com/8114497/175531031-0ac24421-a311-44ce-a918-88b122c7dc92.png)\r\n* Closes #19550\r\n![image](https://user-images.githubusercontent.com/8114497/175531190-1fb1e865-f597-43d0-b356-f6ffad8ebd8f.png)\r\n\r\n~I am still a bit doubtful if this will kill something else and so on, so I've not added tests yet.~ Also, not sure if this warrants a release note.\r\n\r\nThere is a bit of inefficiency in the implementation as there are basically two paths created: one during draw time and one that is just stored (and used for e.g. 3D, scaling and collections). One the other hand, for multiple draws there will not be a new creation of an `Path.arc` on every redraw.\r\n\r\n## PR Checklist\r\n\r\n<!-- Please mark any checkboxes that do not apply to this PR as [N/A]. -->\r\n**Tests and Styling**\r\n- [x] Has pytest style unit tests (and `pytest` passes).\r\n- [x] Is [Flake 8](https://flake8.pycqa.org/en/latest/) compliant (install `flake8-docstrings` and run `flake8 --docstring-convention=all`).\r\n\r\n**Documentation**\r\n- [N/A] New features are documented, with examples if plot related.\r\n- [ ] New features have an entry in `doc/users/next_whats_new/` (follow instructions in README.rst there).\r\n- [N/A] API changes documented in `doc/api/next_api_changes/` (follow instructions in README.rst there).\r\n- [x] Documentation is sphinx and numpydoc compliant (the docs should [build](https://matplotlib.org/devel/documenting_mpl.html#building-the-docs) without error).\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Do not create the PR out of main, but out of a separate branch.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->\r\n",
      "issue_id": 19550,
      "issue_title": "Arc and pathpatch_2d_to_3d plots 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\nI'm trying to draw an arc with an arrow in a 3D plot (to visualize an angle) and am having trouble using `pathpatch_2d_to_3d`. The full circle is displayed when a 3D figure is used.\r\n\r\nI found https://discourse.matplotlib.org/t/matplotlib-users-arc-and-art3d-pathpatch-2d-to-3d/21104, which is the exact same issue.\r\nWhat's the best way to achieve the desired outcome?\r\n\r\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n\r\n**Code for reproduction**\r\n\r\n\r\n\r\n<!--A minimum code snippet required to reproduce the bug.\r\nPlease make sure to minimize the number of dependencies required, and provide\r\nany necessary plotted data.\r\nAvoid using threads, as Matplotlib is (explicitly) not thread-safe.-->\r\n\r\n```python\r\n\r\nimport matplotlib.pyplot as plt\r\nfrom matplotlib.patches import Arc\r\nimport mpl_toolkits.mplot3d.art3d as art3d\r\n\r\nfig = plt.figure()\r\nax = plt.axes(projection='3d')\r\na = Arc((0.5, 0.5), width=0.5, height=0.5, angle=0, theta1=0, theta2=90)\r\nax.add_patch(a)\r\nart3d.pathpatch_2d_to_3d(a, z=0, zdir='z')\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n\r\n![Figure_1](https://user-images.githubusercontent.com/4065335/108608587-f30d7980-7395-11eb-9820-ff115524c589.png)\r\n\r\n**Expected outcome**\r\n\r\nI expect the arc to be 90 degrees, not a full circle.\r\n\r\n**Matplotlib version**\r\nMatplotlib 3.3.4 w/ Python 3.9.1.\r\n\r\n",
      "issue_closed_at": "2022-08-19T19:33:28Z",
      "base_commit": "65cbdefcc42db7253dc0c6a5b22d8e9179ad4594",
      "changes": [
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "__init__",
          "class_name": "ConnectionPatch",
          "code": "def __init__(self, xyA, xyB, coordsA, coordsB=None,\n                 axesA=None, axesB=None,\n                 arrowstyle=\"-\",\n                 connectionstyle=\"arc3\",\n                 patchA=None,\n                 patchB=None,\n                 shrinkA=0.,\n                 shrinkB=0.,\n                 mutation_scale=10.,\n                 mutation_aspect=None,\n                 clip_on=False,\n                 **kwargs):\n        \"\"\"\n        Connect point *xyA* in *coordsA* with point *xyB* in *coordsB*.\n\n        Valid keys are\n\n        ===============  ======================================================\n        Key              Description\n        ===============  ======================================================\n        arrowstyle       the arrow style\n        connectionstyle  the connection style\n        relpos           default is (0.5, 0.5)\n        patchA           default is bounding box of the text\n        patchB           default is None\n        shrinkA          default is 2 points\n        shrinkB          default is 2 points\n        mutation_scale   default is text size (in points)\n        mutation_aspect  default is 1.\n        ?                any key for `matplotlib.patches.PathPatch`\n        ===============  ======================================================\n\n        *coordsA* and *coordsB* are strings that indicate the\n        coordinates of *xyA* and *xyB*.\n\n        ==================== ==================================================\n        Property             Description\n        ==================== ==================================================\n        'figure points'      points from the lower left corner of the figure\n        'figure pixels'      pixels from the lower left corner of the figure\n        'figure fraction'    0, 0 is lower left of figure and 1, 1 is upper\n                             right\n        'subfigure points'   points from the lower left corner of the subfigure\n        'subfigure pixels'   pixels from the lower left corner of the subfigure\n        'subfigure fraction' fraction of the subfigure, 0, 0 is lower left.\n        'axes points'        points from lower left corner of axes\n        'axes pixels'        pixels from lower left corner of axes\n        'axes fraction'      0, 0 is lower left of axes and 1, 1 is upper right\n        'data'               use the coordinate system of the object being\n                             annotated (default)\n        'offset points'      offset (in points) from the *xy* value\n        'polar'              you can specify *theta*, *r* for the annotation,\n                             even in cartesian plots.  Note that if you are\n                             using a polar axes, you do not need to specify\n                             polar for the coordinate system since that is the\n                             native \"data\" coordinate system.\n        ==================== ==================================================\n\n        Alternatively they can be set to any valid\n        `~matplotlib.transforms.Transform`.\n\n        Note that 'subfigure pixels' and 'figure pixels' are the same\n        for the parent figure, so users who want code that is usable in\n        a subfigure can use 'subfigure pixels'.\n\n        .. note::\n\n           Using `ConnectionPatch` across two `~.axes.Axes` instances\n           is not directly compatible with :doc:`constrained layout\n           </tutorials/intermediate/constrainedlayout_guide>`. Add the artist\n           directly to the `.Figure` instead of adding it to a specific Axes,\n           or exclude it from the layout using ``con.set_in_layout(False)``.\n\n           .. code-block:: default\n\n              fig, ax = plt.subplots(1, 2, constrained_layout=True)\n              con = ConnectionPatch(..., axesA=ax[0], axesB=ax[1])\n              fig.add_artist(con)\n\n        \"\"\"\n        if coordsB is None:\n            coordsB = coordsA\n        # we'll draw ourself after the artist we annotate by default\n        self.xy1 = xyA\n        self.xy2 = xyB\n        self.coords1 = coordsA\n        self.coords2 = coordsB\n\n        self.axesA = axesA\n        self.axesB = axesB\n\n        super().__init__(posA=(0, 0), posB=(1, 1),\n                         arrowstyle=arrowstyle,\n                         connectionstyle=connectionstyle,\n                         patchA=patchA, patchB=patchB,\n                         shrinkA=shrinkA, shrinkB=shrinkB,\n                         mutation_scale=mutation_scale,\n                         mutation_aspect=mutation_aspect,\n                         clip_on=clip_on,\n                         **kwargs)\n        # if True, draw annotation only if self.xy is inside the axes\n        self._annotation_clip = None"
        },
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "draw",
          "class_name": "ConnectionPatch",
          "code": "def draw(self, renderer):\n        if renderer is not None:\n            self._renderer = renderer\n        if not self.get_visible() or not self._check_xy(renderer):\n            return\n        super().draw(renderer)"
        },
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "theta_stretch",
          "class_name": "Arc",
          "code": "def theta_stretch(theta, scale):\n            theta = np.deg2rad(theta)\n            x = np.cos(theta)\n            y = np.sin(theta)\n            stheta = np.rad2deg(np.arctan2(scale * y, x))\n            # arctan2 has the range [-pi, pi], we expect [0, 2*pi]\n            return (stheta + 360) % 360"
        },
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "segment_circle_intersect",
          "class_name": "Arc",
          "code": "def segment_circle_intersect(x0, y0, x1, y1):\n            epsilon = 1e-9\n            if x1 < x0:\n                x0e, x1e = x1, x0\n            else:\n                x0e, x1e = x0, x1\n            if y1 < y0:\n                y0e, y1e = y1, y0\n            else:\n                y0e, y1e = y0, y1\n            xys = line_circle_intersect(x0, y0, x1, y1)\n            xs, ys = xys.T\n            return xys[\n                (x0e - epsilon < xs) & (xs < x1e + epsilon)\n                & (y0e - epsilon < ys) & (ys < y1e + epsilon)\n            ]"
        },
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "segment_circle_intersect",
          "class_name": "Arc",
          "code": "def segment_circle_intersect(x0, y0, x1, y1):\n            epsilon = 1e-9\n            if x1 < x0:\n                x0e, x1e = x1, x0\n            else:\n                x0e, x1e = x0, x1\n            if y1 < y0:\n                y0e, y1e = y1, y0\n            else:\n                y0e, y1e = y0, y1\n            xys = line_circle_intersect(x0, y0, x1, y1)\n            xs, ys = xys.T\n            return xys[\n                (x0e - epsilon < xs) & (xs < x1e + epsilon)\n                & (y0e - epsilon < ys) & (ys < y1e + epsilon)\n            ]"
        }
      ]
    },
    {
      "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_id": 2885,
      "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_closed_at": "2015-03-19T21:09:05Z",
      "base_commit": "a488cbc3926d8409270a7c79b7923268fdc93dce",
      "changes": [
        {
          "file": "lib/matplotlib/backends/backend_pgf.py",
          "type": "function",
          "name": "draw_path",
          "class_name": "RendererPgf",
          "code": "def draw_path(self, gc, path, transform, rgbFace=None):\n        writeln(self.fh, r\"\\begin{pgfscope}\")\n        # draw the path\n        self._print_pgf_clip(gc)\n        self._print_pgf_path_styles(gc, rgbFace)\n        self._print_pgf_path(gc, path, transform, rgbFace)\n        self._pgf_path_draw(stroke=gc.get_linewidth() != 0.0,\n                            fill=rgbFace is not None)\n        writeln(self.fh, r\"\\end{pgfscope}\")\n\n        # if present, draw pattern on top\n        if gc.get_hatch():\n            writeln(self.fh, r\"\\begin{pgfscope}\")\n            self._print_pgf_path_styles(gc, rgbFace)\n\n            # combine clip and path for clipping\n            self._print_pgf_clip(gc)\n            self._print_pgf_path(gc, path, transform)\n            writeln(self.fh, r\"\\pgfusepath{clip}\")\n\n            # build pattern definition\n            writeln(self.fh, r\"\\pgfsys@defobject{currentpattern}{\\pgfqpoint{0in}{0in}}{\\pgfqpoint{1in}{1in}}{\")\n            writeln(self.fh, r\"\\begin{pgfscope}\")\n            writeln(self.fh, r\"\\pgfpathrectangle{\\pgfqpoint{0in}{0in}}{\\pgfqpoint{1in}{1in}}\")\n            writeln(self.fh, r\"\\pgfusepath{clip}\")\n            scale = mpl.transforms.Affine2D().scale(self.dpi)\n            self._print_pgf_path(None, gc.get_hatch_path(), scale)\n            self._pgf_path_draw(stroke=True)\n            writeln(self.fh, r\"\\end{pgfscope}\")\n            writeln(self.fh, r\"}\")\n            # repeat pattern, filling the bounding rect of the path\n            f = 1. / self.dpi\n            (xmin, ymin), (xmax, ymax) = path.get_extents(transform).get_points()\n            xmin, xmax = f * xmin, f * xmax\n            ymin, ymax = f * ymin, f * ymax\n            repx, repy = int(math.ceil(xmax-xmin)), int(math.ceil(ymax-ymin))\n            writeln(self.fh, r\"\\pgfsys@transformshift{%fin}{%fin}\" % (xmin, ymin))\n            for iy in range(repy):\n                for ix in range(repx):\n                    writeln(self.fh, r\"\\pgfsys@useobject{currentpattern}{}\")\n                    writeln(self.fh, r\"\\pgfsys@transformshift{1in}{0in}\")\n                writeln(self.fh, r\"\\pgfsys@transformshift{-%din}{0in}\" % repx)\n                writeln(self.fh, r\"\\pgfsys@transformshift{0in}{1in}\")\n\n            writeln(self.fh, r\"\\end{pgfscope}\")"
        }
      ]
    }
  ]
}