{
    "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."
}