{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-24334",
    "repo": "matplotlib/matplotlib",
    "created_at": "2022-11-01T18:11:43Z",
    "problem_statement": "[ENH]: Axes.set_xticks/Axis.set_ticks only validates kwargs if ticklabels are set, but they should\n### Problem\n\nPer the doc of `Axis.set_ticks`:\r\n```\r\n        **kwargs\r\n            `.Text` properties for the labels. These take effect only if you\r\n            pass *labels*. In other cases, please use `~.Axes.tick_params`.\r\n```\r\nThis means that in e.g. `ax.set_xticks([0, 1], xticklabels=[\"a\", \"b\"])`, the incorrect `xticklabels` silently do nothing; they are not even validated (because `labels` has not been passed).\n\n### Proposed solution\n\nWe should at least check that `kwargs` are valid Text properties in all cases; we could even consider making any kwargs an error if `labels` is not set.\n",
    "patch": "diff --git a/lib/matplotlib/axis.py b/lib/matplotlib/axis.py\n--- a/lib/matplotlib/axis.py\n+++ b/lib/matplotlib/axis.py\n@@ -2029,6 +2029,9 @@ def set_ticks(self, ticks, labels=None, *, minor=False, **kwargs):\n         other limits, you should set the limits explicitly after setting the\n         ticks.\n         \"\"\"\n+        if labels is None and kwargs:\n+            raise ValueError('labels argument cannot be None when '\n+                             'kwargs are passed')\n         result = self._set_tick_locations(ticks, minor=minor)\n         if labels is not None:\n             self.set_ticklabels(labels, minor=minor, **kwargs)\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_17736",
        "decision": "Useful",
        "confidence": "Medium",
        "reason": "Both issues involve handling tick labels and ensuring compatibility with previous behavior, focusing on error prevention and user expectations."
      },
      {
        "idx": 2,
        "id": "similar_18848",
        "decision": "Useful",
        "confidence": "Medium",
        "reason": "The issue involves validating the correct use of tick-related parameters, similar to ensuring kwargs are used correctly in the current issue."
      },
      {
        "idx": 3,
        "id": "similar_6142",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue focuses on algorithm flexibility for tick counts, which is unrelated to the validation of kwargs or tick labels."
      },
      {
        "idx": 4,
        "id": "similar_17331",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "This issue deals with axis limits and autoscaling, which does not relate to the validation of kwargs or tick labels."
      },
      {
        "idx": 5,
        "id": "similar_17974",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about performance regression in polygon clipping, unrelated to tick label validation or kwargs handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "ax.set_xticklabels([]) for categorical plots is broken in 3.3.0rc1",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\n\r\n#17266 requires tick labels set by `FixedFormatter` to be equal to the ticks set by `FixedLocator`. `FixedLocator` is used in many cases where categorical data is plotted, e.g. `bar` and `box plot`. A way of removing all tick labels (while maintaining ticks and gridlines) is to do `ax.set_xticklabels([])` or `ax.set_yticklabels([])`, by passing just an empty list. This works on 3.2.2, but raises a `ValueError` with 3.3.0rc1. \r\n\r\nThe new behavior is not mentioned in the \"What's new?\" section of 3.3.0rc1. I suspect this may break existing code, as it broke seaborn and [this stackoverflow thread](https://stackoverflow.com/questions/2176424/hiding-axis-text-in-matplotlib-plots) seems very popular.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\n# Example modified from bar example page\r\n\r\nimport matplotlib.pyplot as plt\r\nimport numpy as np\r\n\r\nlabels = ['G1', 'G2', 'G3', 'G4', 'G5']\r\nmen_means = [20, 34, 30, 35, 27]\r\nwomen_means = [25, 32, 34, 20, 25]\r\n\r\nx = np.arange(len(labels))  # the label locations\r\nwidth = 0.35  # the width of the bars\r\n\r\nfig, ax = plt.subplots()\r\nrects1 = ax.bar(x - width/2, men_means, width, label='Men')\r\nrects2 = ax.bar(x + width/2, women_means, width, label='Women')\r\n\r\nax.set_xticks(x)\r\nax.set_xticklabels([])\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n# 3.3.0rc1\r\nValueError: The number of FixedLocator locations (5), usually from a call to set_ticks, does not match the number of ticklabels (0).\r\n```\r\n\r\n**Expected outcome**\r\n\r\nUnset tick labels but not error out, or raise a deprecation warning that this won't be possible in a future release.\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: macOS\r\n  * Matplotlib version: 3.3.0rc1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): MacOSX\r\n  * Python version: 3.8.3\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\nInstalled using pip",
        "issue_id": 17736,
        "pr_number": 17784,
        "pr_title": "Allow passing empty list of ticks to FixedLocator",
        "pr_body": "## PR Summary\r\nFixes #17736. See https://github.com/matplotlib/matplotlib/issues/17736#issuecomment-648496870 for reasons why I haven't added a deprecation; we can always add that later anyway if desired. The test errors without the fix, but maybe I should make it a figure comparison to make sure the ticks are being removed?\r\n\r\n## PR Checklist\r\n\r\n- [x] Has Pytest style unit tests\r\n- [x] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/api_changes.rst if API changed in a backward-incompatible way\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_closed_at": "2020-06-28T17:52:18Z",
        "base_commit": "56d4f69923d5a4bb1158c7d61fbc7e24bd10d9b9"
      },
      "summary": "### Summary:\nThis issue is related to a change in behavior in the Matplotlib library, specifically in its handling of tick labels for categorical plots starting from version 3.3.0rc1. The problem arises when users attempt to remove tick labels while maintaining the ticks and gridlines by passing an empty list to `ax.set_xticklabels([])` or `ax.set_yticklabels([])`. This results in a `ValueError` due to a mismatch between the number of tick locations set by `FixedLocator` and the number of tick labels provided by `FixedFormatter`. The previous version, 3.2.2, allowed this operation without error, indicating a regression in functionality.\n\nKey symptoms and behaviors include the raising of a `ValueError` when executing the code that was previously valid, thus potentially breaking existing codebases that rely on this behavior. This issue affects components that handle tick labeling for plots, notably in bar and box plots with categorical data.\n\nThe impact of this issue is significant as it can disrupt the functionality of plotting libraries like Seaborn and potentially affect many users, as evidenced by the popularity of related queries on platforms like StackOverflow. Additionally, the change was not documented in the release notes, increasing the likelihood of unexpected errors for developers upgrading to version 3.3.0rc1.\n\nThe technical details involve the interaction between `FixedLocator` and `FixedFormatter` in setting tick labels, where previously, a lack of tick labels did not result in an error. The fix involves modifications to the `Axis.set_ticklabels` function in the `lib/matplotlib/axis.py` file, ensuring compatibility and preventing errors when an empty list of labels is provided.",
      "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: ax.set_xticklabels([]) for categorical plots is broken in 3.3.0rc1\n\nBody:\n### Bug report\r\n\r\n**Bug summary**\r\n\r\n#17266 requires tick labels set by `FixedFormatter` to be equal to the ticks set by `FixedLocator`. `FixedLocator` is used in many cases where categorical data is plotted, e.g. `bar` and `box plot`. A way of removing all tick labels (while maintaining ticks and gridlines) is to do `ax.set_xticklabels([])` or `ax.set_yticklabels([])`, by passing just an empty list. This works on 3.2.2, but raises a `ValueError` with 3.3.0rc1. \r\n\r\nThe new behavior is not mentioned in the \"What's new?\" section of 3.3.0rc1. I suspect this may break existing code, as it broke seaborn and [this stackoverflow thread](https://stackoverflow.com/questions/2176424/hiding-axis-text-in-matplotlib-plots) seems very popular.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\n# Example modified from bar example page\r\n\r\nimport matplotlib.pyplot as plt\r\nimport numpy as np\r\n\r\nlabels = ['G1', 'G2', 'G3', 'G4', 'G5']\r\nmen_means = [20, 34, 30, 35, 27]\r\nwomen_means = [25, 32, 34, 20, 25]\r\n\r\nx = np.arange(len(labels))  # the label locations\r\nwidth = 0.35  # the width of the bars\r\n\r\nfig, ax = plt.subplots()\r\nrects1 = ax.bar(x - width/2, men_means, width, label='Men')\r\nrects2 = ax.bar(x + width/2, women_means, width, label='Women')\r\n\r\nax.set_xticks(x)\r\nax.set_xticklabels([])\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n# 3.3.0rc1\r\nValueError: The number of FixedLocator locations (5), usually from a call to set_ticks, does not match the number of ticklabels (0).\r\n```\r\n\r\n**Expected outcome**\r\n\r\nUnset tick labels but not error out, or raise a deprecation warning that this won't be possible in a future release.\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: macOS\r\n  * Matplotlib version: 3.3.0rc1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): MacOSX\r\n  * Python version: 3.8.3\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\nInstalled using pip\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/axis.py\n  function: Axis.set_ticklabels\n"
    },
    {
      "similar_issue": {
        "issue_title": "Setting xticklabels causes warning related to FixedFormatter",
        "issue_body": "<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nI get a warning related to `FixedFormatter` even though I am not setting a formatter.\r\n\r\nThanks to user Rational-IM [on StackOverflow](https://stackoverflow.com/questions/63723514/userwarning-fixedformatter-should-only-be-used-together-with-fixedlocator) and the good folks at [pandas ](https://github.com/pandas-dev/pandas/issues/35684) for isolating and reproducing the bug.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\n\r\nfig, ax = plt.subplots()\r\nax.scatter(0.5, 0.5)\r\nax.set_xticklabels(['0', r'$T/2$', r'$T$'])\r\n\r\n# Optional line\r\nax.xaxis.set_major_locator(FixedLocator([0, 0.5, 1]))\r\n\r\nNone\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n<ipython-input-3-52a3699e4278>:5: UserWarning: FixedFormatter should only be used together with FixedLocator\r\n  ax.set_xticklabels(['0', r'$T/2$', r'$T$'])\r\n```\r\n\r\n**Expected outcome**\r\n\r\nWorks on 3.2.2 with no warning.\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: Win 10\r\n  * Matplotlib version: 3.3.2\r\n  * Matplotlib backend: module://ipykernel.pylab.backend_inline\r\n  * Python version: 3.8.5\r\n  * Jupyter version (if applicable): 6.1.4\r\n  * Other libraries: none\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\nInstalled from conda\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\n",
        "issue_id": 18848,
        "pr_number": 20047,
        "pr_title": "Add labels parameter to set_ticks()",
        "pr_body": "## PR Summary\r\n\r\nAs proposed in https://github.com/matplotlib/matplotlib/issues/18848#issuecomment-720154479 and discussed on today's dev call.\r\n\r\nCloses #18848, #19016.\r\n\r\n**kwargs:** I've added kwargs for text properties. While this makes the function do a lot (borderline of too much), it is necessary if we want a full replacement of `set_ticklabels(labels, **text_properties)`.\r\nOne can argue that this is actually too much, in which case we'd have to advertise\r\n~~~\r\n# Replace\r\nset_ticks(locs)\r\nset_ticklabels(labels, **text_properties)\r\n# by\r\nset_ticks(locs, labels)\r\ntick_params(**text_properties)\r\n~~~\r\n\r\n\r\n\r\n**Return value:** `set_ticks()` has an undocumented return value (list of the Tick instances). While `plt.xticks()` returns a tuple `(locs, labels)` (list of Ticks and list of Texts), I don't want to do this here. First, I don't think the setter should return anything at all (but that's how it is for now and deprecating that is probably not worth it). Second, since labels are optional, I'm not even sure if we would want to give the texts only if `labels` is not None.\r\n\r\n\r\n\r\n",
        "issue_closed_at": "2021-05-14T03:50:35Z",
        "base_commit": "19aac39fe9e70decc72ce5b3e2261b5c602a8c78"
      },
      "summary": "### Summary:\nThis issue is related to the use of `FixedFormatter` in the Matplotlib library, which triggers a warning when setting x-tick labels without specifying a corresponding `FixedLocator`. The warning message indicates that `FixedFormatter` should only be used in conjunction with `FixedLocator`, highlighting a potential misuse or oversight in the code.\n\n1. **Problem description in general terms**: The problem involves a warning generated by Matplotlib when setting tick labels on a plot. The warning is caused by an incorrect combination of tick label formatting and locator usage.\n\n2. **Key symptoms and behaviors observed**: The primary symptom is a `UserWarning` that appears when executing the plotting code. This warning indicates that `FixedFormatter` should not be used without `FixedLocator`.\n\n3. **Affected components or systems**: The issue specifically affects the Matplotlib library, a widely used plotting library in Python, particularly its functionality for setting axis tick labels and locators.\n\n4. **Potential impact or severity**: The severity is relatively low as the issue is a warning rather than an error, meaning it does not prevent the code from running. However, it may lead to confusion or incorrect plot labeling if not addressed, especially for users who are unaware of the necessary relationship between formatters and locators.\n\n5. **Relevant technical details abstracted for broader understanding**: The crux of the issue lies in the interaction between `FixedFormatter` and `FixedLocator`. `FixedFormatter` is intended to be used with `FixedLocator` to ensure that tick labels are applied at specific, predetermined locations on the axis. The absence of `FixedLocator` leads to the warning. The code changes suggest updates in the functions responsible for setting tick labels and handling secondary axes to resolve this mismatch.\n\nThe changes made in the codebase likely involve modifications in the functions `SecondaryAxis.apply_aspect`, `Axis.set_ticklabels`, `Axis._set_ticklabels`, and `Axis.set_ticks` to ensure proper usage and handling of formatters and locators, thereby eliminating the warning.",
      "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: Setting xticklabels causes warning related to FixedFormatter\n\nBody:\n<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nI get a warning related to `FixedFormatter` even though I am not setting a formatter.\r\n\r\nThanks to user Rational-IM [on StackOverflow](https://stackoverflow.com/questions/63723514/userwarning-fixedformatter-should-only-be-used-together-with-fixedlocator) and the good folks at [pandas ](https://github.com/pandas-dev/pandas/issues/35684) for isolating and reproducing the bug.\r\n\r\n**Code for reproduction**\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\n\r\nfig, ax = plt.subplots()\r\nax.scatter(0.5, 0.5)\r\nax.set_xticklabels(['0', r'$T/2$', r'$T$'])\r\n\r\n# Optional line\r\nax.xaxis.set_major_locator(FixedLocator([0, 0.5, 1]))\r\n\r\nNone\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n```\r\n<ipython-input-3-52a3699e4278>:5: UserWarning: FixedFormatter should only be used together with FixedLocator\r\n  ax.set_xticklabels(['0', r'$T/2$', r'$T$'])\r\n```\r\n\r\n**Expected outcome**\r\n\r\nWorks on 3.2.2 with no warning.\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: Win 10\r\n  * Matplotlib version: 3.3.2\r\n  * Matplotlib backend: module://ipykernel.pylab.backend_inline\r\n  * Python version: 3.8.5\r\n  * Jupyter version (if applicable): 6.1.4\r\n  * Other libraries: none\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\nInstalled from conda\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\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/axes/_secondary_axes.py\n  line: line 4\n  function: SecondaryAxis.apply_aspect\n\nlib/matplotlib/axis.py\n  function: Axis.set_ticklabels\n  function: Axis._set_ticklabels\n  function: Axis.set_ticks\n"
    },
    {
      "similar_issue": {
        "issue_title": "matplotlib.ticker.LinearLocator view_limits algorithm improvement?",
        "issue_body": "Inspecting the code of matplotlib.ticker.LinearLocator\nhttps://github.com/matplotlib/matplotlib/blob/7d1a7c2e4637efba239ad3b984928c0175d45f98/lib/matplotlib/ticker.py#L1161\n\nyou can see that the view limits are chosen such that the difference between vmin and vmax is an interger multiple of scale, which is itself a power of 10. Therefore, the range  will be nicely divisible when divided by 10 (11 tickmarks).\nhttps://github.com/matplotlib/matplotlib/blob/7d1a7c2e4637efba239ad3b984928c0175d45f98/lib/matplotlib/ticker.py#L1213\n\nTherefore, the view_limits function determines the limits assuming there are 11 ticks. This assumption is implicit in two lines:\nhttps://github.com/matplotlib/matplotlib/blob/7d1a7c2e4637efba239ad3b984928c0175d45f98/lib/matplotlib/ticker.py#L1224\nhttps://github.com/matplotlib/matplotlib/blob/7d1a7c2e4637efba239ad3b984928c0175d45f98/lib/matplotlib/ticker.py#L1227\n\nCode is repeated here:\n\n```\nexponent, remainder = divmod(math.log10(vmax - vmin), 1)\nif remainder < 0.5:\n    exponent -= 1\nscale = 10 ** (-exponent)\nvmin = math.floor(scale * vmin) / scale\nvmax = math.ceil(scale * vmax) / scale\n```\n\nSince we know the number of ticks, from `self.num_ticks`, we can generalize the current algorithm to be better suited for any number of ticks. Suggested generalized algorithm:\n\n```\nexponent, remainder = divmod(math.log10(vmax - vmin), math.log10(self.num_ticks-1))\nif remainder < 0.5:\n    exponent -= 1\nscale = (self.num_ticks-1) ** (-exponent)\nvmin = math.floor(scale * vmin) / scale\nvmax = math.ceil(scale * vmax) / scale\n```\n\nThis generalized expression reduces to the current form when `self.num_ticks==11` (which is the current default). For other cases, here is an example:\nwhen num_ticks = 10, vmin = 20, vmax=90\nCurrent algorithm returns vmin = 20, vmax=90, corresponding to ticks spaced by 7.77778.\n\nThe proposed algorithm returns vmin = 18, vmax = 90, corresponding to ticks spaced by 8.\n\nIs this something worth doing? The patch is trivial -- just changing two lines of code. I can turn this in to a pull request to illustrate if it is helpful.\n",
        "issue_id": 6142,
        "pr_number": 6431,
        "pr_title": "Merge from v2.x",
        "pr_body": "This merge from v2.x into master also required a little editing, and it involves many changes, hence this PR.  I resolved conflicts in .travis.yml and lib/matplotlib/tests/test_colors.py.\n",
        "issue_closed_at": "2016-05-04T00:26:00Z",
        "base_commit": "22a7b955a0b9dc4dea8adf155041498dd355e4df"
      },
      "summary": "### Summary: This issue pertains to an enhancement proposal for the `view_limits` algorithm within the `matplotlib.ticker.LinearLocator` component of the Matplotlib library. The current algorithm selects view limits such that the difference between the minimum and maximum values is an integer multiple of a scale, which is a power of ten. This ensures that the range is divisible by 10, creating 11 tick marks. The issue identified is that the algorithm implicitly assumes a fixed number of ticks (11), which limits its flexibility for different use cases requiring a different number of ticks.\n\n1. **Problem Description in General Terms**: The existing algorithm in the Matplotlib library's LinearLocator component is hardcoded to accommodate 11 tick marks, limiting its adaptability to varying numbers of required ticks. This rigid approach may not suit all visualization needs where a different number of ticks is desired.\n\n2. **Key Symptoms and Behaviors Observed**: The current algorithm's inflexibility is highlighted by its inability to adjust to user-specified numbers of ticks. It always calculates view limits based on the assumption of creating 11 tick marks, which can lead to suboptimal spacing when a different number of ticks is required.\n\n3. **Affected Components or Systems**: The primary component affected is the `matplotlib.ticker.LinearLocator` module, specifically the `view_limits` function.\n\n4. **Potential Impact or Severity**: The impact is primarily on the usability and flexibility of the LinearLocator module in Matplotlib. While not resulting in crashes or severe software malfunctions, the limitation can hinder the creation of optimal plots for users who require a different number of ticks, potentially affecting data visualization quality and interpretability.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The proposal suggests modifying the algorithm to dynamically calculate the view limits based on the actual number of ticks specified by `self.num_ticks`. This involves altering the calculation of the scale and exponent to account for different numbers of ticks, thereby generalizing the view limits determination. The proposed algorithm maintains backward compatibility by reducing to the current implementation when `self.num_ticks` equals 11. The change involves a simple adjustment of two lines of code, indicating a low complexity for integration.\n\nThe provided change log suggests that the modification primarily affects the `ticker.py` file within Matplotlib, with no direct alterations to other code elements mentioned in the change summary. The enhancement is suggested to improve the adaptability and utility of the LinearLocator for users with diverse plotting requirements.",
      "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: matplotlib.ticker.LinearLocator view_limits algorithm improvement?\n\nBody:\nInspecting the code of matplotlib.ticker.LinearLocator\nhttps://github.com/matplotlib/matplotlib/blob/7d1a7c2e4637efba239ad3b984928c0175d45f98/lib/matplotlib/ticker.py#L1161\n\nyou can see that the view limits are chosen such that the difference between vmin and vmax is an interger multiple of scale, which is itself a power of 10. Therefore, the range  will be nicely divisible when divided by 10 (11 tickmarks).\nhttps://github.com/matplotlib/matplotlib/blob/7d1a7c2e4637efba239ad3b984928c0175d45f98/lib/matplotlib/ticker.py#L1213\n\nTherefore, the view_limits function determines the limits assuming there are 11 ticks. This assumption is implicit in two lines:\nhttps://github.com/matplotlib/matplotlib/blob/7d1a7c2e4637efba239ad3b984928c0175d45f98/lib/matplotlib/ticker.py#L1224\nhttps://github.com/matplotlib/matplotlib/blob/7d1a7c2e4637efba239ad3b984928c0175d45f98/lib/matplotlib/ticker.py#L1227\n\nCode is repeated here:\n\n```\nexponent, remainder = divmod(math.log10(vmax - vmin), 1)\nif remainder < 0.5:\n    exponent -= 1\nscale = 10 ** (-exponent)\nvmin = math.floor(scale * vmin) / scale\nvmax = math.ceil(scale * vmax) / scale\n```\n\nSince we know the number of ticks, from `self.num_ticks`, we can generalize the current algorithm to be better suited for any number of ticks. Suggested generalized algorithm:\n\n```\nexponent, remainder = divmod(math.log10(vmax - vmin), math.log10(self.num_ticks-1))\nif remainder < 0.5:\n    exponent -= 1\nscale = (self.num_ticks-1) ** (-exponent)\nvmin = math.floor(scale * vmin) / scale\nvmax = math.ceil(scale * vmax) / scale\n```\n\nThis generalized expression reduces to the current form when `self.num_ticks==11` (which is the current default). For other cases, here is an example:\nwhen num_ticks = 10, vmin = 20, vmax=90\nCurrent algorithm returns vmin = 20, vmax=90, corresponding to ticks spaced by 7.77778.\n\nThe proposed algorithm returns vmin = 18, vmax = 90, corresponding to ticks spaced by 8.\n\nIs this something worth doing? The patch is trivial -- just changing two lines of code. I can turn this in to a pull request to illustrate if it is helpful.\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/animation.py\n  line: line 36\n  class: MovieWriter\n  function: FuncAnimation.__init__\n  function: ImageMagickBase.isAvailable\n  class: FFMpegBase\n  function: ImageMagickBase.output_args\n  function: Animation.save\n  function: Animation.save\n  function: Animation.save\n  function: Animation.save\n  function: Animation.to_html5_video\n\nlib/matplotlib/axes/_base.py\n  function: _AxesBase.__init__\n\nlib/matplotlib/backends/backend_qt5.py\n  function: SubplotToolQt.__init__\n  function: SubplotToolQt.funcleft\n  function: SubplotToolQt.funcright\n  function: SubplotToolQt.funcbottom\n  function: SubplotToolQt.functop\n\nlib/matplotlib/cbook.py\n  function: issubclass_safe\n\nlib/matplotlib/contour.py\n  function: ContourSet.changed\n  function: ContourSet._contour_level_args\n  function: QuadContourSet._contour_args\n\nlib/matplotlib/dates.py\n  class: AutoDateFormatter\n  function: MicrosecondLocator.__init__\n\nlib/matplotlib/image.py\n  function: PcolorImage.set_data\n  function: PcolorImage.set_data\n  function: BboxImage.__init__\n  function: PcolorImage._check_unsampled_image\n  function: BboxImage.make_image\n\nlib/matplotlib/rcsetup.py\n  function: validate_animation_writer_path\n\nlib/matplotlib/ticker.py\n  function: OldAutoLocator.__init__\n  function: OldAutoLocator.tick_values\n\nsetupext.py\n  function: PdfToPs.check\n  function: PdfToPs.check\n"
    },
    {
      "similar_issue": {
        "issue_title": "Surprising/changed axis limit (autoscale) behavior",
        "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\n\r\nThe interaction of setting axis limits and autoscaling changed in 3.2 with little guidance, introducing unexpected behavior that doesn't always make sense.\r\n\r\n**Code for reproduction**\r\n\r\nHere is a plot that looks very different on 3.1.2 and 3.2.1\r\n\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\nf, ax = plt.subplots()\r\nx = np.arange(100)\r\ny = np.random.uniform(-.1, .1, 100)\r\nax.scatter(x, y)\r\nassert ax._autoscaleYon\r\nax.set_ylim((-.5, .5), auto=None)\r\n```\r\n\r\n**Actual outcome**\r\n\r\nOn 3.2.1\r\n\r\n![image](https://user-images.githubusercontent.com/315810/81074711-656ca600-8eb7-11ea-9929-cef357be7cf1.png)\r\n\r\n**Expected outcome**\r\n\r\nOn 3.1.2\r\n\r\n![image](https://user-images.githubusercontent.com/315810/81074777-79b0a300-8eb7-11ea-8510-2bddabb72dd1.png)\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: macOS\r\n  * Matplotlib version: 3.2.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): pylab inline\r\n  * Python version: 3.7\r\n\r\n",
        "issue_id": 17331,
        "pr_number": 17408,
        "pr_title": "FIX: cancel pending autoscale on manually setting limits",
        "pr_body": "closes #17331\r\n\r\n## PR Summary\r\nApplies patch suggested by @anntzer  in https://github.com/matplotlib/matplotlib/issues/17331#issuecomment-624109727\r\n\r\n\r\n## PR Checklist\r\n\r\n- [x] Has Pytest style unit tests\r\n- [x] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n\r\n",
        "issue_closed_at": "2020-05-28T18:09:41Z",
        "base_commit": "4a8aa8ce227e4b823305e2adb616facd1435764b"
      },
      "summary": "### Summary:\nThis issue is related to a change in the behavior of axis limit settings and autoscaling in the Matplotlib library, occurring between versions 3.1.2 and 3.2.1. The problem arises from an unexpected alteration in how axis limits interact with the autoscaling feature, leading to discrepancies in the visual output of plots when rendered in different versions of the library. Specifically, setting the y-axis limits with `ax.set_ylim()` without specifying the `auto` parameter results in different scaling behavior, which can surprise users who have upgraded to the newer version. The problem manifests as a visual discrepancy in plots, where data points are displayed differently depending on the version of Matplotlib used.\n\nKey symptoms include:\n- Different plot appearances when using the same code across Matplotlib versions 3.1.2 and 3.2.1.\n- Inconsistent axis scaling behavior when setting axis limits explicitly.\n\nAffected components include:\n- The autoscaling mechanism within the Matplotlib library, specifically in the `_AxesBase.set_xlim` and `_AxesBase.set_ylim` functions, which govern axis limit settings.\n\nPotential impact or severity:\n- The impact is primarily on users upgrading from an older version to 3.2.1, who may find their plots unexpectedly altered. This could affect the visual integrity of data presentations and analysis, leading to potential misinterpretations if not adjusted for the new behavior.\n\nRelevant technical details for broader understanding:\n- The issue highlights the importance of understanding how internal changes in plotting libraries can affect the output. Users need to be aware of version-specific alterations in library behavior, especially when dealing with visual data representation. The fix involves modifications to core functions responsible for managing axis limits and autoscaling, ensuring consistent behavior across versions.",
      "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: Surprising/changed axis limit (autoscale) behavior\n\nBody:\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nThe interaction of setting axis limits and autoscaling changed in 3.2 with little guidance, introducing unexpected behavior that doesn't always make sense.\r\n\r\n**Code for reproduction**\r\n\r\nHere is a plot that looks very different on 3.1.2 and 3.2.1\r\n\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\nf, ax = plt.subplots()\r\nx = np.arange(100)\r\ny = np.random.uniform(-.1, .1, 100)\r\nax.scatter(x, y)\r\nassert ax._autoscaleYon\r\nax.set_ylim((-.5, .5), auto=None)\r\n```\r\n\r\n**Actual outcome**\r\n\r\nOn 3.2.1\r\n\r\n![image](https://user-images.githubusercontent.com/315810/81074711-656ca600-8eb7-11ea-9929-cef357be7cf1.png)\r\n\r\n**Expected outcome**\r\n\r\nOn 3.1.2\r\n\r\n![image](https://user-images.githubusercontent.com/315810/81074777-79b0a300-8eb7-11ea-8510-2bddabb72dd1.png)\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: macOS\r\n  * Matplotlib version: 3.2.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): pylab inline\r\n  * Python version: 3.7\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/axes/_base.py\n  function: _AxesBase.set_xlim\n  function: _AxesBase.set_ylim\n"
    },
    {
      "similar_issue": {
        "issue_title": "Major speed regression introduced in \"plt.bar\" definition clipping between 3.0.3 and 3.3.0.",
        "issue_body": "<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nAs I updated Matplolib from version 3.0.3 to version 3.3.0 I noticed that [Colour](https://github.com/colour-science/colour/) unit test time skyrocketed: our plotting sub-package test suite went from 120 seconds to around 3000 seconds!\r\n\r\nI quickly noticed that it was related to definitions using the spectrum plot:\r\n\r\n![image](https://user-images.githubusercontent.com/99779/87933498-78b80680-cae1-11ea-8bf5-b09af15cec50.png)\r\n\r\nThis definition is using `plt.bar` and as I suspected that polygon clipping might be the culprit, I ran some tests on one of the offending definitions while keeping and removing the polygon clipping:\r\n\r\n*With Polygon Clipping*\r\n\r\n```python\r\n>>> import timeit\r\n>>> import colour\r\n>>> timeit.timeit(lambda : colour.plotting.plot_single_illuminant_sd(filename='test.png'), number=1)\r\n59.81594165299998\r\n```\r\n\r\n*Without Polygon Clipping*\r\n```python\r\n>>> import timeit\r\n>>> import colour\r\n>>> timeit.timeit(lambda : colour.plotting.plot_single_illuminant_sd(filename='test.png'), number=1)\r\n1.3159556400000056\r\n```\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug.\r\nPlease make sure to minimize the number of dependencies required, and provide\r\nany necessary plotted data.\r\nAvoid using threads, as Matplotlib is (explicitly) not thread-safe.-->\r\n\r\nI haven't created a reproducible case but my assumption is that the clipping code is orders of magnitude slower than before, the definition I used is available here: https://github.com/colour-science/colour/blob/d5f68005f62fc86ba59745bd4c8bb8a01bb5dcb4/colour/plotting/colorimetry.py#L183 and the meat is roughly as follows:\r\n\r\n```python\r\n    polygon = Polygon(\r\n        np.vstack([\r\n            (x_min, 0),\r\n            tstack([wavelengths, values]),\r\n            (x_max, 0),\r\n        ]),\r\n        facecolor='none',\r\n        edgecolor='none')\r\n    axes.add_patch(polygon)\r\n\r\n    padding = 0.1\r\n    axes.bar(\r\n        x=wavelengths - padding,\r\n        height=max(values),\r\n        width=1 + padding,\r\n        color=colours,\r\n        align='edge',\r\n        clip_path=polygon)\r\n```\r\n\r\nThere are roughly 450 wavelengths and each one of them generates a coloured bar.\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: macOS 10.15.5\r\n  * Matplotlib version: 3.3.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): MacOSX\r\n  * Python version: 3.8\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: \r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\nMatplotlib was installed with Pip.\r\n\r\n",
        "issue_id": 17974,
        "pr_number": 17994,
        "pr_title": "Special case degree-1 Bezier curves.",
        "pr_body": "This greatly speeds up extent computation for the common case of\r\npolylines.  (We were previously only special-casing the degree-0 case.)\r\n\r\nPartially fixes #17974 (4x speedup locally).  My guess is that the real fix will involve restoring a special-case in Path.get_extents for paths that do not contain curves, but this fix is still useful by itself with no additional complexity cost.\r\n\r\n## PR Summary\r\n\r\n## PR Checklist\r\n\r\n- [ ] Has Pytest style unit tests\r\n- [ ] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/next_api_changes/* if API changed in a backward-incompatible way\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_closed_at": "2020-08-05T20:39:02Z",
        "base_commit": "57c8baaf85f0cfd44a27ef834dc971128b7f8ee4"
      },
      "summary": "### Summary:\nThis issue is a performance regression in the Matplotlib library, specifically affecting the `plt.bar` function when using polygon clipping. Users upgrading from version 3.0.3 to 3.3.0 have experienced a significant increase in execution time for unit tests involving the plotting of spectral data, with test durations increasing from approximately 120 seconds to 3000 seconds. The problem is linked to a change in the handling of polygon clipping, which is now orders of magnitude slower, particularly impacting functions that plot a large number of bars, such as those used in the Colour science library's plotting sub-package.\n\nKey symptoms include a drastic slowdown in unit test execution time when polygon clipping is enabled, as demonstrated by a time comparison test that shows a reduction from nearly 60 seconds to just over 1 second when the clipping is removed. The affected component is the `plt.bar` function in Matplotlib, particularly when used with polygon clipping on MacOS with Python 3.8.\n\nThe potential impact of this issue is severe for users who rely on efficient plotting of spectral data or similar applications, as it leads to unacceptable delays in execution. This could affect workflows, especially in automated testing or data visualization tasks, where time efficiency is crucial.\n\nRelevant technical details indicate the problem may stem from the `BezierSegment.axis_aligned_extrema` function in the `lib/matplotlib/bezier.py` file, which could be responsible for the inefficient polygon clipping. Addressing this issue would require optimizing or revising how polygon clipping is handled within the Matplotlib library to restore or improve performance to pre-regression levels.",
      "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: Major speed regression introduced in \"plt.bar\" definition clipping between 3.0.3 and 3.3.0.\n\nBody:\n<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nAs I updated Matplolib from version 3.0.3 to version 3.3.0 I noticed that [Colour](https://github.com/colour-science/colour/) unit test time skyrocketed: our plotting sub-package test suite went from 120 seconds to around 3000 seconds!\r\n\r\nI quickly noticed that it was related to definitions using the spectrum plot:\r\n\r\n![image](https://user-images.githubusercontent.com/99779/87933498-78b80680-cae1-11ea-8bf5-b09af15cec50.png)\r\n\r\nThis definition is using `plt.bar` and as I suspected that polygon clipping might be the culprit, I ran some tests on one of the offending definitions while keeping and removing the polygon clipping:\r\n\r\n*With Polygon Clipping*\r\n\r\n```python\r\n>>> import timeit\r\n>>> import colour\r\n>>> timeit.timeit(lambda : colour.plotting.plot_single_illuminant_sd(filename='test.png'), number=1)\r\n59.81594165299998\r\n```\r\n\r\n*Without Polygon Clipping*\r\n```python\r\n>>> import timeit\r\n>>> import colour\r\n>>> timeit.timeit(lambda : colour.plotting.plot_single_illuminant_sd(filename='test.png'), number=1)\r\n1.3159556400000056\r\n```\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug.\r\nPlease make sure to minimize the number of dependencies required, and provide\r\nany necessary plotted data.\r\nAvoid using threads, as Matplotlib is (explicitly) not thread-safe.-->\r\n\r\nI haven't created a reproducible case but my assumption is that the clipping code is orders of magnitude slower than before, the definition I used is available here: https://github.com/colour-science/colour/blob/d5f68005f62fc86ba59745bd4c8bb8a01bb5dcb4/colour/plotting/colorimetry.py#L183 and the meat is roughly as follows:\r\n\r\n```python\r\n    polygon = Polygon(\r\n        np.vstack([\r\n            (x_min, 0),\r\n            tstack([wavelengths, values]),\r\n            (x_max, 0),\r\n        ]),\r\n        facecolor='none',\r\n        edgecolor='none')\r\n    axes.add_patch(polygon)\r\n\r\n    padding = 0.1\r\n    axes.bar(\r\n        x=wavelengths - padding,\r\n        height=max(values),\r\n        width=1 + padding,\r\n        color=colours,\r\n        align='edge',\r\n        clip_path=polygon)\r\n```\r\n\r\nThere are roughly 450 wavelengths and each one of them generates a coloured bar.\r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: macOS 10.15.5\r\n  * Matplotlib version: 3.3.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): MacOSX\r\n  * Python version: 3.8\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: \r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\nMatplotlib was installed with Pip.\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/bezier.py\n  function: BezierSegment.axis_aligned_extrema\n"
    }
  ]
}