{
  "Selected_candidate": {
    "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"
      }
    ]
  },
  "Justification": "Candidate E addresses a related graphical issue within the matplotlib library, dealing with the behavior of arch and angle specifications when rendering. The CURRENT bug report also revolves around drawing issues (specifically concerning bar plots with NaN values), which highlights a potential structural problem in how matplotlib processes plot commands. While not identical, both reports suggest there may be similar underlying weaknesses in handling edge cases in plotting data. This context could provide valuable insights into potential fixes and debugging strategies relevant to the CURRENT bug.",
  "instance_id": "matplotlib__matplotlib-24149",
  "repo": "matplotlib/matplotlib",
  "created_at": "2022-10-12T22:00:54Z",
  "problem_statement": "[Bug]: ax.bar raises for all-nan data on matplotlib 3.6.1 \n### Bug summary\n\n`ax.bar` raises an exception in 3.6.1 when passed only nan data. This irrevocably breaks seaborn's histogram function (which draws and then removes a \"phantom\" bar to trip the color cycle).\n\n### Code for reproduction\n\n```python\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\nf, ax = plt.subplots()\r\nax.bar([np.nan], [np.nan])\n```\n\n\n### Actual outcome\n\n```python-traceback\r\n---------------------------------------------------------------------------\r\nStopIteration                             Traceback (most recent call last)\r\nCell In [1], line 4\r\n      2 import matplotlib.pyplot as plt\r\n      3 f, ax = plt.subplots()\r\n----> 4 ax.bar([np.nan], [np.nan])[0].get_x()\r\n\r\nFile ~/miniconda/envs/py310/lib/python3.10/site-packages/matplotlib/__init__.py:1423, in _preprocess_data.<locals>.inner(ax, data, *args, **kwargs)\r\n   1420 @functools.wraps(func)\r\n   1421 def inner(ax, *args, data=None, **kwargs):\r\n   1422     if data is None:\r\n-> 1423         return func(ax, *map(sanitize_sequence, args), **kwargs)\r\n   1425     bound = new_sig.bind(ax, *args, **kwargs)\r\n   1426     auto_label = (bound.arguments.get(label_namer)\r\n   1427                   or bound.kwargs.get(label_namer))\r\n\r\nFile ~/miniconda/envs/py310/lib/python3.10/site-packages/matplotlib/axes/_axes.py:2373, in Axes.bar(self, x, height, width, bottom, align, **kwargs)\r\n   2371 x0 = x\r\n   2372 x = np.asarray(self.convert_xunits(x))\r\n-> 2373 width = self._convert_dx(width, x0, x, self.convert_xunits)\r\n   2374 if xerr is not None:\r\n   2375     xerr = self._convert_dx(xerr, x0, x, self.convert_xunits)\r\n\r\nFile ~/miniconda/envs/py310/lib/python3.10/site-packages/matplotlib/axes/_axes.py:2182, in Axes._convert_dx(dx, x0, xconv, convert)\r\n   2170 try:\r\n   2171     # attempt to add the width to x0; this works for\r\n   2172     # datetime+timedelta, for instance\r\n   (...)\r\n   2179     # removes the units from unit packages like `pint` that\r\n   2180     # wrap numpy arrays.\r\n   2181     try:\r\n-> 2182         x0 = cbook._safe_first_finite(x0)\r\n   2183     except (TypeError, IndexError, KeyError):\r\n   2184         pass\r\n\r\nFile ~/miniconda/envs/py310/lib/python3.10/site-packages/matplotlib/cbook/__init__.py:1749, in _safe_first_finite(obj, skip_nonfinite)\r\n   1746     raise RuntimeError(\"matplotlib does not \"\r\n   1747                        \"support generators as input\")\r\n   1748 else:\r\n-> 1749     return next(val for val in obj if safe_isfinite(val))\r\n\r\nStopIteration: \r\n```\n\n### Expected outcome\n\nOn 3.6.0 this returns a `BarCollection` with one Rectangle, having `nan` for `x` and `height`.\n\n### Additional information\n\nI assume it's related to this bullet in the release notes:\r\n\r\n- Fix barplot being empty when first element is NaN\r\n\r\nBut I don't know the context for it to investigate further (could these link to PRs?)\r\n\r\nFurther debugging:\r\n\r\n```python\r\nax.bar([np.nan], [0])  # Raises\r\nax.bar([0], [np.nan])  # Works\r\n```\r\n\r\nSo it's about the x position specifically.\n\n### Operating system\n\nMacos\n\n### Matplotlib Version\n\n3.6.1\n\n### Matplotlib Backend\n\n_No response_\n\n### Python version\n\n_No response_\n\n### Jupyter version\n\n_No response_\n\n### Installation\n\npip\n",
  "patch": "diff --git a/lib/matplotlib/axes/_axes.py b/lib/matplotlib/axes/_axes.py\n--- a/lib/matplotlib/axes/_axes.py\n+++ b/lib/matplotlib/axes/_axes.py\n@@ -2182,11 +2182,19 @@ def _convert_dx(dx, x0, xconv, convert):\n                 x0 = cbook._safe_first_finite(x0)\n             except (TypeError, IndexError, KeyError):\n                 pass\n+            except StopIteration:\n+                # this means we found no finite element, fall back to first\n+                # element unconditionally\n+                x0 = cbook.safe_first_element(x0)\n \n             try:\n                 x = cbook._safe_first_finite(xconv)\n             except (TypeError, IndexError, KeyError):\n                 x = xconv\n+            except StopIteration:\n+                # this means we found no finite element, fall back to first\n+                # element unconditionally\n+                x = cbook.safe_first_element(xconv)\n \n             delist = False\n             if not np.iterable(dx):\n"
}