{
    "Selected_candidate": {
        "pr_number": 19949,
        "pr_title": "FIX: subfigure indexing error",
        "pr_body": "## PR Summary\r\n\r\nCloses #19947.  \r\n\r\nThe indexing to locate subfigures was wildly off.  Worked fine for 2x2 but was incorrect for anything larger.  \r\n\r\nThis PR fixes that and adds a test.\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\r\n- [ ] Has pytest style unit tests (and `pytest` passes).\r\n- [ ] Is [Flake 8](https://flake8.pycqa.org/en/latest/) compliant (run `flake8` on changed files to check).\r\n- [ ] New features are documented, with examples if plot related.\r\n- [ ] Documentation is sphinx and numpydoc compliant (the docs should [build](https://matplotlib.org/devel/documenting_mpl.html#building-the-docs) without error).\r\n- [ ] Conforms to Matplotlib style conventions (install `flake8-docstrings` and run `flake8 --docstring-convention=all`).\r\n- [ ] New features have an entry in `doc/users/next_whats_new/` (follow instructions in README.rst there).\r\n- [ ] API changes documented in `doc/api/next_api_changes/` (follow instructions in README.rst there).\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": 19947,
        "issue_title": "Figure.subfigures dont show/update correctly",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\nWhen using Figure.subfigures(n, m) for any n or m larger than 2 the resulting figure does not draw properly when shown. \r\nInstead only the subfigures at [0:2, 0] and [0:2, -1] are drawn properly.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport matplotlib.pyplot as plt\r\n\r\nfig = plt.figure()\r\nsub_figs = fig.subfigures(3, 3)\r\n\r\ncolors = [\"red\", \"blue\", \"magenta\", \"gold\", \"green\", \"grey\", \"orange\", \"pink\", \"navy\", \"lightblue\", \"black\"]\r\n\r\nfor i, (color, subfig) in enumerate(zip(colors,sub_figs.flatten())):\r\n    subfig.set_facecolor(color)\r\n    subfig.suptitle(f\"subfig: {i}\")\r\n\r\nplt.show()\r\n\r\n```\r\n\r\n######### for (n, m) figures\r\n```python \r\nimport matplotlib.pyplot as plt\r\n\r\nfig = plt.figure()\r\nsub_figs = fig.subfigures(9, 10)\r\n\r\nfor i, subfig in enumerate(sub_figs.flatten()):\r\n    subfig.set_facecolor(\"grey\")\r\n    subfig.suptitle(f\"subfig: {i}\")\r\n\r\nplt.show()\r\n\r\n```\r\n**Actual outcome**\r\n\r\n![image](https://user-images.githubusercontent.com/29613344/114410466-ae3edb80-9bab-11eb-92a5-aa07e68f4265.png)\r\n\r\nOnly the subfigures at [0:2, 0] and [0:2, -1] are drawn properly for any (n, m) figure.\r\n\r\n**Expected outcome**\r\n3x3 grid with the proper face colors. Similar results for 2x3 or 3x2 or larger grids. \r\n\r\n**Matplotlib version**\r\n  * Operating system: Fedora (UNIX)\r\n  * Matplotlib version (`import matplotlib; print(matplotlib.__version__)`): 3.4.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): module://backend_interagg\r\n  * Python version: 3.7\r\n  * Jupyter version (if applicable): NA\r\n  * Other libraries: NA\r\n\r\nBoth python and Matplotlib from conda with manual update to Matplotlib version 3.4.1\r\nconda channel: conda-forge\r\n\r\n",
        "issue_closed_at": "2021-04-20T11:49:43Z",
        "base_commit": "92ce41defddde23e2fd452c39b6e18d61a5ae5e5",
        "changes": [
            {
                "file": "lib/matplotlib/figure.py",
                "type": "function",
                "name": "_redo_transform_rel_fig",
                "class_name": "SubFigure",
                "code": "def _redo_transform_rel_fig(self, bbox=None):\n        \"\"\"\n        Make the transSubfigure bbox relative to Figure transform.\n\n        Parameters\n        ----------\n        bbox : bbox or None\n            If not None, then the bbox is used for relative bounding box.\n            Otherwise it is calculated from the subplotspec.\n        \"\"\"\n\n        if bbox is not None:\n            self.bbox_relative.p0 = bbox.p0\n            self.bbox_relative.p1 = bbox.p1\n            return\n\n        gs = self._subplotspec.get_gridspec()\n        # need to figure out *where* this subplotspec is.\n        wr = gs.get_width_ratios()\n        hr = gs.get_height_ratios()\n        nrows, ncols = gs.get_geometry()\n        if wr is None:\n            wr = np.ones(ncols)\n        else:\n            wr = np.array(wr)\n        if hr is None:\n            hr = np.ones(nrows)\n        else:\n            hr = np.array(hr)\n        widthf = np.sum(wr[self._subplotspec.colspan]) / np.sum(wr)\n        heightf = np.sum(hr[self._subplotspec.rowspan]) / np.sum(hr)\n\n        x0 = 0\n        if not self._subplotspec.is_first_col():\n            x0 += np.sum(wr[self._subplotspec.colspan.start - 1]) / np.sum(wr)\n\n        y0 = 0\n        if not self._subplotspec.is_last_row():\n            y0 += 1 - (np.sum(hr[self._subplotspec.rowspan.stop - 1]) /\n                       np.sum(hr))\n\n        if self.bbox_relative is None:\n            self.bbox_relative = Bbox.from_bounds(x0, y0, widthf, heightf)\n        else:\n            self.bbox_relative.p0 = (x0, y0)\n            self.bbox_relative.p1 = (x0 + widthf, y0 + heightf)"
            }
        ]
    },
    "Justification": "Candidate A relates closely to the current bug because it deals with the way subfigures are rendered, which may share similarities in the underlying rendering logic of plotting components in Matplotlib. Both bugs involve the display of graphical elements (the subplot visibility in the current bug and the proper rendering of subfigures in Candidate A). The structural similarity is notable, and given that both bugs involve issues arising from subplot handling, the insight gained from Candidate A could help in identifying the root cause of the visibility problem in the current bug."
}