{
  "Selected_candidate": {
    "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_id": 10503,
    "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_closed_at": "2020-02-06T12:07:56Z",
    "base_commit": "a8a3a3b026cc55aa14010fc7cd7909806b6e116c",
    "changes": [
      {
        "file": "sympy/core/function.py",
        "type": "function",
        "name": "_eval_nseries",
        "class_name": "Derivative",
        "code": "def _eval_nseries(self, x, n, logx):\n        if x in self.point:\n            # x is the variable being substituted into\n            apos = self.point.index(x)\n            other = self.variables[apos]\n        else:\n            other = x\n        arg = self.expr.nseries(other, n=n, logx=logx)\n        o = arg.getO()\n        terms = Add.make_args(arg.removeO())\n        rv = Add(*[self.func(a, *self.args[1:]) for a in terms])\n        if o:\n            rv += o.subs(other, x)\n        return rv"
      }
    ]
  },
  "Justification": "Candidate E is the most relevant as it involves a problem related to calculating series expansions, which could share underlying reasoning with the current bug involving the `solve_poly_system` function that deals with solution finding in polynomial equations. Both candidates deal with mathematical functions returning incorrect or non-implemented results. The `solve_poly_system` function's behavior of raising a NotImplementedError suggests a similar need for clearly defined output in other computation functions, like expanding series. The relevance in mathematical processing and how exceptions are handled makes this candidate particularly useful for debugging the current issue.",
  "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"
}