{
  "original_problem": {
    "instance_id": "sympy__sympy-22005",
    "repo": "sympy/sympy",
    "created_at": "2021-09-02T13:05:27Z",
    "problem_statement": "detection of infinite solution request\n```python\r\n>>> solve_poly_system((x - 1,), x, y)\r\nTraceback (most recent call last):\r\n...\r\nNotImplementedError:\r\nonly zero-dimensional systems supported (finite number of solutions)\r\n>>> solve_poly_system((y - 1,), x, y)  <--- this is not handled correctly\r\n[(1,)]\r\n```\r\n```diff\r\ndiff --git a/sympy/solvers/polysys.py b/sympy/solvers/polysys.py\r\nindex b9809fd4e9..674322d4eb 100644\r\n--- a/sympy/solvers/polysys.py\r\n+++ b/sympy/solvers/polysys.py\r\n@@ -240,7 +240,7 @@ def _solve_reduced_system(system, gens, entry=False):\r\n \r\n         univariate = list(filter(_is_univariate, basis))\r\n \r\n-        if len(univariate) == 1:\r\n+        if len(univariate) == 1 and len(gens) == 1:\r\n             f = univariate.pop()\r\n         else:\r\n             raise NotImplementedError(filldedent('''\r\ndiff --git a/sympy/solvers/tests/test_polysys.py b/sympy/solvers/tests/test_polysys.py\r\nindex 58419f8762..9e674a6fe6 100644\r\n--- a/sympy/solvers/tests/test_polysys.py\r\n+++ b/sympy/solvers/tests/test_polysys.py\r\n@@ -48,6 +48,10 @@ def test_solve_poly_system():\r\n     raises(NotImplementedError, lambda: solve_poly_system(\r\n         [z, -2*x*y**2 + x + y**2*z, y**2*(-z - 4) + 2]))\r\n     raises(PolynomialError, lambda: solve_poly_system([1/x], x))\r\n+    raises(NotImplementedError, lambda: solve_poly_system(\r\n+        Poly(x - 1, x, y), (x, y)))\r\n+    raises(NotImplementedError, lambda: solve_poly_system(\r\n+        Poly(y - 1, x, y), (x, y)))\r\n \r\n \r\n def test_solve_biquadratic():\r\n```\n",
    "patch": "diff --git a/sympy/solvers/polysys.py b/sympy/solvers/polysys.py\n--- a/sympy/solvers/polysys.py\n+++ b/sympy/solvers/polysys.py\n@@ -240,6 +240,12 @@ def _solve_reduced_system(system, gens, entry=False):\n \n         univariate = list(filter(_is_univariate, basis))\n \n+        if len(basis) < len(gens):\n+            raise NotImplementedError(filldedent('''\n+                only zero-dimensional systems supported\n+                (finite number of solutions)\n+                '''))\n+\n         if len(univariate) == 1:\n             f = univariate.pop()\n         else:\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_9184",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves limit computation rather than handling of solution dimensions or system constraints."
      },
      {
        "idx": 2,
        "id": "similar_17722",
        "decision": "Useful",
        "confidence": "Medium",
        "reason": "Both issues involve handling input constraints and ensuring correct dimensionality or structure in mathematical computations."
      },
      {
        "idx": 3,
        "id": "similar_13066",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about expression rewriting rather than handling system dimensionality or solution constraints."
      },
      {
        "idx": 4,
        "id": "similar_17350",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue focuses on input validation for specific function arguments, not on system dimensionality or solution constraints."
      },
      {
        "idx": 5,
        "id": "similar_10503",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue pertains to series expansion errors, unrelated to handling system dimensionality or solution constraints."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "bell(n).limit(n, oo) should be oo rather than bell(oo)",
        "issue_body": "`bell(n).limit(n,oo)` should take the value infinity, but the current output is `bell(oo)`. As the Bell numbers represent the number of partitions of a set, it seems natural that `bell(oo)` should be able to be evaluated rather than be returned unevaluated. This issue is also in line with the recent fixes to the corresponding limit for the Fibonacci numbers and Lucas numbers.\n\n```\nfrom sympy import *\nn = symbols('n')\nbell(n).limit(n,oo)\n\nOutput:\nbell(oo)\n```\n\nI'm new to Sympy, so I'd appreciate the opportunity to fix this bug myself if that's alright.\n",
        "issue_id": 9184,
        "pr_number": 13437,
        "pr_title": "Fix bell(n) for n=oo, and negative/non-integer 'n'",
        "pr_body": "This PR uses commits of #9198 (maintaining ownership to original author). And tries to address the requested changes on PR #9198 .\r\nFixes #9184",
        "issue_closed_at": "2017-10-13T04:35:13Z",
        "base_commit": "674afc619d7f5c519b6a5393a8b0532a131e57e0"
      },
      "summary": "### Summary: This issue pertains to the computation of limits within the SymPy library, specifically concerning the behavior of the Bell numbers when approached at infinity. In general terms, the problem is that the limit of the Bell number function as the argument approaches infinity was returning an unevaluated symbolic expression `bell(oo)` instead of the expected mathematical result of infinity (`oo`). \n\nKey symptoms include the incorrect output of `bell(oo)` when `bell(n).limit(n, oo)` is computed, suggesting that the function does not appropriately handle the asymptotic behavior of Bell numbers. The affected system is the SymPy library, a Python library for symbolic mathematics, particularly the module responsible for combinatorial functions.\n\nThe potential impact of this issue is significant for users relying on SymPy for accurate mathematical modeling and analysis, especially in scenarios involving asymptotic analysis or large dataset computations where the behavior of functions at infinity is critical. This issue is similar to previously addressed problems with the limit calculations for other combinatorial sequences like Fibonacci and Lucas numbers, indicating a broader pattern that needed addressing.\n\nThe technical details involve updating the internal logic of the SymPy library to ensure that the Bell number function correctly evaluates to infinity when taking the limit at infinity, aligning with mathematical expectations and enhancing the library's reliability for users. The specific code change occurred in the `sympy/functions/combinatorial/numbers.py` file, focusing on the function `bell._bell_incomplete_poly`.",
      "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: bell(n).limit(n, oo) should be oo rather than bell(oo)\n\nBody:\n`bell(n).limit(n,oo)` should take the value infinity, but the current output is `bell(oo)`. As the Bell numbers represent the number of partitions of a set, it seems natural that `bell(oo)` should be able to be evaluated rather than be returned unevaluated. This issue is also in line with the recent fixes to the corresponding limit for the Fibonacci numbers and Lucas numbers.\n\n```\nfrom sympy import *\nn = symbols('n')\nbell(n).limit(n,oo)\n\nOutput:\nbell(oo)\n```\n\nI'm new to Sympy, so I'd appreciate the opportunity to fix this bug myself if that's alright.\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:\nsympy/functions/combinatorial/numbers.py\n  function: bell._bell_incomplete_poly\n"
    },
    {
      "similar_issue": {
        "issue_title": "linsolve error; ValueError: Got rows of variable lengths: [1, 3]",
        "issue_body": "Can anyone tell me if this is a bug and if there is a method to get around this please, cause it seems like the linsolve() function is broken?\r\nA similar question was asked in issue #17430 but this doesn't solve my problem when used in jupyter or qtconsole or spyder. This function would be really useful if it worked for my uni study.\r\n\r\nParameters given are: *system* in form of Ax=b and variables *c* in a tuple of Sympy Symbols\r\n![image](https://user-images.githubusercontent.com/42601907/66694509-028ba580-ed00-11e9-85db-f8e1567a5306.png)\r\n![image](https://user-images.githubusercontent.com/42601907/66694519-1505df00-ed00-11e9-9861-02ea8f1dd249.png)\r\n",
        "issue_id": 17722,
        "pr_number": 17769,
        "pr_title": "Fix linsolve  for immutable matrix",
        "pr_body": "<!-- Your title above should be a short description of what\r\nwas changed. Do not include the issue number in the title. -->\r\n\r\n#### References to other Issues or PRs\r\n<!-- If this pull request fixes an issue, write \"Fixes #NNNN\" in that exact\r\nformat, e.g. \"Fixes #1234\". See\r\nhttps://github.com/blog/1506-closing-issues-via-pull-requests . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\nFixes #17762 \r\nFixes #17722 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nI've fixed the type checking for `linearsolve`, and also fixed some usage of the mutability of a matrix in `gauss_jordan_solve`.\r\n\r\n#### Other comments\r\n\r\nI'd also try to check `linsolve` whether it works with matrix expressions.\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below. See\r\nhttps://github.com/sympy/sympy/wiki/Writing-Release-Notes for more information\r\non how to write release notes. The bot will check your release notes\r\nautomatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n- matrices\r\n  - Fixed `Matrix.gauss_jordan_solve` raising `ShapeError` for immutable matrices.\r\n- solvers\r\n  - Fixed `linsolve` raising errors for `ImmutableMatrix`.\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-10-21T21:12:36Z",
        "base_commit": "4c87ea3ec5a36b0d3364b9bc52f88653282bf9aa"
      },
      "summary": "### Summary:\n\nThis issue pertains to a problem encountered when using the `linsolve()` function in the Sympy library, which is a Python library for symbolic mathematics. The user experienced a `ValueError` indicating that the function received rows of variable lengths, specifically `[1, 3]`. This suggests that the function was unable to process the input matrices correctly, likely due to inconsistencies in the input dimensions or structure. \n\nKey symptoms include the function failing when executed in environments such as Jupyter, QtConsole, or Spyder, which are commonly used for educational purposes and could hinder users, particularly students, from utilizing this functionality effectively in their studies.\n\nThe affected components are primarily within the Sympy library, specifically the `linsolve` function and related matrix-solving methods in `sympy/matrices/matrices.py` and `sympy/solvers/solveset.py`. The functions `MatrixBase.gauss_jordan_solve` and `linsolve` are explicitly mentioned in the code elements fixed by the patch, indicating that they required modification to address the issue.\n\nThe potential impact of this problem is significant for users who rely on Sympy for solving linear equations symbolically, especially in academic settings where such capabilities are crucial for learning and research. The severity is heightened as it affects multiple popular development environments.\n\nTechnical details abstracted for broader understanding include the importance of ensuring consistent input dimensions for matrix operations and the need for robust error handling in mathematical libraries to prevent such issues from arising. The fix likely involved ensuring that the functions correctly handle varying row lengths and implement appropriate checks or transformations on the input data to maintain compatibility across different environments.",
      "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: linsolve error; ValueError: Got rows of variable lengths: [1, 3]\n\nBody:\nCan anyone tell me if this is a bug and if there is a method to get around this please, cause it seems like the linsolve() function is broken?\r\nA similar question was asked in issue #17430 but this doesn't solve my problem when used in jupyter or qtconsole or spyder. This function would be really useful if it worked for my uni study.\r\n\r\nParameters given are: *system* in form of Ax=b and variables *c* in a tuple of Sympy Symbols\r\n![image](https://user-images.githubusercontent.com/42601907/66694509-028ba580-ed00-11e9-85db-f8e1567a5306.png)\r\n![image](https://user-images.githubusercontent.com/42601907/66694519-1505df00-ed00-11e9-9861-02ea8f1dd249.png)\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:\nsympy/matrices/matrices.py\n  function: MatrixBase.gauss_jordan_solve\n  function: MatrixBase.gauss_jordan_solve\n  function: MatrixBase.gauss_jordan_solve\n\nsympy/solvers/solveset.py\n  function: linsolve\n  function: linsolve\n"
    },
    {
      "similar_issue": {
        "issue_title": "cos(pi/51).rewrite(sqrt) does not fully rewrite the expression on python 3.6 (test failure)",
        "issue_body": "It currently returns `cos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2`, even though both `cos(6*pi/17)` and `sin(6*pi/17)` can be rewritten using `sqrt`s. The slow test `test_sincos_rewrite_sqrt` in test_trigonometric.py currently fails because it tests that `cos(pi/51).rewrite(sqrt)` returns the full expression in terms of `sqrt`s. I tested on python 3.4 64 bit and python 3.6 64 bit, and it only happens on 3.6, which is odd. I tried a fresh installation for 3.6 to be sure it wasn't anything I changed and it still happened.\r\n```\r\n>>> cos(pi/51).rewrite(sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n>>> cos(pi/51).rewrite(cos, sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n>>> cos(pi/51).rewrite([cos, sin], sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n```",
        "issue_id": 13066,
        "pr_number": 13103,
        "pr_title": "fixed cos.rewrite(sqrt) sometimes not fully rewriting",
        "pr_body": "See #13066\r\n`functions.elementary.trigonometric.cos._eval_rewrite_as_sqrt` would fail to fully rewrite `cos(pi/51)` on python 3.6 only. This turned out to be an issue with the `_fermatCoords` function which is supposed to factor 51 into fermat primes. Trigonometric expressions with these fermat primes as denominators of pi can be rewritten using squareroots.\r\n\r\nThe function uses `divmod` repeatedly to get the factors. `n` was set to the whole number result of the `divmod`. This is where the bug was, since that would mean that if `n` was not divisible by that particular factor, then `n` would still be changed to the whole number result, which usually ended up being 0, in which case the function would miss the other factors and return `False`. Or in rare cases it would have led to a false factorization.\r\n\r\nThe reason this bug only revealed itself in 3.6 is because the ordering of dicts was changed. Previously for n=51 it so happened that python ordered the dict with 17 first, then 3, which are both divisible.\r\n\r\n<!-- Please give this pull request a descriptive title. Pull requests with descriptive titles are more likely to receive reviews. Describe what you changed! A title that only references an issue number is not descriptive. -->\r\n\r\n<!-- If this pull request fixes an issue please indicate which issue by typing \"Fixes #NNNN\" below. -->\r\nFixes #13066",
        "issue_closed_at": "2017-08-10T09:16:46Z",
        "base_commit": "8ff744d843f9dc78c560e61e3edc01f878d1960b"
      },
      "summary": "### Summary:\n\nThis issue is related to the symbolic computation library SymPy and concerns the expression rewriting functionality for trigonometric functions. Specifically, the problem arises when attempting to rewrite the cosine of a specific angle, `cos(pi/51)`, in terms of square roots using the `rewrite(sqrt)` method in Python 3.6. The expectation was that the rewritten expression would be fully simplified using square roots, but the output was only partially rewritten, retaining some trigonometric functions in the result. This discrepancy causes a test failure in `test_trigonometric.py`, indicating that the rewrite operation does not perform as intended on Python 3.6, although it works correctly on Python 3.4. The issue affects the trigonometric function rewriting system within SymPy and has the potential to impact the accuracy and performance of symbolic computations relying on this functionality. The problem was isolated to a specific function within the codebase, `cos._fermatCoords`, which required modifications to ensure consistent and correct rewriting of trigonometric expressions across different Python 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: cos(pi/51).rewrite(sqrt) does not fully rewrite the expression on python 3.6 (test failure)\n\nBody:\nIt currently returns `cos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2`, even though both `cos(6*pi/17)` and `sin(6*pi/17)` can be rewritten using `sqrt`s. The slow test `test_sincos_rewrite_sqrt` in test_trigonometric.py currently fails because it tests that `cos(pi/51).rewrite(sqrt)` returns the full expression in terms of `sqrt`s. I tested on python 3.4 64 bit and python 3.6 64 bit, and it only happens on 3.6, which is odd. I tried a fresh installation for 3.6 to be sure it wasn't anything I changed and it still happened.\r\n```\r\n>>> cos(pi/51).rewrite(sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n>>> cos(pi/51).rewrite(cos, sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n>>> cos(pi/51).rewrite([cos, sin], sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\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:\nsympy/functions/elementary/trigonometric.py\n  function: cos._fermatCoords\n"
    },
    {
      "similar_issue": {
        "issue_title": "Should polygamma(a, b) raise NotImplementedError for noninteger (numeric) a?",
        "issue_body": "mpmath's implementation of polygamma is valid only for integer first arguments. SymPy's implementation does not care, but this leads to many issues if you actually try to do things with such objects:\r\n\r\n```\r\n>>> (I*polygamma(I, pi)).as_real_imag()\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'finite'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'extended_positive'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1308, in evalf\r\n    rf = evalf_table[x.func]\r\nKeyError: polygamma\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/eward/se2/sympy/core/mul.py\", line 798, in as_real_imag\r\n    if i.is_zero:\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 864, in _eval_is_negative\r\n    finite = self.is_finite\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 857, in _eval_is_positive\r\n    extended_positive = self.is_extended_positive\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 882, in _eval_is_extended_positive\r\n    n2 = self._eval_evalf(2)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in _eval_evalf\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in <listcomp>\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1489, in _to_mpmath\r\n    re, im, _, _ = evalf(self, prec, {})\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1314, in evalf\r\n    xe = x._eval_evalf(prec)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 590, in _eval_evalf\r\n    v = func(*args)\r\n  File \"/usr/local/lib/python3.6/dist-packages/mpmath/ctx_mp.py\", line 265, in psi\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (tanh(polygamma(I, 1))).rewrite(exp)\r\n...\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (I / polygamma(I, 4)).rewrite(exp)\r\n...\r\n    raise TypeError(\"Invalid comparison of complex %s\" % me)\r\nTypeError: Invalid comparison of complex I\r\n```",
        "issue_id": 17350,
        "pr_number": 17375,
        "pr_title": "polygamma improvements (evaluation, real and positivity determination)",
        "pr_body": "Closes #17350. Fixes #12569.\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\n- Add `_eval_evalf` to prevent evaluation when the first argument is not a nonnegative integer.\r\n- Remove `_eval_is_real` since the logic was wrong.\r\n- Update `_eval_is_positive` and `_eval_is_negative` to avoid doing comparisons with `>`.\r\n\r\n#### Release Notes\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\nNO ENTRY\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-08-23T06:49:24Z",
        "base_commit": "fc6f766ab588fecbb69ad85eb01ca28b44715e5c"
      },
      "summary": "### Summary:\nThis issue pertains to the function `polygamma` within the SymPy library, which incorrectly handles non-integer numeric inputs for its first argument. The `polygamma` function is intended to operate correctly only when the first argument is an integer; however, SymPy's current implementation does not enforce this restriction, leading to a variety of errors when complex or non-integer inputs are used.\n\n1. **Problem Description:**\n   The core problem is the lack of input validation for the `polygamma` function, which should only accept integer values for its first argument. This oversight allows non-integer or complex values to be processed, resulting in multiple unhandled exceptions and errors.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - Attempting to evaluate expressions involving `polygamma` with a non-integer first argument leads to several tracebacks and errors.\n   - Errors include `KeyError` related to assumptions and a `TypeError` when attempting type conversions, indicating the system's inability to handle such inputs gracefully.\n   - Specific operations such as `as_real_imag()` and `rewrite(exp)` on expressions involving `polygamma` with non-integer inputs result in exceptions.\n\n3. **Affected Components or Systems:**\n   - The primary component affected is the `polygamma` function within the `sympy/functions/special/gamma_functions.py` file.\n   - Other parts of the SymPy library that interact with function evaluation and assumption handling are indirectly affected due to the propagation of errors.\n\n4. **Potential Impact or Severity:**\n   - The impact is significant for users relying on accurate mathematical computations involving `polygamma` with potentially non-integer inputs.\n   - The errors can lead to incorrect results or crashes in applications relying on the SymPy library for symbolic computation, thus affecting reliability and accuracy.\n\n5. **Relevant Technical Details:**\n   - The errors stem from the lack of checks ensuring the first argument of `polygamma` is an integer.\n   - The fix involves modifying the relevant class and functions within `sympy/functions/special/gamma_functions.py` to implement appropriate input validation, ensuring that only integer values are processed, thereby preventing the propagation of errors through the system.",
      "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: Should polygamma(a, b) raise NotImplementedError for noninteger (numeric) a?\n\nBody:\nmpmath's implementation of polygamma is valid only for integer first arguments. SymPy's implementation does not care, but this leads to many issues if you actually try to do things with such objects:\r\n\r\n```\r\n>>> (I*polygamma(I, pi)).as_real_imag()\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'finite'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'extended_positive'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1308, in evalf\r\n    rf = evalf_table[x.func]\r\nKeyError: polygamma\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/eward/se2/sympy/core/mul.py\", line 798, in as_real_imag\r\n    if i.is_zero:\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 864, in _eval_is_negative\r\n    finite = self.is_finite\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 857, in _eval_is_positive\r\n    extended_positive = self.is_extended_positive\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 882, in _eval_is_extended_positive\r\n    n2 = self._eval_evalf(2)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in _eval_evalf\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in <listcomp>\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1489, in _to_mpmath\r\n    re, im, _, _ = evalf(self, prec, {})\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1314, in evalf\r\n    xe = x._eval_evalf(prec)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 590, in _eval_evalf\r\n    v = func(*args)\r\n  File \"/usr/local/lib/python3.6/dist-packages/mpmath/ctx_mp.py\", line 265, in psi\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (tanh(polygamma(I, 1))).rewrite(exp)\r\n...\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (I / polygamma(I, 4)).rewrite(exp)\r\n...\r\n    raise TypeError(\"Invalid comparison of complex %s\" % me)\r\nTypeError: Invalid comparison of complex I\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:\nsympy/functions/special/gamma_functions.py\n  class: polygamma\n  function: multigamma.fdiff\n  function: loggamma._eval_expand_func\n"
    },
    {
      "similar_issue": {
        "issue_title": "Series return an incorrect result",
        "issue_body": "The latest sympy master:\n\n```\nIn [1]: f=exp(x**3)*cos(x**6)\n\nIn [2]: f.series(x, 0, 14)\nOut[2]: \n          6    9    12         \n     3   x    x    x      ⎛ 14⎞\n1 + x  + ── + ── + ─── + O⎝x  ⎠\n         2    6     24         \n\nIn [3]: f.series(x, 0, 19)\nOut[3]: \n          6    9       12       15        18         \n     3   x    x    11⋅x     59⋅x     179⋅x      ⎛ 19⎞\n1 + x  + ── + ── - ────── - ────── - ─────── + O⎝x  ⎠\n         2    6      24      120       720           \n```\n",
        "issue_id": 10503,
        "pr_number": 18578,
        "pr_title": "Fixes bug in Series",
        "pr_body": "<!-- Your title above should be a short description of what\r\nwas changed. Do not include the issue number in the title. -->\r\n\r\n#### References to other Issues or PRs\r\n<!-- If this pull request fixes an issue, write \"Fixes #NNNN\" in that exact\r\nformat, e.g. \"Fixes #1234\" (see\r\nhttps://tinyurl.com/auto-closing for more information). Also, please\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\n#Fixes #10503\r\n#### Brief description of what is fixed or changed\r\nNow, \r\n`f=exp(x**3)*cos(x**6)`\r\n`f.series(x, 0, 14)`\r\nreturn correct result.\r\n\r\n#### Other comments\r\n\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below. See\r\nhttps://github.com/sympy/sympy/wiki/Writing-Release-Notes for more information\r\non how to write release notes. The bot will check your release notes\r\nautomatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\nNO ENTRY\r\n<!-- END RELEASE NOTES -->",
        "issue_closed_at": "2020-02-06T12:07:56Z",
        "base_commit": "a8a3a3b026cc55aa14010fc7cd7909806b6e116c"
      },
      "summary": "### Summary:\nThis issue pertains to the incorrect computation of series expansions in the SymPy library, specifically when calculating the series of a composite function involving exponential and trigonometric components. The problem manifests as incorrect coefficients in higher-order terms when expanding the series to certain orders. This miscalculation occurs in the function responsible for evaluating the series representation of derivatives, which is a core part of the symbolic computation engine in SymPy.\n\nKey symptoms include:\n- Incorrect coefficients in the series expansion of the function `exp(x**3)*cos(x**6)` when expanded to orders 14 and 19. Specifically, the coefficients for the terms of order x^12 and higher are incorrect, leading to discrepancies between expected and computed results.\n\nAffected components:\n- The component affected is the `Derivative._eval_nseries` function within `sympy/core/function.py`. This function plays a crucial role in the symbolic manipulation and computation of series, which is essential for accurate mathematical modeling and analysis.\n\nPotential impact or severity:\n- The severity of this issue is significant for users relying on SymPy for precise symbolic computations, especially in fields requiring high accuracy in series expansions, such as mathematical research, engineering simulations, and academic work. Incorrect results could lead to faulty analyses and conclusions.\n\nRelevant technical details abstracted for broader understanding:\n- The problem is rooted in the algorithm used for series expansion, which needs to correctly handle the combination of exponential and trigonometric functions. Ensuring the accuracy of such computations is crucial for the integrity of symbolic mathematical operations in the library. The patch addresses this by modifying the series evaluation logic to correctly compute higher-order terms.",
      "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: Series return an incorrect result\n\nBody:\nThe latest sympy master:\n\n```\nIn [1]: f=exp(x**3)*cos(x**6)\n\nIn [2]: f.series(x, 0, 14)\nOut[2]: \n          6    9    12         \n     3   x    x    x      ⎛ 14⎞\n1 + x  + ── + ── + ─── + O⎝x  ⎠\n         2    6     24         \n\nIn [3]: f.series(x, 0, 19)\nOut[3]: \n          6    9       12       15        18         \n     3   x    x    11⋅x     59⋅x     179⋅x      ⎛ 19⎞\n1 + x  + ── + ── - ────── - ────── - ─────── + O⎝x  ⎠\n         2    6      24      120       720           \n```\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/core/function.py\n  function: Derivative._eval_nseries\n"
    }
  ]
}