{
  "Selected_candidate": {
    "pr_number": 8223,
    "pr_title": "Add _eval_simplify helper for AlgebraicNumber",
    "pr_body": "fixes #4401\n",
    "issue_id": 4401,
    "issue_title": "Raising complex numbers to fractional powers",
    "issue_body": "bc.. >>> simplify((3+4_I)__(Rational(3,2)))\n(3 + 4_I)**(3/2)\n\n> > > expand(_)\n> > > (3 + 4_I)_*(3/2)\n\nMathematica gives: 2 + 11 \\* I as the answer. Would be good if Sympy could do the same (so far as \nmathematics allows ;)\n\np. Original issue for \"#4401\":https://github.com/sympy/sympy/issues/4401: \"http://code.google.com/p/sympy/issues/detail?id=1302\":http://code.google.com/p/sympy/issues/detail?id=1302\n\np. Original author: \"https://code.google.com/u/111560553046880738986/\":https://code.google.com/u/111560553046880738986/\n\np. Original owner: \"https://code.google.com/u/111560553046880738986/\":https://code.google.com/u/111560553046880738986/\n",
    "issue_closed_at": "2014-11-06T01:06:09Z",
    "base_commit": "0cd829dc3e88d5b1f0fa76a73360f94d58926008",
    "changes": [
      {
        "file": "sympy/core/numbers.py",
        "type": "function",
        "name": "to_algebraic_integer",
        "class_name": "AlgebraicNumber",
        "code": "def to_algebraic_integer(self):\n        \"\"\"Convert ``self`` to an algebraic integer. \"\"\"\n        f = self.minpoly\n\n        if f.LC() == 1:\n            return self\n\n        coeff = f.LC()**(f.degree() - 1)\n        poly = f.compose(C.Poly(f.gen/f.LC()))\n\n        minpoly = poly*coeff\n        root = f.LC()*self.root\n\n        return AlgebraicNumber((minpoly, root), self.coeffs())"
      }
    ]
  },
  "Justification": "Candidate A discusses the simplification issue related to complex numbers with fractional powers, which shows structural similarity to the CURRENT bug report's simplification challenge. Additionally, it involves modifications to the `sympy/core/numbers.py` file, which is part of SymPy's core functionality, making it relevant for understanding general simplification processes. The context of simplifying expressions in both reports aids in forming a practical approach to addressing the simplification problems that arise in the CURRENT bug.",
  "instance_id": "sympy__sympy-13146",
  "repo": "sympy/sympy",
  "created_at": "2017-08-18T05:51:45Z",
  "problem_statement": "Exponent doesn't fully simplify\nSay I have code like this:\n\n```\nimport sympy\nfrom sympy import *\nx=Symbol('x')\nexpr1 = S(1)/2*x**2.5\nexpr2 = S(1)*x**(S(5)/2)/2\nres = expr1-expr2\nres= simplify(res.evalf(5))\nprint res\n```\n\nThe output is\n`-0.5*x**2.5 + 0.5*x**2.5`\nHow do I simplify it to 0?\n\n",
  "patch": "diff --git a/sympy/core/operations.py b/sympy/core/operations.py\n--- a/sympy/core/operations.py\n+++ b/sympy/core/operations.py\n@@ -332,9 +332,7 @@ def _eval_evalf(self, prec):\n                         args.append(a)\n                     else:\n                         args.append(newa)\n-                if not _aresame(tuple(args), tail_args):\n-                    tail = self.func(*args)\n-                return self.func(x, tail)\n+                return self.func(x, *args)\n \n         # this is the same as above, but there were no pure-number args to\n         # deal with\n@@ -345,9 +343,7 @@ def _eval_evalf(self, prec):\n                 args.append(a)\n             else:\n                 args.append(newa)\n-        if not _aresame(tuple(args), self.args):\n-            return self.func(*args)\n-        return self\n+        return self.func(*args)\n \n     @classmethod\n     def make_args(cls, expr):\n"
}