{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-23299",
    "repo": "matplotlib/matplotlib",
    "created_at": "2022-06-18T01:34:39Z",
    "problem_statement": "[Bug]: get_backend() clears figures from Gcf.figs if they were created under rc_context\n### Bug summary\r\n\r\ncalling `matplotlib.get_backend()` removes all figures from `Gcf` if the *first* figure in `Gcf.figs` was created in an `rc_context`.\r\n\r\n### Code for reproduction\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nfrom matplotlib import get_backend, rc_context\r\n\r\n# fig1 = plt.figure()  # <- UNCOMMENT THIS LINE AND IT WILL WORK\r\n# plt.ion()            # <- ALTERNATIVELY, UNCOMMENT THIS LINE AND IT WILL ALSO WORK\r\nwith rc_context():\r\n    fig2 = plt.figure()\r\nbefore = f'{id(plt._pylab_helpers.Gcf)} {plt._pylab_helpers.Gcf.figs!r}'\r\nget_backend()\r\nafter = f'{id(plt._pylab_helpers.Gcf)} {plt._pylab_helpers.Gcf.figs!r}'\r\n\r\nassert before == after, '\\n' + before + '\\n' + after\r\n```\r\n\r\n\r\n### Actual outcome\r\n\r\n```\r\n---------------------------------------------------------------------------\r\nAssertionError                            Traceback (most recent call last)\r\n<ipython-input-1-fa4d099aa289> in <cell line: 11>()\r\n      9 after = f'{id(plt._pylab_helpers.Gcf)} {plt._pylab_helpers.Gcf.figs!r}'\r\n     10 \r\n---> 11 assert before == after, '\\n' + before + '\\n' + after\r\n     12 \r\n\r\nAssertionError: \r\n94453354309744 OrderedDict([(1, <matplotlib.backends.backend_qt.FigureManagerQT object at 0x7fb33e26c220>)])\r\n94453354309744 OrderedDict()\r\n```\r\n\r\n### Expected outcome\r\n\r\nThe figure should not be missing from `Gcf`.  Consequences of this are, e.g, `plt.close(fig2)` doesn't work because `Gcf.destroy_fig()` can't find it.\r\n\r\n### Additional information\r\n\r\n_No response_\r\n\r\n### Operating system\r\n\r\nXubuntu\r\n\r\n### Matplotlib Version\r\n\r\n3.5.2\r\n\r\n### Matplotlib Backend\r\n\r\nQtAgg\r\n\r\n### Python version\r\n\r\nPython 3.10.4\r\n\r\n### Jupyter version\r\n\r\nn/a\r\n\r\n### Installation\r\n\r\nconda\n",
    "patch": "diff --git a/lib/matplotlib/__init__.py b/lib/matplotlib/__init__.py\n--- a/lib/matplotlib/__init__.py\n+++ b/lib/matplotlib/__init__.py\n@@ -1059,6 +1059,8 @@ def rc_context(rc=None, fname=None):\n     \"\"\"\n     Return a context manager for temporarily changing rcParams.\n \n+    The :rc:`backend` will not be reset by the context manager.\n+\n     Parameters\n     ----------\n     rc : dict\n@@ -1087,7 +1089,8 @@ def rc_context(rc=None, fname=None):\n              plt.plot(x, y)  # uses 'print.rc'\n \n     \"\"\"\n-    orig = rcParams.copy()\n+    orig = dict(rcParams.copy())\n+    del orig['backend']\n     try:\n         if fname:\n             rc_file(fname)\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_14011",
        "decision": "Useful",
        "confidence": "Medium",
        "reason": "Both issues involve improper handling of figure management due to context-specific conditions, suggesting a need for conditional logic to respect user-specified parameters."
      },
      {
        "idx": 2,
        "id": "similar_5302",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about image rendering quality, which is unrelated to figure management or context handling."
      },
      {
        "idx": 3,
        "id": "similar_1625",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about output format limitations, not related to figure management or context handling."
      },
      {
        "idx": 4,
        "id": "similar_1993",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves rendering errors with specific shading techniques, unrelated to figure management or context handling."
      },
      {
        "idx": 5,
        "id": "similar_3011",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about font size customization, which does not relate to figure management or context handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "TypeError on plt.subplot(figure=plt.figure())",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\nWhen calling `plt.subplot` with a `figure` argument, we get:\r\n```\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\nThe argument 'figure' is specified in the [doc](https://matplotlib.org/api/_as_gen/matplotlib.pyplot.subplot.html)\r\n\r\nThe function `plt.subplot` uses `plt.gcf()` to get the current figure. It should check whether a figure was provided, eg. `fig = kwargs.pop('figure') if kwargs.get('figure') else plt.gcf()`\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nplt.subplot(figure=plt.figure())\r\n# OR EVEN\r\nplt.subplot(figure=None)\r\n```\r\n\r\n**Actual outcome**\r\n```                              \r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n<ipython-input-30-bdfa817205a7> in <module>\r\n----> 1 plt.subplot(figure=None)\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/pyplot.py in subplot(*args, **kwargs)\r\n   1082 \r\n   1083     fig = gcf()\r\n-> 1084     a = fig.add_subplot(*args, **kwargs)\r\n   1085     bbox = a.bbox\r\n   1086     byebye = []\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/figure.py in add_subplot(self, *args, **kwargs)\r\n   1347         else:\r\n   1348             projection_class, kwargs, key = process_projection_requirements(\r\n-> 1349                 self, *args, **kwargs)\r\n   1350 \r\n   1351             # try to find the axes with this key in the stack\r\n\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\n\r\n**Matplotlib version**\r\n  * Operating system: Linux\r\n  * Matplotlib version: 3.0.2 (with conda and with pip)\r\n  * Matplotlib backend: Qt5Agg\r\n  * Python version: tested on 3.7.2 and 3.5\r\n\r\n",
        "issue_id": 14011,
        "pr_number": 14014,
        "pr_title": "Disallow figure argument for pyplot.subplot() and Figure.add_subplot()",
        "pr_body": "## PR Summary\r\n\r\nCloses #14011.\r\n\r\n`Figure.add_subplot()` and `pyplot.subplot()` have technically accepted a `figure` keyword argument by allowing all keywords from the `Axes` constructor.\r\n\r\nIn this context, supplying a figure does not make sense since the axes should be bound to `self` or the current figure respecively.\r\n\r\nI'm daring to go without a deprecation since this anyway did only work so far if the user supplied the same figure that would have been used without the parameter. Please let me know if that's too bold and we should deprecate this first.",
        "issue_closed_at": "2019-05-28T22:25:29Z",
        "base_commit": "559925e3ec43a5cbe1697a4496482d38d8489f68"
      },
      "summary": "### Summary:\nThis issue pertains to an error encountered when invoking the `plt.subplot` function from the Matplotlib library with an explicit `figure` argument. The problem is characterized by a `TypeError` indicating that the `process_projection_requirements` function received multiple values for the 'figure' argument. This error arises because the `plt.subplot` function inadvertently attempts to use the current figure obtained through `plt.gcf()` without properly checking if the 'figure' argument has been explicitly provided by the user. Consequently, this leads to a conflict in argument values.\n\nKey symptoms include the inability to specify a figure object as an argument to `plt.subplot`, resulting in a traceback error and disruption of the intended plotting operation. The affected components are primarily the `subplot` function from the `matplotlib.pyplot` module and the `add_subplot` method of the `Figure` class within the Matplotlib library.\n\nThe impact of this issue is significant for users requiring precise control over figure management in their plotting routines, potentially affecting any scripts or applications relying on this functionality. The severity is moderate as it disrupts specific use cases but does not cause system-wide failures.\n\nFrom a technical perspective, the solution involves modifying the `plt.subplot` function to conditionally use the provided 'figure' argument if present, falling back to the default current figure only when necessary. This adjustment ensures compatibility with the documented API while maintaining backward compatibility with existing code relying on default behavior.",
      "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: TypeError on plt.subplot(figure=plt.figure())\n\nBody:\n### Bug report\r\n\r\n**Bug summary**\r\nWhen calling `plt.subplot` with a `figure` argument, we get:\r\n```\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\nThe argument 'figure' is specified in the [doc](https://matplotlib.org/api/_as_gen/matplotlib.pyplot.subplot.html)\r\n\r\nThe function `plt.subplot` uses `plt.gcf()` to get the current figure. It should check whether a figure was provided, eg. `fig = kwargs.pop('figure') if kwargs.get('figure') else plt.gcf()`\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nplt.subplot(figure=plt.figure())\r\n# OR EVEN\r\nplt.subplot(figure=None)\r\n```\r\n\r\n**Actual outcome**\r\n```                              \r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n<ipython-input-30-bdfa817205a7> in <module>\r\n----> 1 plt.subplot(figure=None)\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/pyplot.py in subplot(*args, **kwargs)\r\n   1082 \r\n   1083     fig = gcf()\r\n-> 1084     a = fig.add_subplot(*args, **kwargs)\r\n   1085     bbox = a.bbox\r\n   1086     byebye = []\r\n\r\n~/bin/anaconda3/lib/python3.7/site-packages/matplotlib/figure.py in add_subplot(self, *args, **kwargs)\r\n   1347         else:\r\n   1348             projection_class, kwargs, key = process_projection_requirements(\r\n-> 1349                 self, *args, **kwargs)\r\n   1350 \r\n   1351             # try to find the axes with this key in the stack\r\n\r\nTypeError: process_projection_requirements() got multiple values for argument 'figure'\r\n```\r\n\r\n**Matplotlib version**\r\n  * Operating system: Linux\r\n  * Matplotlib version: 3.0.2 (with conda and with pip)\r\n  * Matplotlib backend: Qt5Agg\r\n  * Python version: tested on 3.7.2 and 3.5\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/figure.py\n  function: Figure.add_subplot\n  function: Figure.add_subplot\n\nlib/matplotlib/pyplot.py\n  function: subplot\n"
    },
    {
      "similar_issue": {
        "issue_title": "Pixelated fonts when plot saved as jpeg",
        "issue_body": "I have noticed that when you save figures as jpeg using the nbagg backend you will get pixelated fonts for labels and tickmarks.  It appears this has to do with giving PIL raw data with transparent regions when trying to save jpeg images.  This can be avoided with setting: rcParams['nbagg.transparent'] = False.\n\nIs this behavior desired?  Perhaps there is a way we can assign default values that will be called for when you have a transparency in a figure and you are trying to save it to a file format that doesn't support transparency?\n\nPlease see http://stackoverflow.com/questions/33283274/pixelated-fonts-when-plot-is-saved-as-jpeg for more information.\n",
        "issue_id": 5302,
        "pr_number": 5324,
        "pr_title": "Fix #5302: Proper alpha-blending for jpeg",
        "pr_body": "Saving a JPEG with an alpha channel doesn't look right -- I think pillow just removes the alpha channel altogether and uses the rest of the RGB values as-is.\n\nThis blends RGBA images onto a white background before saving.\n\nThis is JPEG-specific since it's our only raster output file format that doesn't support alpha blending.  If we ever grow another (unlikely) this will need to be duplicated there.\n",
        "issue_closed_at": "2015-10-28T22:45:18Z",
        "base_commit": "0e6ca435d132edd6c2274770de306d80e5a8f0a8"
      },
      "summary": "### Summary:\nThis issue pertains to the rendering and saving of graphical figures using the nbagg backend in a software library, leading to pixelated text elements when figures are saved in JPEG format. The root cause is identified as the handling of transparency in images, which JPEG does not support, resulting in undesirable visual artifacts like pixelated fonts in labels and tickmarks. This problem is linked to the software's use of the Python Imaging Library (PIL) when it receives raw data with transparent regions, causing the pixelation issue.\n\nKey symptoms include the degradation of font clarity in saved JPEG images, which is specifically noticed in text elements like labels and tickmarks. This affects users who rely on the nbagg backend for rendering figures and opt to save them in JPEG format.\n\nThe affected components include the matplotlib library, particularly the backend_agg module, which is responsible for rendering figures and handling image output. The severity of the issue is moderate, as it impacts the quality of graphical outputs and could hinder the presentation quality of visual data.\n\nIn terms of technical details, the problem can be mitigated by configuring the rcParams setting `nbagg.transparent` to False, which disables transparency when saving figures. This points to a broader need for establishing default configurations that align with the limitations of different file formats, ensuring compatibility without compromising image quality.",
      "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: Pixelated fonts when plot saved as jpeg\n\nBody:\nI have noticed that when you save figures as jpeg using the nbagg backend you will get pixelated fonts for labels and tickmarks.  It appears this has to do with giving PIL raw data with transparent regions when trying to save jpeg images.  This can be avoided with setting: rcParams['nbagg.transparent'] = False.\n\nIs this behavior desired?  Perhaps there is a way we can assign default values that will be called for when you have a transparency in a figure and you are trying to save it to a file format that doesn't support transparency?\n\nPlease see http://stackoverflow.com/questions/33283274/pixelated-fonts-when-plot-is-saved-as-jpeg for more information.\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_agg.py\n  line: line 38\n  function: FigureCanvasAgg.print_to_buffer\n  function: FigureCanvasAgg.print_jpg\n"
    },
    {
      "similar_issue": {
        "issue_title": "saving pgf to a stream is not supported",
        "issue_body": "Hi,\n\nThe pgf output does not support a stream as illustrated by this snippet\n\n``` python\nimport sys\nplt.plot([1,2])\nplt.savefig(sys.stdout, format='pgf')\n```\n\nIt returns:\n\n``` python\nValueError: saving pgf to a stream is not supported, consider using the pdf option of the pgf-backend\n```\n\nOther formats like png, eps, ps, svg support it. I don't see any good reason to do not support streams for pgf and I guess it is a bug :)\n\nThanks.\n",
        "issue_id": 1625,
        "pr_number": 2587,
        "pr_title": "Make backend_pgf more flexible when saving to file-handles or streams (fix #1625).",
        "pr_body": "Since binary data and thus raster images cannot be embedded in pgf code, saving to a stream was prohibited in backend_pgf. This PR allows saving pgf code to streams after deactivating draw_image() and emitting a user warning.\n\nI'll merge this in a few days if there are no objections (fixing issue #1625).\n",
        "issue_closed_at": "2013-11-12T13:20:52Z",
        "base_commit": "c91589c024aa4c95288173112d3d5c44e1703d27"
      },
      "summary": "### Summary: This issue pertains to the inability of the Matplotlib library to save figures in the PGF format directly to a stream, such as `sys.stdout`. The PGF format, which is commonly used for creating graphics in LaTeX documents, lacks support for stream output, which is a feature available in other supported formats like PNG, EPS, PS, and SVG. The reported problem results in a `ValueError` when attempting to save a PGF formatted figure to a stream, suggesting a limitation or oversight in the backend's implementation. This issue affects the PGF backend of Matplotlib, specifically within the `FigureManagerPgf.__init__` and `FigureCanvasPgf.print_pgf` functions. The severity is moderate as it limits flexibility and might hinder workflows that rely on stream outputs for PGF, potentially affecting users who utilize Matplotlib for generating LaTeX-compatible graphics. The fix involves modifications to the backend's code to accommodate stream handling for PGF output, aligning its capabilities with other output formats supported by Matplotlib.",
      "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: saving pgf to a stream is not supported\n\nBody:\nHi,\n\nThe pgf output does not support a stream as illustrated by this snippet\n\n``` python\nimport sys\nplt.plot([1,2])\nplt.savefig(sys.stdout, format='pgf')\n```\n\nIt returns:\n\n``` python\nValueError: saving pgf to a stream is not supported, consider using the pdf option of the pgf-backend\n```\n\nOther formats like png, eps, ps, svg support it. I don't see any good reason to do not support streams for pgf and I guess it is a bug :)\n\nThanks.\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_pgf.py\n  line: line 12\n  function: FigureManagerPgf.__init__\n  function: FigureCanvasPgf.print_pgf\n"
    },
    {
      "similar_issue": {
        "issue_title": "PS backend fails to savefig() pcolormesh with gouraud shading",
        "issue_body": "Following script\n\n``` python\nimport numpy as np\nfrom matplotlib.pyplot import figure, savefig\n\nn = 12\nx = np.linspace(-1.5,1.5,n)\ny = np.linspace(-1.5,1.5,n*2)\nX,Y = np.meshgrid(x,y);\n\nQx = np.cos(Y) - np.cos(X)\nQz = np.sin(Y) + np.sin(X)\nQx = (Qx + 1.1)\nZ = np.sqrt(X**2 + Y**2)/5;\nZ = (Z - Z.min()) / (Z.max() - Z.min())\n\nfig = figure()\nax = fig.add_subplot(111)\nax.pcolormesh(Qx,Qz,Z, shading='gouraud')\nsavefig('bug.eps')\n```\n\nresults in\n\n``` text\nTraceback (most recent call last):\n  File \"quad.py\", line 20, in <module>\n    savefig('bug.eps')\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/pyplot.py\", line 494, in savefig\n    return fig.savefig(*args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/figure.py\", line 1403, in savefig\n    self.canvas.print_figure(*args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_qt4agg.py\", line 161, in print_figure\n    FigureCanvasAgg.print_figure(self, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backend_bases.py\", line 2158, in print_figure\n    **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backend_bases.py\", line 1886, in print_eps\n    return ps.print_eps(*args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 974, in print_eps\n    return self._print_ps(outfile, 'eps', *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 1002, in _print_ps\n    **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 1095, in _print_figure\n    self.figure.draw(renderer)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/artist.py\", line 54, in draw_wrapper\n    draw(artist, renderer, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/figure.py\", line 1027, in draw\n    func(*args)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/artist.py\", line 54, in draw_wrapper\n    draw(artist, renderer, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/axes.py\", line 2086, in draw\n    a.draw(renderer)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/artist.py\", line 54, in draw_wrapper\n    draw(artist, renderer, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/collections.py\", line 1745, in draw\n    gc, triangles, colors, transform.frozen())\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 827, in draw_gouraud_triangles\n    points = trans.transform(points)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/transforms.py\", line 1561, in transform\n    return self.transform_affine(values)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/transforms.py\", line 1645, in transform_affine\n    return affine_transform(points, mtx)\nValueError: Invalid vertices array.\n```\n\nTested with\n\n``` text\ncommit af07100823d219e51f061cfc8e96d957fa661126\n\nBUILDING MATPLOTLIB\n            matplotlib: yes [1.3.x]\n                python: yes [2.7.4 (default, Apr 21 2013, 14:51:13)  [GCC\n                        4.7.2]]\n              platform: yes [linux2]\n\nREQUIRED DEPENDENCIES AND EXTENSIONS\n                 numpy: yes [version 1.6.2]\n              dateutil: yes [using dateutil version 2.1]\n               tornado: yes [using tornado version 2.3]\n             pyparsing: yes [using pyparsing version 1.5.7]\n                 pycxx: yes [pkg-config information for 'PyCXX' could not be\n                        found. Using local copy.]\n                libagg: yes [pkg-config information for 'libagg' could not\n                        be found. Using local copy.]\n              freetype: yes [version 16.0.10]\n                   png: yes [version 1.6.1]\n\nOPTIONAL SUBPACKAGES\n           sample_data: yes [installing]\n              toolkits: yes [installing]\n                 tests: yes [using nose version 1.1.2]\n\nOPTIONAL BACKEND EXTENSIONS\n                macosx: no  [Mac OS-X only]\n                qt4agg: yes [Qt: 4.8.2, PyQt4: 4.9.2]\n               gtk3agg: yes [version 3.3.6]\n             gtk3cairo: yes [version 3.3.6]\n                gtkagg: yes [Gtk: 2.24.17 pygtk: 2.24.0]\n                 tkagg: yes [version 81008]\n                 wxagg: yes [version 2.8.12.1]\n                   gtk: yes [Gtk: 2.24.17 pygtk: 2.24.0]\n                 qtagg: no  [pyqt not found]\n                   agg: yes [installing]\n                 cairo: yes [version 1.10.0]\n\nOPTIONAL LATEX DEPENDENCIES\n                dvipng: yes [version Larsson]\n           ghostscript: yes [version 9.06]\n                 latex: yes [version 3.1415926]\n               pdftops: yes [version 0.22.3]\n```\n",
        "issue_id": 1993,
        "pr_number": 1993,
        "pr_title": "PS backend fails to savefig() pcolormesh with gouraud shading",
        "pr_body": "Following script\n\n``` python\nimport numpy as np\nfrom matplotlib.pyplot import figure, savefig\n\nn = 12\nx = np.linspace(-1.5,1.5,n)\ny = np.linspace(-1.5,1.5,n*2)\nX,Y = np.meshgrid(x,y);\n\nQx = np.cos(Y) - np.cos(X)\nQz = np.sin(Y) + np.sin(X)\nQx = (Qx + 1.1)\nZ = np.sqrt(X**2 + Y**2)/5;\nZ = (Z - Z.min()) / (Z.max() - Z.min())\n\nfig = figure()\nax = fig.add_subplot(111)\nax.pcolormesh(Qx,Qz,Z, shading='gouraud')\nsavefig('bug.eps')\n```\n\nresults in\n\n``` text\nTraceback (most recent call last):\n  File \"quad.py\", line 20, in <module>\n    savefig('bug.eps')\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/pyplot.py\", line 494, in savefig\n    return fig.savefig(*args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/figure.py\", line 1403, in savefig\n    self.canvas.print_figure(*args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_qt4agg.py\", line 161, in print_figure\n    FigureCanvasAgg.print_figure(self, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backend_bases.py\", line 2158, in print_figure\n    **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backend_bases.py\", line 1886, in print_eps\n    return ps.print_eps(*args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 974, in print_eps\n    return self._print_ps(outfile, 'eps', *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 1002, in _print_ps\n    **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 1095, in _print_figure\n    self.figure.draw(renderer)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/artist.py\", line 54, in draw_wrapper\n    draw(artist, renderer, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/figure.py\", line 1027, in draw\n    func(*args)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/artist.py\", line 54, in draw_wrapper\n    draw(artist, renderer, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/axes.py\", line 2086, in draw\n    a.draw(renderer)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/artist.py\", line 54, in draw_wrapper\n    draw(artist, renderer, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/collections.py\", line 1745, in draw\n    gc, triangles, colors, transform.frozen())\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 827, in draw_gouraud_triangles\n    points = trans.transform(points)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/transforms.py\", line 1561, in transform\n    return self.transform_affine(values)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/transforms.py\", line 1645, in transform_affine\n    return affine_transform(points, mtx)\nValueError: Invalid vertices array.\n```\n\nTested with\n\n``` text\ncommit af07100823d219e51f061cfc8e96d957fa661126\n\nBUILDING MATPLOTLIB\n            matplotlib: yes [1.3.x]\n                python: yes [2.7.4 (default, Apr 21 2013, 14:51:13)  [GCC\n                        4.7.2]]\n              platform: yes [linux2]\n\nREQUIRED DEPENDENCIES AND EXTENSIONS\n                 numpy: yes [version 1.6.2]\n              dateutil: yes [using dateutil version 2.1]\n               tornado: yes [using tornado version 2.3]\n             pyparsing: yes [using pyparsing version 1.5.7]\n                 pycxx: yes [pkg-config information for 'PyCXX' could not be\n                        found. Using local copy.]\n                libagg: yes [pkg-config information for 'libagg' could not\n                        be found. Using local copy.]\n              freetype: yes [version 16.0.10]\n                   png: yes [version 1.6.1]\n\nOPTIONAL SUBPACKAGES\n           sample_data: yes [installing]\n              toolkits: yes [installing]\n                 tests: yes [using nose version 1.1.2]\n\nOPTIONAL BACKEND EXTENSIONS\n                macosx: no  [Mac OS-X only]\n                qt4agg: yes [Qt: 4.8.2, PyQt4: 4.9.2]\n               gtk3agg: yes [version 3.3.6]\n             gtk3cairo: yes [version 3.3.6]\n                gtkagg: yes [Gtk: 2.24.17 pygtk: 2.24.0]\n                 tkagg: yes [version 81008]\n                 wxagg: yes [version 2.8.12.1]\n                   gtk: yes [Gtk: 2.24.17 pygtk: 2.24.0]\n                 qtagg: no  [pyqt not found]\n                   agg: yes [installing]\n                 cairo: yes [version 1.10.0]\n\nOPTIONAL LATEX DEPENDENCIES\n                dvipng: yes [version Larsson]\n           ghostscript: yes [version 9.06]\n                 latex: yes [version 3.1415926]\n               pdftops: yes [version 0.22.3]\n```\n",
        "issue_closed_at": "2013-05-16T16:07:26Z",
        "base_commit": "f3f345022481db548d7fdabcfe297925b08ca436"
      },
      "summary": "### Summary:\nThis issue is a bug related to the Matplotlib library, specifically involving the PostScript (PS) backend's inability to correctly handle and save figures generated with pcolormesh using Gouraud shading. When attempting to execute a script that uses the `pcolormesh` function with Gouraud shading and subsequently save the figure as an EPS file, the operation fails, resulting in a traceback error. This error is due to an invalid vertices array being passed during the transformation process within the rendering pipeline of the PS backend.\n\n1. **Problem Description in General Terms:** \n   The problem occurs when saving a plot as an EPS file using the PS backend in Matplotlib, particularly when the plot involves a pcolormesh with Gouraud shading. The saving process fails due to an invalid transformation of vertices.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - Execution of a script that attempts to save a figure using `savefig('bug.eps')` raises a `ValueError` with the message \"Invalid vertices array.\"\n   - The error occurs during the rendering process, specifically in the `draw_gouraud_triangles` function, indicating a failure in handling the transformation of geometric data.\n\n3. **Affected Components or Systems:**\n   - Matplotlib's PS backend is the primary component affected by this issue.\n   - The function `draw_gouraud_triangles` within the `backend_ps.py` file is directly involved in the error.\n\n4. **Potential Impact or Severity:**\n   - The issue prevents users from saving figures as EPS files when using Gouraud shading with pcolormesh, which can be critical for those relying on this functionality for publication-quality graphics.\n   - This bug could impact users needing to generate specific visualizations in EPS format, a common requirement for high-resolution printing and publications.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The problem stems from the transformation operations applied to vertex data within the rendering process.\n   - The issue was tested on a specific version of Matplotlib (1.3.x) and Python (2.7.4) on a Linux platform, indicating potential compatibility or regression issues with this configuration.\n   - The fix involves updates to the `draw_gouraud_triangles` function within the `backend_ps.py` file to correctly handle and transform vertex data for Gouraud shading.",
      "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: PS backend fails to savefig() pcolormesh with gouraud shading\n\nBody:\nFollowing script\n\n``` python\nimport numpy as np\nfrom matplotlib.pyplot import figure, savefig\n\nn = 12\nx = np.linspace(-1.5,1.5,n)\ny = np.linspace(-1.5,1.5,n*2)\nX,Y = np.meshgrid(x,y);\n\nQx = np.cos(Y) - np.cos(X)\nQz = np.sin(Y) + np.sin(X)\nQx = (Qx + 1.1)\nZ = np.sqrt(X**2 + Y**2)/5;\nZ = (Z - Z.min()) / (Z.max() - Z.min())\n\nfig = figure()\nax = fig.add_subplot(111)\nax.pcolormesh(Qx,Qz,Z, shading='gouraud')\nsavefig('bug.eps')\n```\n\nresults in\n\n``` text\nTraceback (most recent call last):\n  File \"quad.py\", line 20, in <module>\n    savefig('bug.eps')\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/pyplot.py\", line 494, in savefig\n    return fig.savefig(*args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/figure.py\", line 1403, in savefig\n    self.canvas.print_figure(*args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_qt4agg.py\", line 161, in print_figure\n    FigureCanvasAgg.print_figure(self, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backend_bases.py\", line 2158, in print_figure\n    **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backend_bases.py\", line 1886, in print_eps\n    return ps.print_eps(*args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 974, in print_eps\n    return self._print_ps(outfile, 'eps', *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 1002, in _print_ps\n    **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 1095, in _print_figure\n    self.figure.draw(renderer)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/artist.py\", line 54, in draw_wrapper\n    draw(artist, renderer, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/figure.py\", line 1027, in draw\n    func(*args)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/artist.py\", line 54, in draw_wrapper\n    draw(artist, renderer, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/axes.py\", line 2086, in draw\n    a.draw(renderer)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/artist.py\", line 54, in draw_wrapper\n    draw(artist, renderer, *args, **kwargs)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/collections.py\", line 1745, in draw\n    gc, triangles, colors, transform.frozen())\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/backends/backend_ps.py\", line 827, in draw_gouraud_triangles\n    points = trans.transform(points)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/transforms.py\", line 1561, in transform\n    return self.transform_affine(values)\n  File \"/tmp/matplotlib/build/lib.linux-x86_64-2.7/matplotlib/transforms.py\", line 1645, in transform_affine\n    return affine_transform(points, mtx)\nValueError: Invalid vertices array.\n```\n\nTested with\n\n``` text\ncommit af07100823d219e51f061cfc8e96d957fa661126\n\nBUILDING MATPLOTLIB\n            matplotlib: yes [1.3.x]\n                python: yes [2.7.4 (default, Apr 21 2013, 14:51:13)  [GCC\n                        4.7.2]]\n              platform: yes [linux2]\n\nREQUIRED DEPENDENCIES AND EXTENSIONS\n                 numpy: yes [version 1.6.2]\n              dateutil: yes [using dateutil version 2.1]\n               tornado: yes [using tornado version 2.3]\n             pyparsing: yes [using pyparsing version 1.5.7]\n                 pycxx: yes [pkg-config information for 'PyCXX' could not be\n                        found. Using local copy.]\n                libagg: yes [pkg-config information for 'libagg' could not\n                        be found. Using local copy.]\n              freetype: yes [version 16.0.10]\n                   png: yes [version 1.6.1]\n\nOPTIONAL SUBPACKAGES\n           sample_data: yes [installing]\n              toolkits: yes [installing]\n                 tests: yes [using nose version 1.1.2]\n\nOPTIONAL BACKEND EXTENSIONS\n                macosx: no  [Mac OS-X only]\n                qt4agg: yes [Qt: 4.8.2, PyQt4: 4.9.2]\n               gtk3agg: yes [version 3.3.6]\n             gtk3cairo: yes [version 3.3.6]\n                gtkagg: yes [Gtk: 2.24.17 pygtk: 2.24.0]\n                 tkagg: yes [version 81008]\n                 wxagg: yes [version 2.8.12.1]\n                   gtk: yes [Gtk: 2.24.17 pygtk: 2.24.0]\n                 qtagg: no  [pyqt not found]\n                   agg: yes [installing]\n                 cairo: yes [version 1.10.0]\n\nOPTIONAL LATEX DEPENDENCIES\n                dvipng: yes [version Larsson]\n           ghostscript: yes [version 9.06]\n                 latex: yes [version 3.1415926]\n               pdftops: yes [version 0.22.3]\n```\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: RendererPS.draw_gouraud_triangles\n"
    },
    {
      "similar_issue": {
        "issue_title": "Allow to customize default font size for suptitle() in matplotlibrc",
        "issue_body": "It seems that suptitle() is using the default font size and there's no way to customize the default font size, while title() is using axes.titlesize.\n\nI always have to specify the 'size' parameter when using suptitle, which is inconvenient.\n\nI'd love to have a \"figure.titlesize\", which defaults to 'xx-large' for consistency.\n",
        "issue_id": 3011,
        "pr_number": 3083,
        "pr_title": "New rcParams to set pyplot.suptitle() defaults",
        "pr_body": "Two new rcParams are introduced:\n- figure.titlesize (xx-large)\n- figure.titleweight (normal)\n\nAllow to set the pyplot.suptitle() default font size and weight.\n\nFixes #3011\n",
        "issue_closed_at": "2014-11-13T17:20:52Z",
        "base_commit": "ed953827850179256c09996ac7a7a80e7d291aa6"
      },
      "summary": "### Summary:\nThis issue relates to the customization capabilities of font sizes within the Matplotlib library, specifically focusing on the suptitle() function. The problem identified is the lack of a customizable default font size for suptitle(), unlike the title() function, which uses axes.titlesize for its default. This discrepancy forces users to manually specify the 'size' parameter each time they use suptitle(), leading to inconvenience and inconsistency in workflow. The proposed solution is to introduce a \"figure.titlesize\" setting that defaults to 'xx-large' to harmonize font size management across different title functions in Matplotlib.\n\nKey symptoms and behaviors observed include the inability to set a default font size for suptitle(), resulting in repetitive manual configuration. The affected components are primarily within the Matplotlib library, specifically the Figure.suptitle function and related configuration settings in rcsetup.py. The potential impact of this issue is primarily centered around user inconvenience and the inconsistency in font size management, which can affect the readability and visual consistency of figures generated using Matplotlib. Relevant technical details include the addition of a \"figure.titlesize\" parameter to allow users to define a default font size for suptitle(), improving user experience and maintaining consistency with other title functions.",
      "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: Allow to customize default font size for suptitle() in matplotlibrc\n\nBody:\nIt seems that suptitle() is using the default font size and there's no way to customize the default font size, while title() is using axes.titlesize.\n\nI always have to specify the 'size' parameter when using suptitle, which is inconvenient.\n\nI'd love to have a \"figure.titlesize\", which defaults to 'xx-large' for consistency.\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/figure.py\n  function: Figure.suptitle\n\nlib/matplotlib/rcsetup.py\n  function: ValidateInterval.__call__\n"
    }
  ]
}