{
  "Selected_candidate": {
    "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}\")"
      }
    ]
  },
  "Justification": "Candidate B is the most helpful because it deals with issues related to the colorbar, a component directly relevant to the CURRENT bug report regarding updating the colorbar when the normalization of a mappable changes. Additionally, it involves a fix for handling fill issues in matplotlib, which may give insights into how normalization changes affect rendering and updates in color-related features. The focus on the colorbar's behavior in different contexts aligns closely with the problem being faced in the CURRENT bug.",
  "instance_id": "matplotlib__matplotlib-25498",
  "repo": "matplotlib/matplotlib",
  "created_at": "2023-03-18T17:01:11Z",
  "problem_statement": "Update colorbar after changing mappable.norm\nHow can I update a colorbar, after I changed the norm instance of the colorbar?\n\n`colorbar.update_normal(mappable)` has now effect and `colorbar.update_bruteforce(mappable)` throws a `ZeroDivsionError`-Exception.\n\nConsider this example:\n\n``` python\nimport matplotlib.pyplot as plt\nfrom matplotlib.colors import LogNorm\nimport numpy as np\n\nimg = 10**np.random.normal(1, 1, size=(50, 50))\n\nfig, ax = plt.subplots(1, 1)\nplot = ax.imshow(img, cmap='gray')\ncb = fig.colorbar(plot, ax=ax)\nplot.norm = LogNorm()\ncb.update_normal(plot)  # no effect\ncb.update_bruteforce(plot)  # throws ZeroDivisionError\nplt.show()\n```\n\nOutput for `cb.update_bruteforce(plot)`:\n\n```\nTraceback (most recent call last):\n  File \"test_norm.py\", line 12, in <module>\n    cb.update_bruteforce(plot)\n  File \"/home/maxnoe/.local/anaconda3/lib/python3.4/site-packages/matplotlib/colorbar.py\", line 967, in update_bruteforce\n    self.draw_all()\n  File \"/home/maxnoe/.local/anaconda3/lib/python3.4/site-packages/matplotlib/colorbar.py\", line 342, in draw_all\n    self._process_values()\n  File \"/home/maxnoe/.local/anaconda3/lib/python3.4/site-packages/matplotlib/colorbar.py\", line 664, in _process_values\n    b = self.norm.inverse(self._uniform_y(self.cmap.N + 1))\n  File \"/home/maxnoe/.local/anaconda3/lib/python3.4/site-packages/matplotlib/colors.py\", line 1011, in inverse\n    return vmin * ma.power((vmax / vmin), val)\nZeroDivisionError: division by zero\n```\n\n",
  "patch": "diff --git a/lib/matplotlib/colorbar.py b/lib/matplotlib/colorbar.py\n--- a/lib/matplotlib/colorbar.py\n+++ b/lib/matplotlib/colorbar.py\n@@ -301,11 +301,6 @@ def __init__(self, ax, mappable=None, *, cmap=None,\n         if mappable is None:\n             mappable = cm.ScalarMappable(norm=norm, cmap=cmap)\n \n-        # Ensure the given mappable's norm has appropriate vmin and vmax\n-        # set even if mappable.draw has not yet been called.\n-        if mappable.get_array() is not None:\n-            mappable.autoscale_None()\n-\n         self.mappable = mappable\n         cmap = mappable.cmap\n         norm = mappable.norm\n@@ -1101,7 +1096,10 @@ def _process_values(self):\n             b = np.hstack((b, b[-1] + 1))\n \n         # transform from 0-1 to vmin-vmax:\n+        if self.mappable.get_array() is not None:\n+            self.mappable.autoscale_None()\n         if not self.norm.scaled():\n+            # If we still aren't scaled after autoscaling, use 0, 1 as default\n             self.norm.vmin = 0\n             self.norm.vmax = 1\n         self.norm.vmin, self.norm.vmax = mtransforms.nonsingular(\n"
}