{
  "original_problem": {
    "instance_id": "mwaskom__seaborn-3190",
    "repo": "mwaskom/seaborn",
    "created_at": "2022-12-18T17:13:51Z",
    "problem_statement": "Color mapping fails with boolean data\n```python\r\nso.Plot([\"a\", \"b\"], [1, 2], color=[True, False]).add(so.Bar())\r\n```\r\n```python-traceback\r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n...\r\nFile ~/code/seaborn/seaborn/_core/plot.py:841, in Plot._plot(self, pyplot)\r\n    838 plotter._compute_stats(self, layers)\r\n    840 # Process scale spec for semantic variables and coordinates computed by stat\r\n--> 841 plotter._setup_scales(self, common, layers)\r\n    843 # TODO Remove these after updating other methods\r\n    844 # ---- Maybe have debug= param that attaches these when True?\r\n    845 plotter._data = common\r\n\r\nFile ~/code/seaborn/seaborn/_core/plot.py:1252, in Plotter._setup_scales(self, p, common, layers, variables)\r\n   1250     self._scales[var] = Scale._identity()\r\n   1251 else:\r\n-> 1252     self._scales[var] = scale._setup(var_df[var], prop)\r\n   1254 # Everything below here applies only to coordinate variables\r\n   1255 # We additionally skip it when we're working with a value\r\n   1256 # that is derived from a coordinate we've already processed.\r\n   1257 # e.g., the Stat consumed y and added ymin/ymax. In that case,\r\n   1258 # we've already setup the y scale and ymin/max are in scale space.\r\n   1259 if axis is None or (var != coord and coord in p._variables):\r\n\r\nFile ~/code/seaborn/seaborn/_core/scales.py:351, in ContinuousBase._setup(self, data, prop, axis)\r\n    349 vmin, vmax = axis.convert_units((vmin, vmax))\r\n    350 a = forward(vmin)\r\n--> 351 b = forward(vmax) - forward(vmin)\r\n    353 def normalize(x):\r\n    354     return (x - a) / b\r\n\r\nTypeError: numpy boolean subtract, the `-` operator, is not supported, use the bitwise_xor, the `^` operator, or the logical_xor function instead.\r\n```\n",
    "patch": "diff --git a/seaborn/_core/scales.py b/seaborn/_core/scales.py\n--- a/seaborn/_core/scales.py\n+++ b/seaborn/_core/scales.py\n@@ -346,7 +346,7 @@ def _setup(\n                 vmin, vmax = data.min(), data.max()\n             else:\n                 vmin, vmax = new.norm\n-            vmin, vmax = axis.convert_units((vmin, vmax))\n+            vmin, vmax = map(float, axis.convert_units((vmin, vmax)))\n             a = forward(vmin)\n             b = forward(vmax) - forward(vmin)\n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_2465",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves parameter handling logic rather than type conversion or arithmetic operations."
      },
      {
        "idx": 2,
        "id": "similar_2295",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about handling NaN values in categorical data, which is unrelated to boolean arithmetic operations."
      },
      {
        "idx": 3,
        "id": "similar_3058",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about custom color map handling, not related to type conversion or arithmetic operations."
      },
      {
        "idx": 4,
        "id": "similar_2976",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves axis label visibility, which is unrelated to type conversion or arithmetic operations."
      },
      {
        "idx": 5,
        "id": "similar_2317",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about data type interpretation for plotting, not about handling boolean arithmetic operations."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "bivariate displot with kind=\"hist\" ignores common_norm=False if hue is not assigned",
        "issue_body": "Somehow similar to #2377, but for `kind='hist'` and with `common_norm=False` being ignored.\r\n\r\nIf I understand it well, passing `common_norm=False` to `sns.distplot` should produce plots with independent \"z\" scale. While this is the behaviour for kde plots, it seems to be ignored for bivariate histograms unless hue is also specified.\r\n\r\nTest case:\r\n```python\r\nx, y = np.random.randn(2, 200)\r\nz = [0] * 150 + [1] * 50\r\nsns.displot(x=x, y=y, col=z, kind=\"hist\", cbar=True, common_norm=False)\r\nsns.displot(x=x, y=y, col=z, hue=z, kind=\"hist\", cbar=True, common_norm=False)\r\n```\r\n\r\nRunning seaborn version 0.11.1\r\n(I tried to look for other (open or closed) related issues, hope not duplicating them)",
        "issue_id": 2465,
        "pr_number": 2468,
        "pr_title": "Fix faceted bivariate histogram normalization at displot",
        "pr_body": "Fixes #2465",
        "issue_closed_at": "2021-02-05T01:20:16Z",
        "base_commit": "beb7f822895375143de396659cb562465ade25d7"
      },
      "summary": "### Summary:\nThis issue pertains to a functionality inconsistency in the seaborn data visualization library, specifically with the `displot` function when generating bivariate histograms. The problem arises when the `common_norm=False` parameter, which is intended to ensure that each subplot has its independent z-scale, is ignored unless a `hue` argument is specified.\n\n1. **Problem Description in General Terms:**\n   The problem involves an unexpected behavior in data visualization where the intended normalization of histogram scales is not applied when certain parameters are omitted. This affects the visual interpretation of data by not displaying each subplot's histograms on an independent scale as expected.\n\n2. **Key Symptoms and Behaviors Observed:**\n   When users create bivariate histograms with `common_norm=False`, the histogram plots do not reflect independent z-scales, contrary to the expected functionality. This behavior is consistent unless the `hue` parameter is also provided, which then correctly applies independent normalization.\n\n3. **Affected Components or Systems:**\n   The issue specifically affects the seaborn library's `displot` function, particularly in configurations for bivariate histograms. The relevant code is located in the `plot_bivariate_histogram` method within the `seaborn/distributions.py` module.\n\n4. **Potential Impact or Severity:**\n   The impact of this issue primarily affects data analysts and scientists relying on accurate visual representations of their data. Incorrect normalization can lead to misinterpretation of data distributions when comparing subplots, potentially affecting decision-making processes. The severity is moderate, given it impacts visualization accuracy but does not crash the system or data integrity.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The issue is linked to the internal logic of the seaborn library, where the condition to apply `common_norm` is not appropriately checked unless a `hue` parameter is present. This suggests a need for code adjustment in the handling of normalization logic within the bivariate histogram plotting function to ensure consistent behavior across different parameter configurations.",
      "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: bivariate displot with kind=\"hist\" ignores common_norm=False if hue is not assigned\n\nBody:\nSomehow similar to #2377, but for `kind='hist'` and with `common_norm=False` being ignored.\r\n\r\nIf I understand it well, passing `common_norm=False` to `sns.distplot` should produce plots with independent \"z\" scale. While this is the behaviour for kde plots, it seems to be ignored for bivariate histograms unless hue is also specified.\r\n\r\nTest case:\r\n```python\r\nx, y = np.random.randn(2, 200)\r\nz = [0] * 150 + [1] * 50\r\nsns.displot(x=x, y=y, col=z, kind=\"hist\", cbar=True, common_norm=False)\r\nsns.displot(x=x, y=y, col=z, hue=z, kind=\"hist\", cbar=True, common_norm=False)\r\n```\r\n\r\nRunning seaborn version 0.11.1\r\n(I tried to look for other (open or closed) related issues, hope not duplicating them)\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:\nseaborn/distributions.py\n  function: _DistributionPlotter.plot_bivariate_histogram\n"
    },
    {
      "similar_issue": {
        "issue_title": "histplot with categorical values crashes with missing data, though numerical values work fine",
        "issue_body": "Not sure if this is intended behaviour, but it caught me out due to the difference in handling numerical/categorical data. I note that drawing histograms of categorical data is labelled as experimental, so ignore/close if that explains it.\r\n\r\nWith numerical data `histplot` ignores NaN and plots the other values, this is the behaviour I would expect:\r\n\r\n```\r\nimport numpy as np\r\nimport seaborn as sns\r\n\r\nsns.histplot(\r\n    [1.1, 1.2, 1.3, 1.4, np.nan]\r\n)\r\n```\r\n\r\nbut with categorical data it crashes:\r\n```\r\nimport numpy as np\r\nimport seaborn as sns\r\n\r\nsns.histplot(\r\n    ['foo', 'foo', 'bar', np.nan]\r\n)\r\n\r\n# output\r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/axis.py in convert_units(self, x)\r\n   1519         try:\r\n-> 1520             ret = self.converter.convert(x, self.units, self)\r\n   1521         except Exception as e:\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/category.py in convert(value, unit, axis)\r\n     60         # force an update so it also does type checking\r\n---> 61         unit.update(values)\r\n     62         return np.vectorize(unit._mapping.__getitem__, otypes=[float])(values)\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/category.py in update(self, data)\r\n    210             # OrderedDict just iterates over unique values in data.\r\n--> 211             cbook._check_isinstance((str, bytes), value=val)\r\n    212             if convertible:\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/cbook/__init__.py in _check_isinstance(_types, **kwargs)\r\n   2234         if not isinstance(v, types):\r\n-> 2235             raise TypeError(\r\n   2236                 \"{!r} must be an instance of {}, not a {}\".format(\r\n\r\nTypeError: 'value' must be an instance of str or bytes, not a float\r\n\r\nThe above exception was the direct cause of the following exception:\r\n\r\nConversionError                           Traceback (most recent call last)\r\n<ipython-input-61-b132ea7dca6c> in <module>\r\n      2 import seaborn as sns\r\n      3 \r\n----> 4 sns.histplot(\r\n      5     ['foo', 'foo', 'bar', np.nan]\r\n      6 )\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/seaborn/distributions.py in histplot(data, x, y, hue, weights, stat, bins, binwidth, binrange, discrete, cumulative, common_bins, common_norm, multiple, element, fill, shrink, kde, kde_kws, line_kws, thresh, pthresh, pmax, cbar, cbar_ax, cbar_kws, palette, hue_order, hue_norm, color, log_scale, legend, ax, **kwargs)\r\n   1420     if p.univariate:\r\n   1421 \r\n-> 1422         p.plot_univariate_histogram(\r\n   1423             multiple=multiple,\r\n   1424             element=element,\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/seaborn/distributions.py in plot_univariate_histogram(self, multiple, element, fill, common_norm, common_bins, shrink, kde, kde_kws, color, legend, line_kws, estimate_kws, **plot_kws)\r\n    421 \r\n    422         # First pass through the data to compute the histograms\r\n--> 423         for sub_vars, sub_data in self.iter_data(\"hue\", from_comp_data=True):\r\n    424 \r\n    425             # Prepare the relevant data\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/seaborn/_core.py in iter_data(self, grouping_vars, reverse, from_comp_data)\r\n    965 \r\n    966         if from_comp_data:\r\n--> 967             data = self.comp_data\r\n    968         else:\r\n    969             data = self.plot_data\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/seaborn/_core.py in comp_data(self)\r\n   1034                 axis = getattr(ax, f\"{var}axis\")\r\n   1035 \r\n-> 1036                 comp_var = axis.convert_units(self.plot_data[var])\r\n   1037                 if axis.get_scale() == \"log\":\r\n   1038                     comp_var = np.log10(comp_var)\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/axis.py in convert_units(self, x)\r\n   1520             ret = self.converter.convert(x, self.units, self)\r\n   1521         except Exception as e:\r\n-> 1522             raise munits.ConversionError('Failed to convert value(s) to axis '\r\n   1523                                          f'units: {x!r}') from e\r\n   1524         return ret\r\n\r\nConversionError: Failed to convert value(s) to axis units: 0    foo\r\n1    foo\r\n2    bar\r\n3    NaN\r\nName: x, dtype: object\r\n```\r\n\r\n",
        "issue_id": 2295,
        "pr_number": 2417,
        "pr_title": "Improve NA robustness in VectorPlotter.comp_data",
        "pr_body": "This PR avoids passing `nan` through the matplotlib converters used to obtain a numeric/computable representation of the data (i.e. `VectorPlotter.comp_data`).\r\n\r\nIt also\r\n- codifies that the converted columns in `comp_data` have a float dtype\r\n- converts `inf` to `nan`, in line with what matplotlib does\r\n\r\nFixes #2295 \r\n\r\nAdditionally this will implicitly address #1971 once the regression plots are refactored to use `comp_data` internally. (@mojones, funny that you opened both issues).",
        "issue_closed_at": "2021-01-05T19:40:57Z",
        "base_commit": "aad96f8d2e36ceceb82a42b69aa3a8f47ef7210d"
      },
      "summary": "### Summary:\nThis issue is related to the behavior of the `histplot` function in the Seaborn library when handling categorical data that includes missing values. The problem arises due to a discrepancy in how the function processes numerical versus categorical data containing NaN values. While numerical data with NaNs is handled gracefully, allowing the plot to be generated by ignoring NaN values, the inclusion of NaN in categorical data results in a TypeError. This error is triggered because the underlying matplotlib library expects categorical data to be of string or byte types, not floats, which is the type of NaN.\n\n1. **Problem description in general terms**: The Seaborn `histplot` function fails to process categorical data containing missing values (NaNs), causing a crash, whereas it handles numerical data with NaNs without issue.\n\n2. **Key symptoms and behaviors observed**: The primary symptom is a TypeError when attempting to generate a histogram of categorical data with NaNs. This error cascades into a ConversionError due to the inability to convert NaN values into the expected string or byte format for categorical data.\n\n3. **Affected components or systems**: The issue affects the `histplot` function within the Seaborn library, specifically when used with categorical data containing NaN values. The error is deeply rooted in the interaction between Seaborn and the matplotlib library's handling of categorical data types.\n\n4. **Potential impact or severity**: This issue can significantly impact users attempting to visualize categorical data with missing values, particularly given that handling missing values is a common requirement in data analysis. The crash prevents users from generating the intended plots, potentially hindering data analysis workflows.\n\n5. **Any relevant technical details abstracted for broader understanding**: The root of the problem lies in the type-checking mechanism within matplotlib's category module, which fails when encountering NaN values in categorical data. This discrepancy highlights the experimental nature of categorical data handling in Seaborn and the need for consistent handling of NaN values across data types. The fix involves adjusting the function in Seaborn's core module to appropriately manage NaN values in categorical data.",
      "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: histplot with categorical values crashes with missing data, though numerical values work fine\n\nBody:\nNot sure if this is intended behaviour, but it caught me out due to the difference in handling numerical/categorical data. I note that drawing histograms of categorical data is labelled as experimental, so ignore/close if that explains it.\r\n\r\nWith numerical data `histplot` ignores NaN and plots the other values, this is the behaviour I would expect:\r\n\r\n```\r\nimport numpy as np\r\nimport seaborn as sns\r\n\r\nsns.histplot(\r\n    [1.1, 1.2, 1.3, 1.4, np.nan]\r\n)\r\n```\r\n\r\nbut with categorical data it crashes:\r\n```\r\nimport numpy as np\r\nimport seaborn as sns\r\n\r\nsns.histplot(\r\n    ['foo', 'foo', 'bar', np.nan]\r\n)\r\n\r\n# output\r\n---------------------------------------------------------------------------\r\nTypeError                                 Traceback (most recent call last)\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/axis.py in convert_units(self, x)\r\n   1519         try:\r\n-> 1520             ret = self.converter.convert(x, self.units, self)\r\n   1521         except Exception as e:\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/category.py in convert(value, unit, axis)\r\n     60         # force an update so it also does type checking\r\n---> 61         unit.update(values)\r\n     62         return np.vectorize(unit._mapping.__getitem__, otypes=[float])(values)\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/category.py in update(self, data)\r\n    210             # OrderedDict just iterates over unique values in data.\r\n--> 211             cbook._check_isinstance((str, bytes), value=val)\r\n    212             if convertible:\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/cbook/__init__.py in _check_isinstance(_types, **kwargs)\r\n   2234         if not isinstance(v, types):\r\n-> 2235             raise TypeError(\r\n   2236                 \"{!r} must be an instance of {}, not a {}\".format(\r\n\r\nTypeError: 'value' must be an instance of str or bytes, not a float\r\n\r\nThe above exception was the direct cause of the following exception:\r\n\r\nConversionError                           Traceback (most recent call last)\r\n<ipython-input-61-b132ea7dca6c> in <module>\r\n      2 import seaborn as sns\r\n      3 \r\n----> 4 sns.histplot(\r\n      5     ['foo', 'foo', 'bar', np.nan]\r\n      6 )\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/seaborn/distributions.py in histplot(data, x, y, hue, weights, stat, bins, binwidth, binrange, discrete, cumulative, common_bins, common_norm, multiple, element, fill, shrink, kde, kde_kws, line_kws, thresh, pthresh, pmax, cbar, cbar_ax, cbar_kws, palette, hue_order, hue_norm, color, log_scale, legend, ax, **kwargs)\r\n   1420     if p.univariate:\r\n   1421 \r\n-> 1422         p.plot_univariate_histogram(\r\n   1423             multiple=multiple,\r\n   1424             element=element,\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/seaborn/distributions.py in plot_univariate_histogram(self, multiple, element, fill, common_norm, common_bins, shrink, kde, kde_kws, color, legend, line_kws, estimate_kws, **plot_kws)\r\n    421 \r\n    422         # First pass through the data to compute the histograms\r\n--> 423         for sub_vars, sub_data in self.iter_data(\"hue\", from_comp_data=True):\r\n    424 \r\n    425             # Prepare the relevant data\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/seaborn/_core.py in iter_data(self, grouping_vars, reverse, from_comp_data)\r\n    965 \r\n    966         if from_comp_data:\r\n--> 967             data = self.comp_data\r\n    968         else:\r\n    969             data = self.plot_data\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/seaborn/_core.py in comp_data(self)\r\n   1034                 axis = getattr(ax, f\"{var}axis\")\r\n   1035 \r\n-> 1036                 comp_var = axis.convert_units(self.plot_data[var])\r\n   1037                 if axis.get_scale() == \"log\":\r\n   1038                     comp_var = np.log10(comp_var)\r\n\r\n~/.virtualenvs/drawingfromdata/lib/python3.8/site-packages/matplotlib/axis.py in convert_units(self, x)\r\n   1520             ret = self.converter.convert(x, self.units, self)\r\n   1521         except Exception as e:\r\n-> 1522             raise munits.ConversionError('Failed to convert value(s) to axis '\r\n   1523                                          f'units: {x!r}') from e\r\n   1524         return ret\r\n\r\nConversionError: Failed to convert value(s) to axis units: 0    foo\r\n1    foo\r\n2    bar\r\n3    NaN\r\nName: x, dtype: object\r\n```\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:\nseaborn/_core.py\n  function: VectorPlotter.comp_data\n"
    },
    {
      "similar_issue": {
        "issue_title": "unable to plot with custom color ramp seaborn 0.12.0",
        "issue_body": "I was trying to use seaborn kdeplot with custom colour ramp, it is working with seaboarn version 0.11.00, but not with seaboarn 0.12.0\r\n\r\n**color ramp as below** \r\n```\r\ndef make_Ramp( ramp_colors ): \r\n    from colour import Color\r\n    from matplotlib.colors import LinearSegmentedColormap\r\n\r\n    color_ramp = LinearSegmentedColormap.from_list( 'my_list', [ Color( c1 ).rgb for c1 in ramp_colors ] )\r\n    plt.figure( figsize = (15,3))\r\n    plt.imshow( [list(np.arange(0, len( ramp_colors ) , 0.1)) ] , interpolation='nearest', origin='lower', cmap= color_ramp )\r\n    plt.xticks([])\r\n    plt.yticks([])\r\n    return color_ramp\r\n\r\ncustom_ramp = make_Ramp( ['#0000ff','#00ffff','#ffff00','#ff0000' ] ) \r\n```\r\n\r\nmy data look like this\r\n```\r\n\r\n            0        1         2\r\n0    142.5705  38.5744  hairpins\r\n1    281.0795  55.1900  hairpins\r\n2    101.7282  49.5604  hairpins\r\n3     59.8472  63.0699  hairpins\r\n4    296.4381  44.8293  hairpins\r\n..        ...      ...       ...\r\n347  284.6841  51.7468     stems\r\n348  288.7241  49.9322     stems\r\n349  320.2972  41.5520     stems\r\n350  302.6805  67.2658     stems\r\n351  293.6837  52.0663     stems\r\n\r\n[352 rows x 3 columns]\r\n<class 'numpy.float64'>\r\n```\r\n\r\n**this is my code**\r\n\r\n`ax = sns.kdeplot(data=df, x=df.loc[df[2] == \"hairpins\", 0], y=df.loc[df[2] == \"hairpins\", 1], fill=False, thresh=0, levels=20, cmap=custom_ramp, common_norm=True, cbar=True, )`\r\n\r\n**with version 0.12.0 get this error**\r\n\r\n```\r\n\r\n---------------------------------------------------------------------------\r\nAttributeError                            Traceback (most recent call last)\r\n[<ipython-input-6-88652c0ba7ce>](https://localhost:8080/#) in <module>\r\n     21   #/\r\n     22     plt.subplot(2,3,i+1)\r\n---> 23     ax = sns.kdeplot(data=df, x=df.loc[df[2] == dimtypes[i], 0], y=df.loc[df[2] == dimtypes[i], 1], fill=False, thresh=0, levels=20, cmap=custom_ramp, common_norm=True, cbar=True, cbar_kws={'format': '%2.1e', 'label': 'kernel density'} )\r\n     24     plt.title(\"Chart {}: {}\".format(i+1, dimtypes[i]), size=20)\r\n     25     plt.xlabel(str(xname), fontsize=12)\r\n\r\n9 frames\r\n[/usr/local/lib/python3.7/dist-packages/matplotlib/artist.py](https://localhost:8080/#) in update(self, props)\r\n   1065                     func = getattr(self, f\"set_{k}\", None)\r\n   1066                     if not callable(func):\r\n-> 1067                         raise AttributeError(f\"{type(self).__name__!r} object \"\r\n   1068                                              f\"has no property {k!r}\")\r\n   1069                     ret.append(func(v))\r\n\r\nAttributeError: 'Line2D' object has no property 'cmap'\r\n```\r\n\r\n**with version 0.11.0 get this plot**\r\n\r\n![image](https://user-images.githubusercontent.com/67545640/194606070-fc6a1d26-0d2d-48e9-b371-eff69c69b4b6.png)\r\n\r\nbasically, custom ramp is not woking with seaborn 0.12.0 , please update thanks\r\n",
        "issue_id": 3058,
        "pr_number": 3065,
        "pr_title": "Fix unfilled kdeplot cmap regression",
        "pr_body": "Fixes #3058\r\n\r\n```python\r\ngeyser = sns.load_dataset(\"geyser\")\r\nsns.kdeplot(geyser, x=\"waiting\", y=\"duration\", cmap=\"viridis\")\r\n```\r\n\r\n![image](https://user-images.githubusercontent.com/315810/194729481-110b8da9-7a97-4109-9063-a9d47c74dd5d.png)\r\n",
        "issue_closed_at": "2022-10-08T23:02:17Z",
        "base_commit": "c412ddf1fede5d8882a6c230826c1d8fbbf61911"
      },
      "summary": "### Summary:\nThis issue pertains to a regression observed in the Seaborn library, specifically affecting the functionality of custom color ramps when generating kernel density estimate (KDE) plots. The problem emerged with the upgrade from Seaborn version 0.11.0 to 0.12.0, where users encounter an AttributeError when attempting to apply a custom color map to a KDE plot. \n\n1. **Problem description in general terms**: Users are unable to utilize custom color gradients in KDE plots due to an error introduced in the latest version of the Seaborn library.\n\n2. **Key symptoms and behaviors observed**: The primary symptom is an AttributeError indicating that the `Line2D` object does not have a 'cmap' property. This error prevents the successful rendering of KDE plots with custom color ramps.\n\n3. **Affected components or systems**: The issue affects the KDE plotting functionality within the Seaborn library, particularly when using custom color maps with the `kdeplot` function. The error arises from the `plot_bivariate_density` function in `seaborn/distributions.py` and potentially the `_default_color` utility function in `seaborn/utils.py`.\n\n4. **Potential impact or severity**: The severity of the issue is moderate, as it disrupts the ability to customize plot aesthetics, which is a significant aspect of data visualization tasks. Users relying on Seaborn for visual representations with specific color schemes are directly impacted.\n\n5. **Relevant technical details abstracted for broader understanding**: The issue seems to be associated with changes in how Seaborn handles color maps in its plot functions. The error message suggests that a property expected by the plotting function is missing or has been altered, which could indicate a change in the API or an oversight in accommodating custom color maps in the new version. The resolution would involve updating the relevant plot functions to properly support custom color maps, thereby restoring the desired functionality.",
      "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: unable to plot with custom color ramp seaborn 0.12.0\n\nBody:\nI was trying to use seaborn kdeplot with custom colour ramp, it is working with seaboarn version 0.11.00, but not with seaboarn 0.12.0\r\n\r\n**color ramp as below** \r\n```\r\ndef make_Ramp( ramp_colors ): \r\n    from colour import Color\r\n    from matplotlib.colors import LinearSegmentedColormap\r\n\r\n    color_ramp = LinearSegmentedColormap.from_list( 'my_list', [ Color( c1 ).rgb for c1 in ramp_colors ] )\r\n    plt.figure( figsize = (15,3))\r\n    plt.imshow( [list(np.arange(0, len( ramp_colors ) , 0.1)) ] , interpolation='nearest', origin='lower', cmap= color_ramp )\r\n    plt.xticks([])\r\n    plt.yticks([])\r\n    return color_ramp\r\n\r\ncustom_ramp = make_Ramp( ['#0000ff','#00ffff','#ffff00','#ff0000' ] ) \r\n```\r\n\r\nmy data look like this\r\n```\r\n\r\n            0        1         2\r\n0    142.5705  38.5744  hairpins\r\n1    281.0795  55.1900  hairpins\r\n2    101.7282  49.5604  hairpins\r\n3     59.8472  63.0699  hairpins\r\n4    296.4381  44.8293  hairpins\r\n..        ...      ...       ...\r\n347  284.6841  51.7468     stems\r\n348  288.7241  49.9322     stems\r\n349  320.2972  41.5520     stems\r\n350  302.6805  67.2658     stems\r\n351  293.6837  52.0663     stems\r\n\r\n[352 rows x 3 columns]\r\n<class 'numpy.float64'>\r\n```\r\n\r\n**this is my code**\r\n\r\n`ax = sns.kdeplot(data=df, x=df.loc[df[2] == \"hairpins\", 0], y=df.loc[df[2] == \"hairpins\", 1], fill=False, thresh=0, levels=20, cmap=custom_ramp, common_norm=True, cbar=True, )`\r\n\r\n**with version 0.12.0 get this error**\r\n\r\n```\r\n\r\n---------------------------------------------------------------------------\r\nAttributeError                            Traceback (most recent call last)\r\n[<ipython-input-6-88652c0ba7ce>](https://localhost:8080/#) in <module>\r\n     21   #/\r\n     22     plt.subplot(2,3,i+1)\r\n---> 23     ax = sns.kdeplot(data=df, x=df.loc[df[2] == dimtypes[i], 0], y=df.loc[df[2] == dimtypes[i], 1], fill=False, thresh=0, levels=20, cmap=custom_ramp, common_norm=True, cbar=True, cbar_kws={'format': '%2.1e', 'label': 'kernel density'} )\r\n     24     plt.title(\"Chart {}: {}\".format(i+1, dimtypes[i]), size=20)\r\n     25     plt.xlabel(str(xname), fontsize=12)\r\n\r\n9 frames\r\n[/usr/local/lib/python3.7/dist-packages/matplotlib/artist.py](https://localhost:8080/#) in update(self, props)\r\n   1065                     func = getattr(self, f\"set_{k}\", None)\r\n   1066                     if not callable(func):\r\n-> 1067                         raise AttributeError(f\"{type(self).__name__!r} object \"\r\n   1068                                              f\"has no property {k!r}\")\r\n   1069                     ret.append(func(v))\r\n\r\nAttributeError: 'Line2D' object has no property 'cmap'\r\n```\r\n\r\n**with version 0.11.0 get this plot**\r\n\r\n![image](https://user-images.githubusercontent.com/67545640/194606070-fc6a1d26-0d2d-48e9-b371-eff69c69b4b6.png)\r\n\r\nbasically, custom ramp is not woking with seaborn 0.12.0 , please update thanks\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:\nseaborn/distributions.py\n  function: _DistributionPlotter.plot_bivariate_density\n  function: _DistributionPlotter.plot_bivariate_density\n\nseaborn/utils.py\n  function: _default_color\n"
    },
    {
      "similar_issue": {
        "issue_title": "Visibility of internal axis labels is wrong with wrapped pair plot",
        "issue_body": "```python\r\n(\r\n    so.Plot(mpg, y=\"mpg\")\r\n    .pair([\"displacement\", \"weight\", \"horsepower\", \"cylinders\"], wrap=2)\r\n)\r\n```\r\n![image](https://user-images.githubusercontent.com/315810/186793170-dedae71a-2cb9-4f0e-9339-07fc1d13ac59.png)\r\n\r\nThe top two subplots should have distinct x labels.",
        "issue_id": 2976,
        "pr_number": 2979,
        "pr_title": "Fix visibility of internal axis labels with Plot.pair(wrap=...)",
        "pr_body": "\r\n1. Fix visibility of internal axis labels with `Plot.pair(wrap=...)`  (Closes #2976)\r\n\r\n```python\r\n(\r\n    so.Plot(mpg, y=\"mpg\")\r\n    .pair([\"displacement\", \"weight\", \"horsepower\", \"acceleration\"], wrap=2)\r\n    .add(so.Dots())\r\n)\r\n```\r\n![image](https://user-images.githubusercontent.com/315810/186991689-69c61e56-3054-49b3-ad87-7797198b1cd1.png)\r\n\r\n2. Fix (non-)sharing of axes for distinct variables with `Plot.pair(wrap=1)`\r\n\r\n```python\r\n(\r\n    so.Plot(mpg, x=\"mpg\")\r\n    .pair(y=[\"displacement\", \"weight\"], wrap=1)\r\n    .add(so.Dots())\r\n)\r\n```\r\n![image](https://user-images.githubusercontent.com/315810/186991550-5be28208-c5aa-4d47-b2c6-a36e0f1fe59b.png)\r\n",
        "issue_closed_at": "2022-08-27T00:31:23Z",
        "base_commit": "ebc4bfe9f8bf5c4ff10b14da8a49c8baa1ba76d0"
      },
      "summary": "### Summary:\nThis issue pertains to the incorrect visibility of axis labels in a data visualization context when using a specific plotting function. The problem arises within a wrapped pair plot, a type of multi-panel plot, where the x-axis labels in the top two subplots are not distinct, leading to potential misinterpretation of the visualized data. Key symptoms include the incorrect and potentially misleading display of internal axis labels, specifically affecting the clarity and accuracy of data representation in the subplots located at the top.\n\nThe affected components are part of a data visualization library, specifically within the plot setup and axis sharing functionalities. The functions involved in the issue are related to figure and scale setup, as well as the determination of axis sharing across subplots. The severity of this issue can be considered moderate, as it directly impacts the readability and interpretability of visualizations, which are crucial for data analysis and decision-making based on the plots.\n\nTechnical details abstracted for broader understanding involve the improper configuration of axis labels in complex plot arrangements, which can occur when plots are arranged in a grid with wrapping. The resolution required adjustments to the internal logic for setting up plot figures and scales, as well as ensuring appropriate axis sharing across subplots to maintain distinct and clear labeling.",
      "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: Visibility of internal axis labels is wrong with wrapped pair plot\n\nBody:\n```python\r\n(\r\n    so.Plot(mpg, y=\"mpg\")\r\n    .pair([\"displacement\", \"weight\", \"horsepower\", \"cylinders\"], wrap=2)\r\n)\r\n```\r\n![image](https://user-images.githubusercontent.com/315810/186793170-dedae71a-2cb9-4f0e-9339-07fc1d13ac59.png)\r\n\r\nThe top two subplots should have distinct x labels.\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:\nseaborn/_core/plot.py\n  function: Plotter._setup_figure\n  function: Plotter._setup_scales\n\nseaborn/_core/subplots.py\n  function: Subplots._determine_axis_sharing\n"
    },
    {
      "similar_issue": {
        "issue_title": "Categorical variable with numerical classes incorrectly plotted only on y axis",
        "issue_body": "Dear All,\r\n\r\n\r\nI think I may have found a bug in Seaborn categorical plotting functions.\r\nIf a DataFrame column contains numbers, and it is explicitely converted to CategoricalDType, it will be correctly treated as categorical by functions such as boxplot only if it is passed to `x` argument.\r\nIf it is instead passed to `y` argument of the plotting function, it will be treated as numerical, and the other variable will be treated as categorical (even though the other variable is obviously numerical).\r\n\r\nI am using Python 3.7, Matplotlib 3.3.1, Seaborn 0.11, Numpy 1.19.1, and Pandas 1.1.1 .\r\nI am using Matplotlib backend: 'module://ipykernel.pylab.backend_inline'\r\n\r\n\r\nReproducible code:\r\n```python\r\n\r\n#Create DataFrame with a numerical column, and a categorical column with number as classes.\r\nn_points = 50\r\n\r\ndf = pd.DataFrame({\"value\": np.random.rand(n_points),\r\n                   \"class\": np.random.randint(0, 2, n_points),\r\n                   })\r\n\r\n#Explicitely set `class` column to categorical data type.\r\ndf[\"class\"] = df[\"class\"].astype(\"category\")\r\n\r\n#If `class` column is passed to `x` argument, the plot is correct: column is treated as categorical.\r\nsns.boxplot(data=df,\r\n            x=\"class\",\r\n            y=\"value\",\r\n            );\r\n\r\n#BUG: If `class` column is passed to `y` argument, the plot is incorrect: `class` is treated as numerical!\r\nsns.boxplot(data=df,\r\n            x=\"value\",\r\n            y=\"class\",\r\n            );\r\n\r\n```\r\n\r\nPlease take a look at\r\n[bug_categorical_numbers.pdf](https://github.com/mwaskom/seaborn/files/5371402/bug_categorical_numbers.pdf)\r\n the attached PDF file with the correct and wrong plots.",
        "issue_id": 2317,
        "pr_number": 2379,
        "pr_title": "FIX: Infer categorical dtypes before boolean resolution",
        "pr_body": "Fixes #2317, with small changes to the docstring of `variable_type`.",
        "issue_closed_at": "2020-12-12T14:22:35Z",
        "base_commit": "ae123d79ed341d352d3f29b6936c044350b75e86"
      },
      "summary": "### Summary:\n\nThis issue is related to the Seaborn data visualization library, specifically concerning the categorical plotting functions. The problem arises when a DataFrame column, which contains numerical values, is explicitly converted to a categorical data type using Pandas' `CategoricalDType`. The issue manifests when this categorically-typed column is plotted on the y-axis using Seaborn's plotting functions such as `boxplot`. Despite being cast to a categorical type, the column is incorrectly interpreted as numerical when placed on the y-axis, leading to an incorrect plot where the roles of the categorical and numerical variables are swapped. This behavior is inconsistent as the same column is correctly treated as categorical when placed on the x-axis.\n\nKey symptoms and behaviors observed include the incorrect plotting of categorical data as numerical when used on the y-axis, despite explicit type conversion. This issue affects Seaborn functions that rely on the correct interpretation of data types for plotting, particularly `boxplot` in this context.\n\nThe affected components are primarily within the Seaborn library, specifically related to the handling of data types in plotting functions. The issue is traced to functions in the `seaborn/_core.py` file, notably `VectorPlotter._add_axis_labels` and `variable_type`, which are responsible for determining how data types are processed and plotted.\n\nThe potential impact of this issue is significant for users relying on accurate visual representations of categorical data. Misinterpretation of data types can lead to misleading plots, affecting data analysis and decision-making processes based on visual data insights.\n\nRelevant technical details include the use of Python 3.7, Matplotlib 3.3.1, Seaborn 0.11, Numpy 1.19.1, and Pandas 1.1.1, with the Matplotlib backend 'module://ipykernel.pylab.backend_inline'. The issue highlights the importance of ensuring consistency in how categorical data types are handled across different axes in plotting 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: Categorical variable with numerical classes incorrectly plotted only on y axis\n\nBody:\nDear All,\r\n\r\n\r\nI think I may have found a bug in Seaborn categorical plotting functions.\r\nIf a DataFrame column contains numbers, and it is explicitely converted to CategoricalDType, it will be correctly treated as categorical by functions such as boxplot only if it is passed to `x` argument.\r\nIf it is instead passed to `y` argument of the plotting function, it will be treated as numerical, and the other variable will be treated as categorical (even though the other variable is obviously numerical).\r\n\r\nI am using Python 3.7, Matplotlib 3.3.1, Seaborn 0.11, Numpy 1.19.1, and Pandas 1.1.1 .\r\nI am using Matplotlib backend: 'module://ipykernel.pylab.backend_inline'\r\n\r\n\r\nReproducible code:\r\n```python\r\n\r\n#Create DataFrame with a numerical column, and a categorical column with number as classes.\r\nn_points = 50\r\n\r\ndf = pd.DataFrame({\"value\": np.random.rand(n_points),\r\n                   \"class\": np.random.randint(0, 2, n_points),\r\n                   })\r\n\r\n#Explicitely set `class` column to categorical data type.\r\ndf[\"class\"] = df[\"class\"].astype(\"category\")\r\n\r\n#If `class` column is passed to `x` argument, the plot is correct: column is treated as categorical.\r\nsns.boxplot(data=df,\r\n            x=\"class\",\r\n            y=\"value\",\r\n            );\r\n\r\n#BUG: If `class` column is passed to `y` argument, the plot is incorrect: `class` is treated as numerical!\r\nsns.boxplot(data=df,\r\n            x=\"value\",\r\n            y=\"class\",\r\n            );\r\n\r\n```\r\n\r\nPlease take a look at\r\n[bug_categorical_numbers.pdf](https://github.com/mwaskom/seaborn/files/5371402/bug_categorical_numbers.pdf)\r\n the attached PDF file with the correct and wrong plots.\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:\nseaborn/_core.py\n  function: VectorPlotter._add_axis_labels\n  function: variable_type\n"
    }
  ]
}