{
  "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 is the most relevant as it deals with raising complex numbers to fractional powers, which is closely related to the current bug involving the simplification of expressions with complex components. The structural similarity with complex arithmetic and the use of the simplify function provides a foundational understanding that would directly aid in debugging the inconsistency observed in the CURRENT bug report. Moreover, the fix focuses on enhancing the handling of complex numbers, which aligns well with the nature of the current issue regarding symbolic manipulation, making it an informative reference for resolving it.",
  "instance_id": "sympy__sympy-14024",
  "repo": "sympy/sympy",
  "created_at": "2018-01-27T05:55:11Z",
  "problem_statement": "Inconsistency when simplifying (-a)**x * a**(-x), a a positive integer\nCompare:\r\n\r\n```\r\n>>> a = Symbol('a', integer=True, positive=True)\r\n>>> e = (-a)**x * a**(-x)\r\n>>> f = simplify(e)\r\n>>> print(e)\r\na**(-x)*(-a)**x\r\n>>> print(f)\r\n(-1)**x\r\n>>> t = -S(10)/3\r\n>>> n1 = e.subs(x,t)\r\n>>> n2 = f.subs(x,t)\r\n>>> print(N(n1))\r\n-0.5 + 0.866025403784439*I\r\n>>> print(N(n2))\r\n-0.5 + 0.866025403784439*I\r\n```\r\n\r\nvs\r\n\r\n```\r\n>>> a = S(2)\r\n>>> e = (-a)**x * a**(-x)\r\n>>> f = simplify(e)\r\n>>> print(e)\r\n(-2)**x*2**(-x)\r\n>>> print(f)\r\n(-1)**x\r\n>>> t = -S(10)/3\r\n>>> n1 = e.subs(x,t)\r\n>>> n2 = f.subs(x,t)\r\n>>> print(N(n1))\r\n0.5 - 0.866025403784439*I\r\n>>> print(N(n2))\r\n-0.5 + 0.866025403784439*I\r\n```\n",
  "patch": "diff --git a/sympy/core/numbers.py b/sympy/core/numbers.py\n--- a/sympy/core/numbers.py\n+++ b/sympy/core/numbers.py\n@@ -1678,11 +1678,7 @@ def _eval_power(self, expt):\n                 if (ne is S.One):\n                     return Rational(self.q, self.p)\n                 if self.is_negative:\n-                    if expt.q != 1:\n-                        return -(S.NegativeOne)**((expt.p % expt.q) /\n-                               S(expt.q))*Rational(self.q, -self.p)**ne\n-                    else:\n-                        return S.NegativeOne**ne*Rational(self.q, -self.p)**ne\n+                    return S.NegativeOne**expt*Rational(self.q, -self.p)**ne\n                 else:\n                     return Rational(self.q, self.p)**ne\n             if expt is S.Infinity:  # -oo already caught by test for negative\n@@ -2223,11 +2219,7 @@ def _eval_power(self, expt):\n             # invert base and change sign on exponent\n             ne = -expt\n             if self.is_negative:\n-                if expt.q != 1:\n-                    return -(S.NegativeOne)**((expt.p % expt.q) /\n-                            S(expt.q))*Rational(1, -self)**ne\n-                else:\n-                    return (S.NegativeOne)**ne*Rational(1, -self)**ne\n+                    return S.NegativeOne**expt*Rational(1, -self)**ne\n             else:\n                 return Rational(1, self.p)**ne\n         # see if base is a perfect root, sqrt(4) --> 2\n"
}