{
  "instance_id": "sympy__sympy-21627",
  "repo": "sympy/sympy",
  "created_at": "2021-06-16T17:29:41Z",
  "problem_statement": "Bug: maximum recusion depth error when checking is_zero of cosh expression\nThe following code causes a `RecursionError: maximum recursion depth exceeded while calling a Python object` error when checked if it is zero:\r\n```\r\nexpr =sympify(\"cosh(acos(-i + acosh(-g + i)))\")\r\nexpr.is_zero\r\n```\n",
  "patch": "diff --git a/sympy/functions/elementary/complexes.py b/sympy/functions/elementary/complexes.py\n--- a/sympy/functions/elementary/complexes.py\n+++ b/sympy/functions/elementary/complexes.py\n@@ -607,6 +607,8 @@ def eval(cls, arg):\n             arg2 = -S.ImaginaryUnit * arg\n             if arg2.is_extended_nonnegative:\n                 return arg2\n+        if arg.is_extended_real:\n+            return\n         # reject result if all new conjugates are just wrappers around\n         # an expression that was already in the arg\n         conj = signsimp(arg.conjugate(), evaluate=False)\n",
  "similar_bug_items": [
    {
      "pr_number": 8548,
      "pr_title": "Issue #6988: expand_log(exp(x), force=True) = x",
      "pr_body": "This is a try to fix issue #6988. If I made some mistake just let me know, as I'm still new to sympy development.\n\n```\nIn [9]: expand_log(log(exp(x)), force=True)\nOut[9]: x\n\nIn [10]: expand_log(log(y**(x)), force=True)\nOut[10]: x\u22c5log(y)\n```\n",
      "issue_id": 6988,
      "issue_title": "expand_log(exp(x), force=True) should give x",
      "issue_body": "```\nIn [5]: expand_log(log(exp(x)), force=True)\nOut[5]:\n   \u239b x\u239e\nlog\u239d\u212f \u23a0\n\nIn [6]: expand_log(log(y**(x)), force=True)\nOut[6]: x\u22c5log(y) Issue 1799 is probably to blame.\n```\n\nOriginal issue for #6988: http://code.google.com/p/sympy/issues/detail?id=3889\nOriginal author: https://code.google.com/u/asmeurer@gmail.com/\n",
      "issue_closed_at": "2014-12-03T13:34:14Z",
      "base_commit": "e6fc53f27ee872b27bc79b96529fc4bf34d4f023",
      "changes": [
        {
          "file": "sympy/functions/elementary/exponential.py",
          "type": "function",
          "name": "_eval_expand_log",
          "class_name": "log",
          "code": "def _eval_expand_log(self, deep=True, **hints):\n        from sympy import unpolarify\n        from sympy.concrete import Sum, Product\n        force = hints.get('force', False)\n        arg = self.args[0]\n        if arg.is_Integer:\n            # remove perfect powers\n            p = perfect_power(int(arg))\n            if p is not False:\n                return p[1]*self.func(p[0])\n        elif arg.is_Mul:\n            expr = []\n            nonpos = []\n            for x in arg.args:\n                if force or x.is_positive or x.is_polar:\n                    a = self.func(x)\n                    if isinstance(a, log):\n                        expr.append(self.func(x)._eval_expand_log(**hints))\n                    else:\n                        expr.append(a)\n                elif x.is_negative:\n                    a = self.func(-x)\n                    expr.append(a)\n                    nonpos.append(S.NegativeOne)\n                else:\n                    nonpos.append(x)\n            return Add(*expr) + log(Mul(*nonpos))\n        elif arg.is_Pow:\n            if force or (arg.exp.is_real and arg.base.is_positive) or \\\n                    arg.base.is_polar:\n                b = arg.base\n                e = arg.exp\n                a = self.func(b)\n                if isinstance(a, log):\n                    return unpolarify(e) * a._eval_expand_log(**hints)\n                else:\n                    return unpolarify(e) * a\n        elif isinstance(arg, Product):\n            if arg.function.is_positive:\n                return Sum(log(arg.function), *arg.limits)\n\n        return self.func(arg)"
        }
      ]
    },
    {
      "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_id": 17350,
      "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_closed_at": "2019-08-23T06:49:24Z",
      "base_commit": "fc6f766ab588fecbb69ad85eb01ca28b44715e5c",
      "changes": [
        {
          "file": "sympy/functions/special/gamma_functions.py",
          "type": "class",
          "name": "polygamma",
          "code": "class polygamma(Function):\n    r\"\"\"\n    The function ``polygamma(n, z)`` returns ``log(gamma(z)).diff(n + 1)``.\n\n    It is a meromorphic function on `\\mathbb{C}` and defined as the (n+1)-th\n    derivative of the logarithm of the gamma function:\n\n    .. math::\n        \\psi^{(n)} (z) := \\frac{\\mathrm{d}^{n+1}}{\\mathrm{d} z^{n+1}} \\log\\Gamma(z).\n\n    Examples\n    ========\n\n    Several special values are known:\n\n    >>> from sympy import S, polygamma\n    >>> polygamma(0, 1)\n    -EulerGamma\n    >>> polygamma(0, 1/S(2))\n    -2*log(2) - EulerGamma\n    >>> polygamma(0, 1/S(3))\n    -log(3) - sqrt(3)*pi/6 - EulerGamma - log(sqrt(3))\n    >>> polygamma(0, 1/S(4))\n    -pi/2 - log(4) - log(2) - EulerGamma\n    >>> polygamma(0, 2)\n    1 - EulerGamma\n    >>> polygamma(0, 23)\n    19093197/5173168 - EulerGamma\n\n    >>> from sympy import oo, I\n    >>> polygamma(0, oo)\n    oo\n    >>> polygamma(0, -oo)\n    oo\n    >>> polygamma(0, I*oo)\n    oo\n    >>> polygamma(0, -I*oo)\n    oo\n\n    Differentiation with respect to x is supported:\n\n    >>> from sympy import Symbol, diff\n    >>> x = Symbol(\"x\")\n    >>> diff(polygamma(0, x), x)\n    polygamma(1, x)\n    >>> diff(polygamma(0, x), x, 2)\n    polygamma(2, x)\n    >>> diff(polygamma(0, x), x, 3)\n    polygamma(3, x)\n    >>> diff(polygamma(1, x), x)\n    polygamma(2, x)\n    >>> diff(polygamma(1, x), x, 2)\n    polygamma(3, x)\n    >>> diff(polygamma(2, x), x)\n    polygamma(3, x)\n    >>> diff(polygamma(2, x), x, 2)\n    polygamma(4, x)\n\n    >>> n = Symbol(\"n\")\n    >>> diff(polygamma(n, x), x)\n    polygamma(n + 1, x)\n    >>> diff(polygamma(n, x), x, 2)\n    polygamma(n + 2, x)\n\n    We can rewrite polygamma functions in terms of harmonic numbers:\n\n    >>> from sympy import harmonic\n    >>> polygamma(0, x).rewrite(harmonic)\n    harmonic(x - 1) - EulerGamma\n    >>> polygamma(2, x).rewrite(harmonic)\n    2*harmonic(x - 1, 3) - 2*zeta(3)\n    >>> ni = Symbol(\"n\", integer=True)\n    >>> polygamma(ni, x).rewrite(harmonic)\n    (-1)**(n + 1)*(-harmonic(x - 1, n + 1) + zeta(n + 1))*factorial(n)\n\n    See Also\n    ========\n\n    gamma: Gamma function.\n    lowergamma: Lower incomplete gamma function.\n    uppergamma: Upper incomplete gamma function.\n    loggamma: Log Gamma function.\n    digamma: Digamma function.\n    trigamma: Trigamma function.\n    sympy.functions.special.beta_functions.beta: Euler Beta function.\n\n    References\n    ==========\n\n    .. [1] https://en.wikipedia.org/wiki/Polygamma_function\n    .. [2] http://mathworld.wolfram.com/PolygammaFunction.html\n    .. [3] http://functions.wolfram.com/GammaBetaErf/PolyGamma/\n    .. [4] http://functions.wolfram.com/GammaBetaErf/PolyGamma2/\n    \"\"\"\n\n\n    def fdiff(self, argindex=2):\n        if argindex == 2:\n            n, z = self.args[:2]\n            return polygamma(n + 1, z)\n        else:\n            raise ArgumentIndexError(self, argindex)\n\n    def _eval_is_positive(self):\n        if self.args[1].is_positive and (self.args[0] > 0) == True:\n            return self.args[0].is_odd\n\n    def _eval_is_negative(self):\n        if self.args[1].is_positive and (self.args[0] > 0) == True:\n            return self.args[0].is_even\n\n    def _eval_is_real(self):\n        return self.args[0].is_real\n\n    def _eval_aseries(self, n, args0, x, logx):\n        from sympy import Order\n        if args0[1] != oo or not \\\n                (self.args[0].is_Integer and self.args[0].is_nonnegative):\n            return super(polygamma, self)._eval_aseries(n, args0, x, logx)\n        z = self.args[1]\n        N = self.args[0]\n\n        if N == 0:\n            # digamma function series\n            # Abramowitz & Stegun, p. 259, 6.3.18\n            r = log(z) - 1/(2*z)\n            o = None\n            if n < 2:\n                o = Order(1/z, x)\n            else:\n                m = ceiling((n + 1)//2)\n                l = [bernoulli(2*k) / (2*k*z**(2*k)) for k in range(1, m)]\n                r -= Add(*l)\n                o = Order(1/z**(2*m), x)\n            return r._eval_nseries(x, n, logx) + o\n        else:\n            # proper polygamma function\n            # Abramowitz & Stegun, p. 260, 6.4.10\n            # We return terms to order higher than O(x**n) on purpose\n            # -- otherwise we would not be able to return any terms for\n            #    quite a long time!\n            fac = gamma(N)\n            e0 = fac + N*fac/(2*z)\n            m = ceiling((n + 1)//2)\n            for k in range(1, m):\n                fac = fac*(2*k + N - 1)*(2*k + N - 2) / ((2*k)*(2*k - 1))\n                e0 += bernoulli(2*k)*fac/z**(2*k)\n            o = Order(1/z**(2*m), x)\n            if n == 0:\n                o = Order(1/z, x)\n            elif n == 1:\n                o = Order(1/z**2, x)\n            r = e0._eval_nseries(z, n, logx) + o\n            return (-1 * (-1/z)**N * r)._eval_nseries(x, n, logx)\n\n    @classmethod\n    def eval(cls, n, z):\n        n, z = map(sympify, (n, z))\n        from sympy import unpolarify\n\n        if n.is_integer:\n            if n.is_nonnegative:\n                nz = unpolarify(z)\n                if z != nz:\n                    return polygamma(n, nz)\n\n            if n == -1:\n                return loggamma(z)\n            else:\n                if z.is_Number:\n                    if z is S.NaN:\n                        return S.NaN\n                    elif z is S.Infinity:\n                        if n.is_Number:\n                            if n is S.Zero:\n                                return S.Infinity\n                            else:\n                                return S.Zero\n                    elif z.is_Integer:\n                        if z.is_nonpositive:\n                            return S.ComplexInfinity\n                        else:\n                            if n is S.Zero:\n                                return -S.EulerGamma + harmonic(z - 1, 1)\n                            elif n.is_odd:\n                                return (-1)**(n + 1)*factorial(n)*zeta(n + 1, z)\n\n        if n == 0:\n            if z is S.NaN:\n                return S.NaN\n            elif z.is_Rational:\n\n                p, q = z.as_numer_denom()\n\n                # only expand for small denominators to avoid creating long expressions\n                if q <= 5:\n                    return expand_func(polygamma(n, z, evaluate=False))\n\n            elif z in (S.Infinity, S.NegativeInfinity):\n                return S.Infinity\n            else:\n                t = z.extract_multiplicatively(S.ImaginaryUnit)\n                if t in (S.Infinity, S.NegativeInfinity):\n                    return S.Infinity\n\n        # TODO n == 1 also can do some rational z\n\n    def _eval_expand_func(self, **hints):\n        n, z = self.args\n\n        if n.is_Integer and n.is_nonnegative:\n            if z.is_Add:\n                coeff = z.args[0]\n                if coeff.is_Integer:\n                    e = -(n + 1)\n                    if coeff > 0:\n                        tail = Add(*[Pow(\n                            z - i, e) for i in range(1, int(coeff) + 1)])\n                    else:\n                        tail = -Add(*[Pow(\n                            z + i, e) for i in range(0, int(-coeff))])\n                    return polygamma(n, z - coeff) + (-1)**n*factorial(n)*tail\n\n            elif z.is_Mul:\n                coeff, z = z.as_two_terms()\n                if coeff.is_Integer and coeff.is_positive:\n                    tail = [ polygamma(n, z + Rational(\n                        i, coeff)) for i in range(0, int(coeff)) ]\n                    if n == 0:\n                        return Add(*tail)/coeff + log(coeff)\n                    else:\n                        return Add(*tail)/coeff**(n + 1)\n                z *= coeff\n\n        if n == 0 and z.is_Rational:\n            p, q = z.as_numer_denom()\n\n            # Reference:\n            #   Values of the polygamma functions at rational arguments, J. Choi, 2007\n            part_1 = -S.EulerGamma - pi * cot(p * pi / q) / 2 - log(q) + Add(\n                *[cos(2 * k * pi * p / q) * log(2 * sin(k * pi / q)) for k in range(1, q)])\n\n            if z > 0:\n                n = floor(z)\n                z0 = z - n\n                return part_1 + Add(*[1 / (z0 + k) for k in range(n)])\n            elif z < 0:\n                n = floor(1 - z)\n                z0 = z + n\n                return part_1 - Add(*[1 / (z0 - 1 - k) for k in range(n)])\n\n        return polygamma(n, z)\n\n    def _eval_rewrite_as_zeta(self, n, z, **kwargs):\n        if n >= S.One:\n            return (-1)**(n + 1)*factorial(n)*zeta(n + 1, z)\n        else:\n            return self\n\n    def _eval_rewrite_as_harmonic(self, n, z, **kwargs):\n        if n.is_integer:\n            if n == S.Zero:\n                return harmonic(z - 1) - S.EulerGamma\n            else:\n                return S.NegativeOne**(n+1) * factorial(n) * (zeta(n+1) - harmonic(z-1, n+1))\n\n    def _eval_as_leading_term(self, x):\n        from sympy import Order\n        n, z = [a.as_leading_term(x) for a in self.args]\n        o = Order(z, x)\n        if n == 0 and o.contains(1/x):\n            return o.getn() * log(x)\n        else:\n            return self.func(n, z)"
        },
        {
          "file": "sympy/functions/special/gamma_functions.py",
          "type": "function",
          "name": "fdiff",
          "class_name": "multigamma",
          "code": "def fdiff(self, argindex=2):\n        from sympy import Sum\n        if argindex == 2:\n            x, p = self.args\n            k = Dummy(\"k\")\n            return self.func(x, p)*Sum(polygamma(0, x + (1 - k)/2), (k, 1, p))\n        else:\n            raise ArgumentIndexError(self, argindex)"
        },
        {
          "file": "sympy/functions/special/gamma_functions.py",
          "type": "function",
          "name": "_eval_expand_func",
          "class_name": "loggamma",
          "code": "def _eval_expand_func(self, **hints):\n        from sympy import Sum\n        z = self.args[0]\n\n        if z.is_Rational:\n            p, q = z.as_numer_denom()\n            # General rational arguments (u + p/q)\n            # Split z as n + p/q with p < q\n            n = p // q\n            p = p - n*q\n            if p.is_positive and q.is_positive and p < q:\n                k = Dummy(\"k\")\n                if n.is_positive:\n                    return loggamma(p / q) - n*log(q) + Sum(log((k - 1)*q + p), (k, 1, n))\n                elif n.is_negative:\n                    return loggamma(p / q) - n*log(q) + S.Pi*S.ImaginaryUnit*n - Sum(log(k*q - p), (k, 1, -n))\n                elif n.is_zero:\n                    return loggamma(p / q)\n\n        return self"
        }
      ]
    },
    {
      "pr_number": 12236,
      "pr_title": "Fixed apart() producing wrong answer",
      "pr_body": "apart() produced a wrong result when given multivariate polynomial with fractional coefficients in a result. Division was done correctly, but the domain wasn't properly converted to a field. Now the default parameter `field=True` is set explicitly before conversion to polynomial.\r\n\r\nPreviously:\r\n`In [1]: apart(x/2, y)`\r\n`Out[1]: 0`\r\n\r\nNow:\r\n`In [1]: apart(x/2, y)`\r\n`Out[1]:`\r\nx\r\n\u2500\r\n2\r\n\r\nThis fixes #12177, #9123.",
      "issue_id": 12177,
      "issue_title": "Wrong result with apart",
      "issue_body": "```\r\nPython 3.6.0 |Continuum Analytics, Inc.| (default, Dec 23 2016, 12:22:00) \r\nType \"copyright\", \"credits\" or \"license\" for more information.\r\n\r\nIPython 5.1.0 -- An enhanced Interactive Python.\r\n?         -> Introduction and overview of IPython's features.\r\n%quickref -> Quick reference.\r\nhelp      -> Python's own help system.\r\nobject?   -> Details about 'object', use 'object??' for extra details.\r\n\r\nIn [1]: from sympy import symbols\r\n\r\nIn [2]: a = symbols('a', real=True)\r\n\r\nIn [3]: t = symbols('t', real=True, negative=False)\r\n\r\nIn [4]: bug = a * (-t + (-t + 1) * (2 * t - 1)) / (2 * t - 1)\r\n\r\nIn [5]: bug.subs(a, 1)\r\nOut[5]: (-t + (-t + 1)*(2*t - 1))/(2*t - 1)\r\n\r\nIn [6]: bug.subs(a, 1).apart()\r\nOut[6]: -t + 1/2 - 1/(2*(2*t - 1))\r\n\r\nIn [7]: bug.subs(a, 1).apart(t)\r\nOut[7]: -t + 1/2 - 1/(2*(2*t - 1))\r\n\r\nIn [8]: bug.apart(t)\r\nOut[8]: -a*t\r\n\r\nIn [9]: import sympy; sympy.__version__\r\nOut[9]: '1.0'\r\n```",
      "issue_closed_at": "2017-03-06T12:58:04Z",
      "base_commit": "d60497958f6dea7f5e25bc41e9107a6a63694d01",
      "changes": [
        {
          "file": "sympy/polys/domains/polynomialring.py",
          "type": "function",
          "name": "from_PolynomialRing",
          "class_name": "PolynomialRing",
          "code": "def from_PolynomialRing(K1, a, K0):\n        \"\"\"Convert a polynomial to ``dtype``. \"\"\"\n        try:\n            return a.set_ring(K1.ring)\n        except (CoercionFailed, GeneratorsError):\n            return None"
        }
      ]
    },
    {
      "pr_number": 10029,
      "pr_title": "oo**e for non-real complex `e` handling",
      "pr_body": "fixes #10020\n",
      "issue_id": 10020,
      "issue_title": "oo**I raises RunTimeError",
      "issue_body": "```\ngxyd@swap:~/Public/sympy$ python3.4\nPython 3.4.3 (default, Jul 28 2015, 18:20:59) \n[GCC 4.8.4] on linux\nType \"help\", \"copyright\", \"credits\" or \"license\" for more information.\n>>> from sympy import *\n>>> oo**I\nTraceback (most recent call last):\n  File \"<stdin>\", line 1, in <module>\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\nRuntimeError: maximum recursion depth exceeded while calling a Python object\n```\n\nSome part of traceback has been removed to keep it short\n",
      "issue_closed_at": "2015-12-08T15:49:18Z",
      "base_commit": "41fc8f5a4dabd350f2f23a4aef53db728ca8ee0d",
      "changes": [
        {
          "file": "sympy/core/numbers.py",
          "type": "function",
          "name": "_eval_power",
          "class_name": "ImaginaryUnit",
          "code": "def _eval_power(self, expt):\n        \"\"\"\n        b is I = sqrt(-1)\n        e is symbolic object but not equal to 0, 1\n\n        I**r -> (-1)**(r/2) -> exp(r/2*Pi*I) -> sin(Pi*r/2) + cos(Pi*r/2)*I, r is decimal\n        I**0 mod 4 -> 1\n        I**1 mod 4 -> I\n        I**2 mod 4 -> -1\n        I**3 mod 4 -> -I\n        \"\"\"\n\n        if isinstance(expt, Number):\n            if isinstance(expt, Integer):\n                expt = expt.p % 4\n                if expt == 0:\n                    return S.One\n                if expt == 1:\n                    return S.ImaginaryUnit\n                if expt == 2:\n                    return -S.One\n                return -S.ImaginaryUnit\n            return (S.NegativeOne)**(expt*S.Half)\n        return"
        },
        {
          "file": "sympy/core/numbers.py",
          "type": "function",
          "name": "_eval_power",
          "class_name": "ImaginaryUnit",
          "code": "def _eval_power(self, expt):\n        \"\"\"\n        b is I = sqrt(-1)\n        e is symbolic object but not equal to 0, 1\n\n        I**r -> (-1)**(r/2) -> exp(r/2*Pi*I) -> sin(Pi*r/2) + cos(Pi*r/2)*I, r is decimal\n        I**0 mod 4 -> 1\n        I**1 mod 4 -> I\n        I**2 mod 4 -> -1\n        I**3 mod 4 -> -I\n        \"\"\"\n\n        if isinstance(expt, Number):\n            if isinstance(expt, Integer):\n                expt = expt.p % 4\n                if expt == 0:\n                    return S.One\n                if expt == 1:\n                    return S.ImaginaryUnit\n                if expt == 2:\n                    return -S.One\n                return -S.ImaginaryUnit\n            return (S.NegativeOne)**(expt*S.Half)\n        return"
        },
        {
          "file": "sympy/core/numbers.py",
          "type": "function",
          "name": "_eval_power",
          "class_name": "ImaginaryUnit",
          "code": "def _eval_power(self, expt):\n        \"\"\"\n        b is I = sqrt(-1)\n        e is symbolic object but not equal to 0, 1\n\n        I**r -> (-1)**(r/2) -> exp(r/2*Pi*I) -> sin(Pi*r/2) + cos(Pi*r/2)*I, r is decimal\n        I**0 mod 4 -> 1\n        I**1 mod 4 -> I\n        I**2 mod 4 -> -1\n        I**3 mod 4 -> -I\n        \"\"\"\n\n        if isinstance(expt, Number):\n            if isinstance(expt, Integer):\n                expt = expt.p % 4\n                if expt == 0:\n                    return S.One\n                if expt == 1:\n                    return S.ImaginaryUnit\n                if expt == 2:\n                    return -S.One\n                return -S.ImaginaryUnit\n            return (S.NegativeOne)**(expt*S.Half)\n        return"
        },
        {
          "file": "sympy/core/power.py",
          "type": "class",
          "name": "Pow",
          "code": "class Pow(Expr):\n    \"\"\"\n    Defines the expression x**y as \"x raised to a power y\"\n\n    Singleton definitions involving (0, 1, -1, oo, -oo):\n\n    +--------------+---------+-----------------------------------------------+\n    | expr         | value   | reason                                        |\n    +==============+=========+===============================================+\n    | z**0         | 1       | Although arguments over 0**0 exist, see [2].  |\n    +--------------+---------+-----------------------------------------------+\n    | z**1         | z       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-oo)**(-1)  | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-1)**-1     | -1      |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | S.Zero**-1   | zoo     | This is not strictly true, as 0**-1 may be    |\n    |              |         | undefined, but is convenient in some contexts |\n    |              |         | where the base is assumed to be positive.     |\n    +--------------+---------+-----------------------------------------------+\n    | 1**-1        | 1       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**-1       | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | 0**oo        | 0       | Because for all complex numbers z near        |\n    |              |         | 0, z**oo -> 0.                                |\n    +--------------+---------+-----------------------------------------------+\n    | 0**-oo       | zoo     | This is not strictly true, as 0**oo may be    |\n    |              |         | oscillating between positive and negative     |\n    |              |         | values or rotating in the complex plane.      |\n    |              |         | It is convenient, however, when the base      |\n    |              |         | is positive.                                  |\n    +--------------+---------+-----------------------------------------------+\n    | 1**oo        | nan     | Because there are various cases where         |\n    | 1**-oo       |         | lim(x(t),t)=1, lim(y(t),t)=oo (or -oo),       |\n    | 1**zoo       |         | but lim( x(t)**y(t), t) != 1.  See [3].       |\n    +--------------+---------+-----------------------------------------------+\n    | (-1)**oo     | nan     | Because of oscillations in the limit.         |\n    | (-1)**(-oo)  |         |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**oo       | oo      |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**-oo      | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-oo)**oo    | nan     |                                               |\n    | (-oo)**-oo   |         |                                               |\n    +--------------+---------+-----------------------------------------------+\n\n    Because symbolic computations are more flexible that floating point\n    calculations and we prefer to never return an incorrect answer,\n    we choose not to conform to all IEEE 754 conventions.  This helps\n    us avoid extra test-case code in the calculation of limits.\n\n    See Also\n    ========\n\n    sympy.core.numbers.Infinity\n    sympy.core.numbers.NegativeInfinity\n    sympy.core.numbers.NaN\n\n    References\n    ==========\n\n    .. [1] http://en.wikipedia.org/wiki/Exponentiation\n    .. [2] http://en.wikipedia.org/wiki/Exponentiation#Zero_to_the_power_of_zero\n    .. [3] http://en.wikipedia.org/wiki/Indeterminate_forms\n\n    \"\"\"\n    is_Pow = True\n\n    __slots__ = ['is_commutative']\n\n    @cacheit\n    def __new__(cls, b, e, evaluate=None):\n        if evaluate is None:\n            evaluate = global_evaluate[0]\n        from sympy.functions.elementary.exponential import exp_polar\n\n        b = _sympify(b)\n        e = _sympify(e)\n        if evaluate:\n            if e is S.Zero:\n                return S.One\n            elif e is S.One:\n                return b\n            # Only perform autosimplification if exponent or base is a Symbol or number\n            elif (b.is_Symbol or b.is_number) and (e.is_Symbol or e.is_number) and\\\n                e.is_integer and _coeff_isneg(b):\n                if e.is_even:\n                    b = -b\n                elif e.is_odd:\n                    return -Pow(-b, e)\n            if S.NaN in (b, e):  # XXX S.NaN**x -> S.NaN under assumption that x != 0\n                return S.NaN\n            elif b is S.One:\n                if abs(e).is_infinite:\n                    return S.NaN\n                return S.One\n            else:\n                # recognize base as E\n                if not e.is_Atom and b is not S.Exp1 and b.func is not exp_polar:\n                    from sympy import numer, denom, log, sign, im, factor_terms\n                    c, ex = factor_terms(e, sign=False).as_coeff_Mul()\n                    den = denom(ex)\n                    if den.func is log and den.args[0] == b:\n                        return S.Exp1**(c*numer(ex))\n                    elif den.is_Add:\n                        s = sign(im(b))\n                        if s.is_Number and s and den == \\\n                                log(-factor_terms(b, sign=False)) + s*S.ImaginaryUnit*S.Pi:\n                            return S.Exp1**(c*numer(ex))\n\n                obj = b._eval_power(e)\n                if obj is not None:\n                    return obj\n        obj = Expr.__new__(cls, b, e)\n        obj.is_commutative = (b.is_commutative and e.is_commutative)\n        return obj\n\n    @property\n    def base(self):\n        return self._args[0]\n\n    @property\n    def exp(self):\n        return self._args[1]\n\n    @classmethod\n    def class_key(cls):\n        return 3, 2, cls.__name__\n\n    def _eval_refine(self):\n        b, e = self.as_base_exp()\n        if e.is_integer and _coeff_isneg(b):\n            if e.is_even:\n                return Pow(-b, e)\n            elif e.is_odd:\n                return -Pow(-b, e)\n\n    def _eval_power(self, other):\n        from sympy import Abs, arg, exp, floor, im, log, re, sign, refine\n        b, e = self.as_base_exp()\n        if b is S.NaN:\n            return (b**e)**other  # let __new__ handle it\n\n        s = None\n        if other.is_integer:\n            s = 1\n        elif b.is_polar:  # e.g. exp_polar, besselj, var('p', polar=True)...\n            s = 1\n        elif e.is_real is not None:\n            # helper functions ===========================\n            def _half(e):\n                \"\"\"Return True if the exponent has a literal 2 as the\n                denominator, else None.\"\"\"\n                if getattr(e, 'q', None) == 2:\n                    return True\n                n, d = e.as_numer_denom()\n                if n.is_integer and d == 2:\n                    return True\n            def _n2(e):\n                \"\"\"Return ``e`` evaluated to a Number with 2 significant\n                digits, else None.\"\"\"\n                try:\n                    rv = e.evalf(2, strict=True)\n                    if rv.is_Number:\n                        return rv\n                except PrecisionExhausted:\n                    pass\n            # ===================================================\n            if e.is_real:\n                # we need _half(other) with constant floor or\n                # floor(S.Half - e*arg(b)/2/pi) == 0\n\n                # handle -1 as special case\n                if (e == -1) == True:\n                    # floor arg. is 1/2 + arg(b)/2/pi\n                    if _half(other):\n                        if b.is_negative is True:\n                            return S.NegativeOne**other*Pow(-b, e*other)\n                        if b.is_real is False:\n                            return Pow(b.conjugate()/Abs(b)**2, other)\n                elif e.is_even:\n                    if b.is_real:\n                        b = refine(abs(b))\n                    if b.is_imaginary:\n                        b = refine(abs(im(b)))*S.ImaginaryUnit\n\n                if (abs(e) < 1) == True or (e == 1) == True:\n                    s = 1  # floor = 0\n                elif b.is_nonnegative:\n                    s = 1  # floor = 0\n                elif re(b).is_nonnegative and (abs(e) < 2) == True:\n                    s = 1  # floor = 0\n                elif fuzzy_not(im(b).is_zero) and (abs(e) == 2) == True:\n                    s = 1  # floor = 0\n                elif _half(other):\n                    s = exp(2*S.Pi*S.ImaginaryUnit*other*floor(\n                        S.Half - e*arg(b)/(2*S.Pi)))\n                    if s.is_real and _n2(sign(s) - s) == 0:\n                        s = sign(s)\n                    else:\n                        s = None\n            else:\n                # e.is_real is False requires:\n                #     _half(other) with constant floor or\n                #     floor(S.Half - im(e*log(b))/2/pi) == 0\n                try:\n                    s = exp(2*S.ImaginaryUnit*S.Pi*other*\n                        floor(S.Half - im(e*log(b))/2/S.Pi))\n                    # be careful to test that s is -1 or 1 b/c sign(I) == I:\n                    # so check that s is real\n                    if s.is_real and _n2(sign(s) - s) == 0:\n                        s = sign(s)\n                    else:\n                        s = None\n                except PrecisionExhausted:\n                    s = None\n\n        if s is not None:\n            return s*Pow(b, e*other)\n\n    def _eval_is_even(self):\n        if self.exp.is_integer and self.exp.is_positive:\n            return self.base.is_even\n\n    def _eval_is_positive(self):\n        from sympy import log\n        if self.base == self.exp:\n            if self.base.is_nonnegative:\n                return True\n        elif self.base.is_positive:\n            if self.exp.is_real:\n                return True\n        elif self.base.is_negative:\n            if self.exp.is_even:\n                return True\n            if self.exp.is_odd:\n                return False\n        elif self.base.is_nonpositive:\n            if self.exp.is_odd:\n                return False\n        elif self.base.is_imaginary:\n            if self.exp.is_integer:\n                m = self.exp % 4\n                if m.is_zero:\n                    return True\n                if m.is_integer and m.is_zero is False:\n                    return False\n            if self.exp.is_imaginary:\n                return log(self.base).is_imaginary\n\n    def _eval_is_negative(self):\n        if self.base.is_negative:\n            if self.exp.is_odd:\n                return True\n            if self.exp.is_even:\n                return False\n        elif self.base.is_positive:\n            if self.exp.is_real:\n                return False\n        elif self.base.is_nonnegative:\n            if self.exp.is_nonnegative:\n                return False\n        elif self.base.is_nonpositive:\n            if self.exp.is_even:\n                return False\n        elif self.base.is_real:\n            if self.exp.is_even:\n                return False\n\n    def _eval_is_zero(self):\n        if self.base.is_zero:\n            if self.exp.is_positive:\n                return True\n            elif self.exp.is_nonpositive:\n                return False\n        elif self.base.is_zero is False:\n            if self.exp.is_finite:\n                return False\n            elif self.exp.is_infinite:\n                if (1 - abs(self.base)).is_positive:\n                    return self.exp.is_positive\n                elif (1 - abs(self.base)).is_negative:\n                    return self.exp.is_negative\n        else:\n            # when self.base.is_zero is None\n            return None\n\n    def _eval_is_integer(self):\n        b, e = self.args\n        if b.is_rational:\n            if b.is_integer is False and e.is_positive:\n                return False  # rat**nonneg\n        if b.is_integer and e.is_integer:\n            if b is S.NegativeOne:\n                return True\n            if e.is_nonnegative or e.is_positive:\n                return True\n        if b.is_integer and e.is_negative and (e.is_finite or e.is_integer):\n            if fuzzy_not((b - 1).is_zero) and fuzzy_not((b + 1).is_zero):\n                return False\n        if b.is_Number and e.is_Number:\n            check = self.func(*self.args)\n            return check.is_Integer\n\n    def _eval_is_real(self):\n        from sympy import arg, exp, log, Mul\n        real_b = self.base.is_real\n        if real_b is None:\n            if self.base.func == exp and self.base.args[0].is_imaginary:\n                return self.exp.is_imaginary\n            return\n        real_e = self.exp.is_real\n        if real_e is None:\n            return\n        if real_b and real_e:\n            if self.base.is_positive:\n                return True\n            elif self.base.is_nonnegative:\n                if self.exp.is_nonnegative:\n                    return True\n            else:\n                if self.exp.is_integer:\n                    return True\n                elif self.base.is_negative:\n                    if self.exp.is_Rational:\n                        return False\n        if real_e and self.exp.is_negative:\n            return Pow(self.base, -self.exp).is_real\n        im_b = self.base.is_imaginary\n        im_e = self.exp.is_imaginary\n        if im_b:\n            if self.exp.is_integer:\n                if self.exp.is_even:\n                    return True\n                elif self.exp.is_odd:\n                    return False\n            elif im_e and log(self.base).is_imaginary:\n                return True\n            elif self.exp.is_Add:\n                c, a = self.exp.as_coeff_Add()\n                if c and c.is_Integer:\n                    return Mul(\n                        self.base**c, self.base**a, evaluate=False).is_real\n            elif self.base in (-S.ImaginaryUnit, S.ImaginaryUnit):\n                if (self.exp/2).is_integer is False:\n                    return False\n        if real_b and im_e:\n            if self.base is S.NegativeOne:\n                return True\n            c = self.exp.coeff(S.ImaginaryUnit)\n            if c:\n                ok = (c*log(self.base)/S.Pi).is_Integer\n                if ok is not None:\n                    return ok\n\n        if real_b is False:  # we already know it's not imag\n            i = arg(self.base)*self.exp/S.Pi\n            return i.is_integer\n\n    def _eval_is_complex(self):\n        if all(a.is_complex for a in self.args):\n            return True\n\n    def _eval_is_imaginary(self):\n        from sympy import arg, log\n        if self.base.is_imaginary:\n            if self.exp.is_integer:\n                odd = self.exp.is_odd\n                if odd is not None:\n                    return odd\n                return\n\n        if self.exp.is_imaginary:\n            imlog = log(self.base).is_imaginary\n            if imlog is not None:\n                return False  # I**i -> real; (2*I)**i -> complex ==> not imaginary\n\n        if self.base.is_real and self.exp.is_real:\n            if self.base.is_positive:\n                return False\n            else:\n                rat = self.exp.is_rational\n                if not rat:\n                    return rat\n                if self.exp.is_integer:\n                    return False\n                else:\n                    half = (2*self.exp).is_integer\n                    if half:\n                        return self.base.is_negative\n                    return half\n\n        if self.base.is_real is False:  # we already know it's not imag\n            i = arg(self.base)*self.exp/S.Pi\n            return (2*i).is_odd\n\n    def _eval_is_odd(self):\n        if self.exp.is_integer:\n            if self.exp.is_positive:\n                return self.base.is_odd\n            elif self.exp.is_nonnegative and self.base.is_odd:\n                return True\n            elif self.base is S.NegativeOne:\n                return True\n\n    def _eval_is_finite(self):\n        if self.exp.is_negative:\n            if self.base.is_zero:\n                return False\n            if self.base.is_infinite:\n                return True\n        c1 = self.base.is_finite\n        if c1 is None:\n            return\n        c2 = self.exp.is_finite\n        if c2 is None:\n            return\n        if c1 and c2:\n            if self.exp.is_nonnegative or fuzzy_not(self.base.is_zero):\n                return True\n\n    def _eval_is_prime(self):\n        if self.exp == S.One:\n            return self.base.is_prime\n        if self.is_number:\n            return self.doit().is_prime\n\n        if self.is_integer and self.is_positive:\n            \"\"\"\n            a Power will be non-prime only if both base and exponent\n            are greater than 1\n            \"\"\"\n            if (self.base-1).is_positive or (self.exp-1).is_positive:\n                return False\n\n    def _eval_is_polar(self):\n        return self.base.is_polar\n\n    def _eval_subs(self, old, new):\n        from sympy import exp, log, Symbol\n        def _check(ct1, ct2, old):\n            \"\"\"Return bool, pow where, if bool is True, then the exponent of\n            Pow `old` will combine with `pow` so the substitution is valid,\n            otherwise bool will be False,\n\n            cti are the coefficient and terms of an exponent of self or old\n            In this _eval_subs routine a change like (b**(2*x)).subs(b**x, y)\n            will give y**2 since (b**x)**2 == b**(2*x); if that equality does\n            not hold then the substitution should not occur so `bool` will be\n            False.\n            \"\"\"\n            coeff1, terms1 = ct1\n            coeff2, terms2 = ct2\n            if terms1 == terms2:\n                pow = coeff1/coeff2\n                try:\n                    pow = as_int(pow)\n                    combines = True\n                except ValueError:\n                    combines = Pow._eval_power(\n                        Pow(*old.as_base_exp(), evaluate=False),\n                        pow) is not None\n                return combines, pow\n            return False, None\n\n        if old == self.base:\n            return new**self.exp._subs(old, new)\n\n        if old.func is self.func and self.base == old.base:\n            if self.exp.is_Add is False:\n                ct1 = self.exp.as_independent(Symbol, as_Add=False)\n                ct2 = old.exp.as_independent(Symbol, as_Add=False)\n                ok, pow = _check(ct1, ct2, old)\n                if ok:\n                    # issue 5180: (x**(6*y)).subs(x**(3*y),z)->z**2\n                    return self.func(new, pow)\n            else:  # b**(6*x+a).subs(b**(3*x), y) -> y**2 * b**a\n                # exp(exp(x) + exp(x**2)).subs(exp(exp(x)), w) -> w * exp(exp(x**2))\n                oarg = old.exp\n                new_l = []\n                o_al = []\n                ct2 = oarg.as_coeff_mul()\n                for a in self.exp.args:\n                    newa = a._subs(old, new)\n                    ct1 = newa.as_coeff_mul()\n                    ok, pow = _check(ct1, ct2, old)\n                    if ok:\n                        new_l.append(new**pow)\n                        continue\n                    o_al.append(newa)\n                if new_l:\n                    new_l.append(Pow(self.base, Add(*o_al), evaluate=False))\n                    return Mul(*new_l)\n\n        if old.func is exp and self.exp.is_real and self.base.is_positive:\n            ct1 = old.args[0].as_independent(Symbol, as_Add=False)\n            ct2 = (self.exp*log(self.base)).as_independent(\n                Symbol, as_Add=False)\n            ok, pow = _check(ct1, ct2, old)\n            if ok:\n                return self.func(new, pow)  # (2**x).subs(exp(x*log(2)), z) -> z\n\n    def as_base_exp(self):\n        \"\"\"Return base and exp of self.\n\n        If base is 1/Integer, then return Integer, -exp. If this extra\n        processing is not needed, the base and exp properties will\n        give the raw arguments\n\n        Examples\n        ========\n\n        >>> from sympy import Pow, S\n        >>> p = Pow(S.Half, 2, evaluate=False)\n        >>> p.as_base_exp()\n        (2, -2)\n        >>> p.args\n        (1/2, 2)\n\n        \"\"\"\n\n        b, e = self.args\n        if b.is_Rational and b.p == 1 and b.q != 1:\n            return Integer(b.q), -e\n        return b, e\n\n    def _eval_adjoint(self):\n        from sympy.functions.elementary.complexes import adjoint\n        i, p = self.exp.is_integer, self.base.is_positive\n        if i:\n            return adjoint(self.base)**self.exp\n        if p:\n            return self.base**adjoint(self.exp)\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return adjoint(expanded)\n\n    def _eval_conjugate(self):\n        from sympy.functions.elementary.complexes import conjugate as c\n        i, p = self.exp.is_integer, self.base.is_positive\n        if i:\n            return c(self.base)**self.exp\n        if p:\n            return self.base**c(self.exp)\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return c(expanded)\n\n    def _eval_transpose(self):\n        from sympy.functions.elementary.complexes import transpose\n        i, p = self.exp.is_integer, self.base.is_complex\n        if p:\n            return self.base**self.exp\n        if i:\n            return transpose(self.base)**self.exp\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return transpose(expanded)\n\n    def _eval_expand_power_exp(self, **hints):\n        \"\"\"a**(n+m) -> a**n*a**m\"\"\"\n        b = self.base\n        e = self.exp\n        if e.is_Add and e.is_commutative:\n            expr = []\n            for x in e.args:\n                expr.append(self.func(self.base, x))\n            return Mul(*expr)\n        return self.func(b, e)\n\n    def _eval_expand_power_base(self, **hints):\n        \"\"\"(a*b)**n -> a**n * b**n\"\"\"\n        force = hints.get('force', False)\n\n        b = self.base\n        e = self.exp\n        if not b.is_Mul:\n            return self\n\n        cargs, nc = b.args_cnc(split_1=False)\n\n        # expand each term - this is top-level-only\n        # expansion but we have to watch out for things\n        # that don't have an _eval_expand method\n        if nc:\n            nc = [i._eval_expand_power_base(**hints)\n                if hasattr(i, '_eval_expand_power_base') else i\n                for i in nc]\n\n            if e.is_Integer:\n                if e.is_positive:\n                    rv = Mul(*nc*e)\n                else:\n                    rv = 1/Mul(*nc*-e)\n                if cargs:\n                    rv *= Mul(*cargs)**e\n                return rv\n\n            if not cargs:\n                return self.func(Mul(*nc), e, evaluate=False)\n\n            nc = [Mul(*nc)]\n\n        # sift the commutative bases\n        def pred(x):\n            if x is S.ImaginaryUnit:\n                return S.ImaginaryUnit\n            polar = x.is_polar\n            if polar:\n                return True\n            if polar is None:\n                return fuzzy_bool(x.is_nonnegative)\n        sifted = sift(cargs, pred)\n        nonneg = sifted[True]\n        other = sifted[None]\n        neg = sifted[False]\n        imag = sifted[S.ImaginaryUnit]\n        if imag:\n            I = S.ImaginaryUnit\n            i = len(imag) % 4\n            if i == 0:\n                pass\n            elif i == 1:\n                other.append(I)\n            elif i == 2:\n                if neg:\n                    nonn = -neg.pop()\n                    if nonn is not S.One:\n                        nonneg.append(nonn)\n                else:\n                    neg.append(S.NegativeOne)\n            else:\n                if neg:\n                    nonn = -neg.pop()\n                    if nonn is not S.One:\n                        nonneg.append(nonn)\n                else:\n                    neg.append(S.NegativeOne)\n                other.append(I)\n            del imag\n\n        # bring out the bases that can be separated from the base\n\n        if force or e.is_integer:\n            # treat all commutatives the same and put nc in other\n            cargs = nonneg + neg + other\n            other = nc\n        else:\n            # this is just like what is happening automatically, except\n            # that now we are doing it for an arbitrary exponent for which\n            # no automatic expansion is done\n\n            assert not e.is_Integer\n\n            # handle negatives by making them all positive and putting\n            # the residual -1 in other\n            if len(neg) > 1:\n                o = S.One\n                if not other and neg[0].is_Number:\n                    o *= neg.pop(0)\n                if len(neg) % 2:\n                    o = -o\n                for n in neg:\n                    nonneg.append(-n)\n                if o is not S.One:\n                    other.append(o)\n            elif neg and other:\n                if neg[0].is_Number and neg[0] is not S.NegativeOne:\n                    other.append(S.NegativeOne)\n                    nonneg.append(-neg[0])\n                else:\n                    other.extend(neg)\n            else:\n                other.extend(neg)\n            del neg\n\n            cargs = nonneg\n            other += nc\n\n        rv = S.One\n        if cargs:\n            rv *= Mul(*[self.func(b, e, evaluate=False) for b in cargs])\n        if other:\n            rv *= self.func(Mul(*other), e, evaluate=False)\n        return rv\n\n    def _eval_expand_multinomial(self, **hints):\n        \"\"\"(a+b+..) ** n -> a**n + n*a**(n-1)*b + .., n is nonzero integer\"\"\"\n\n        base, exp = self.args\n        result = self\n\n        if exp.is_Rational and exp.p > 0 and base.is_Add:\n            if not exp.is_Integer:\n                n = Integer(exp.p // exp.q)\n\n                if not n:\n                    return result\n                else:\n                    radical, result = self.func(base, exp - n), []\n\n                    expanded_base_n = self.func(base, n)\n                    if expanded_base_n.is_Pow:\n                        expanded_base_n = \\\n                            expanded_base_n._eval_expand_multinomial()\n                    for term in Add.make_args(expanded_base_n):\n                        result.append(term*radical)\n\n                    return Add(*result)\n\n            n = int(exp)\n\n            if base.is_commutative:\n                order_terms, other_terms = [], []\n\n                for b in base.args:\n                    if b.is_Order:\n                        order_terms.append(b)\n                    else:\n                        other_terms.append(b)\n\n                if order_terms:\n                    # (f(x) + O(x^n))^m -> f(x)^m + m*f(x)^{m-1} *O(x^n)\n                    f = Add(*other_terms)\n                    o = Add(*order_terms)\n\n                    if n == 2:\n                        return expand_multinomial(f**n, deep=False) + n*f*o\n                    else:\n                        g = expand_multinomial(f**(n - 1), deep=False)\n                        return expand_mul(f*g, deep=False) + n*g*o\n\n                if base.is_number:\n                    # Efficiently expand expressions of the form (a + b*I)**n\n                    # where 'a' and 'b' are real numbers and 'n' is integer.\n                    a, b = base.as_real_imag()\n\n                    if a.is_Rational and b.is_Rational:\n                        if not a.is_Integer:\n                            if not b.is_Integer:\n                                k = self.func(a.q * b.q, n)\n                                a, b = a.p*b.q, a.q*b.p\n                            else:\n                                k = self.func(a.q, n)\n                                a, b = a.p, a.q*b\n                        elif not b.is_Integer:\n                            k = self.func(b.q, n)\n                            a, b = a*b.q, b.p\n                        else:\n                            k = 1\n\n                        a, b, c, d = int(a), int(b), 1, 0\n\n                        while n:\n                            if n & 1:\n                                c, d = a*c - b*d, b*c + a*d\n                                n -= 1\n                            a, b = a*a - b*b, 2*a*b\n                            n //= 2\n\n                        I = S.ImaginaryUnit\n\n                        if k == 1:\n                            return c + I*d\n                        else:\n                            return Integer(c)/k + I*d/k\n\n                p = other_terms\n                # (x+y)**3 -> x**3 + 3*x**2*y + 3*x*y**2 + y**3\n                # in this particular example:\n                # p = [x,y]; n = 3\n                # so now it's easy to get the correct result -- we get the\n                # coefficients first:\n                from sympy import multinomial_coefficients\n                from sympy.polys.polyutils import basic_from_dict\n                expansion_dict = multinomial_coefficients(len(p), n)\n                # in our example: {(3, 0): 1, (1, 2): 3, (0, 3): 1, (2, 1): 3}\n                # and now construct the expression.\n                return basic_from_dict(expansion_dict, *p)\n            else:\n                if n == 2:\n                    return Add(*[f*g for f in base.args for g in base.args])\n                else:\n                    multi = (base**(n - 1))._eval_expand_multinomial()\n                    if multi.is_Add:\n                        return Add(*[f*g for f in base.args\n                            for g in multi.args])\n                    else:\n                        # XXX can this ever happen if base was an Add?\n                        return Add(*[f*multi for f in base.args])\n        elif (exp.is_Rational and exp.p < 0 and base.is_Add and\n                abs(exp.p) > exp.q):\n            return 1 / self.func(base, -exp)._eval_expand_multinomial()\n        elif exp.is_Add and base.is_Number:\n            #  a + b      a  b\n            # n      --> n  n  , where n, a, b are Numbers\n\n            coeff, tail = S.One, S.Zero\n            for term in exp.args:\n                if term.is_Number:\n                    coeff *= self.func(base, term)\n                else:\n                    tail += term\n\n            return coeff * self.func(base, tail)\n        else:\n            return result\n\n    def as_real_imag(self, deep=True, **hints):\n        from sympy import atan2, cos, im, re, sin\n        from sympy.polys.polytools import poly\n\n        if self.exp.is_Integer:\n            exp = self.exp\n            re, im = self.base.as_real_imag(deep=deep)\n            if not im:\n                return self, S.Zero\n            a, b = symbols('a b', cls=Dummy)\n            if exp >= 0:\n                if re.is_Number and im.is_Number:\n                    # We can be more efficient in this case\n                    expr = expand_multinomial(self.base**exp)\n                    return expr.as_real_imag()\n\n                expr = poly(\n                    (a + b)**exp)  # a = re, b = im; expr = (a + b*I)**exp\n            else:\n                mag = re**2 + im**2\n                re, im = re/mag, -im/mag\n                if re.is_Number and im.is_Number:\n                    # We can be more efficient in this case\n                    expr = expand_multinomial((re + im*S.ImaginaryUnit)**-exp)\n                    return expr.as_real_imag()\n\n                expr = poly((a + b)**-exp)\n\n            # Terms with even b powers will be real\n            r = [i for i in expr.terms() if not i[0][1] % 2]\n            re_part = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n            # Terms with odd b powers will be imaginary\n            r = [i for i in expr.terms() if i[0][1] % 4 == 1]\n            im_part1 = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n            r = [i for i in expr.terms() if i[0][1] % 4 == 3]\n            im_part3 = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n\n            return (re_part.subs({a: re, b: S.ImaginaryUnit*im}),\n            im_part1.subs({a: re, b: im}) + im_part3.subs({a: re, b: -im}))\n\n        elif self.exp.is_Rational:\n            re, im = self.base.as_real_imag(deep=deep)\n\n            if im.is_zero and self.exp is S.Half:\n                if re.is_nonnegative:\n                    return self, S.Zero\n                if re.is_nonpositive:\n                    return S.Zero, (-self.base)**self.exp\n\n            # XXX: This is not totally correct since for x**(p/q) with\n            #      x being imaginary there are actually q roots, but\n            #      only a single one is returned from here.\n            r = self.func(self.func(re, 2) + self.func(im, 2), S.Half)\n            t = atan2(im, re)\n\n            rp, tp = self.func(r, self.exp), t*self.exp\n\n            return (rp*cos(tp), rp*sin(tp))\n        else:\n\n            if deep:\n                hints['complex'] = False\n\n                expanded = self.expand(deep, **hints)\n                if hints.get('ignore') == expanded:\n                    return None\n                else:\n                    return (re(expanded), im(expanded))\n            else:\n                return (re(self), im(self))\n\n    def _eval_derivative(self, s):\n        from sympy import log\n        dbase = self.base.diff(s)\n        dexp = self.exp.diff(s)\n        return self * (dexp * log(self.base) + dbase * self.exp/self.base)\n\n    def _eval_evalf(self, prec):\n        base, exp = self.as_base_exp()\n        base = base._evalf(prec)\n        if not exp.is_Integer:\n            exp = exp._evalf(prec)\n        if exp.is_negative and base.is_number and base.is_real is False:\n            base = base.conjugate() / (base * base.conjugate())._evalf(prec)\n            exp = -exp\n            return self.func(base, exp).expand()\n        return self.func(base, exp)\n\n    def _eval_is_polynomial(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return bool(self.base._eval_is_polynomial(syms) and\n                self.exp.is_Integer and (self.exp >= 0))\n        else:\n            return True\n\n    def _eval_is_rational(self):\n        p = self.func(*self.as_base_exp())  # in case it's unevaluated\n        if not p.is_Pow:\n            return p.is_rational\n        b, e = p.as_base_exp()\n        if e.is_Rational and b.is_Rational:\n            # we didn't check that e is not an Integer\n            # because Rational**Integer autosimplifies\n            return False\n        if e.is_integer:\n            if b.is_rational:\n                if fuzzy_not(b.is_zero) or e.is_nonnegative:\n                    return True\n                if b == e:  # always rational, even for 0**0\n                    return True\n            elif b.is_irrational:\n                return e.is_zero\n\n    def _eval_is_algebraic(self):\n        if self.base.is_zero or (self.base - 1).is_zero:\n            return True\n        elif self.exp.is_rational:\n            return self.base.is_algebraic\n        elif self.base.is_algebraic and self.exp.is_algebraic:\n            if ((fuzzy_not(self.base.is_zero)\n                and fuzzy_not((self.base - 1).is_zero))\n                or self.base.is_integer is False\n                or self.base.is_irrational):\n                return self.exp.is_rational\n\n    def _eval_is_rational_function(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return self.base._eval_is_rational_function(syms) and \\\n                self.exp.is_Integer\n        else:\n            return True\n\n    def _eval_is_algebraic_expr(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return self.base._eval_is_algebraic_expr(syms) and \\\n                self.exp.is_Rational\n        else:\n            return True\n\n    def as_numer_denom(self):\n        if not self.is_commutative:\n            return self, S.One\n        base, exp = self.as_base_exp()\n        n, d = base.as_numer_denom()\n        # this should be the same as ExpBase.as_numer_denom wrt\n        # exponent handling\n        neg_exp = exp.is_negative\n        if not neg_exp and not (-exp).is_negative:\n            neg_exp = _coeff_isneg(exp)\n        int_exp = exp.is_integer\n        # the denominator cannot be separated from the numerator if\n        # its sign is unknown unless the exponent is an integer, e.g.\n        # sqrt(a/b) != sqrt(a)/sqrt(b) when a=1 and b=-1. But if the\n        # denominator is negative the numerator and denominator can\n        # be negated and the denominator (now positive) separated.\n        if not (d.is_real or int_exp):\n            n = base\n            d = S.One\n        dnonpos = d.is_nonpositive\n        if dnonpos:\n            n, d = -n, -d\n        elif dnonpos is None and not int_exp:\n            n = base\n            d = S.One\n        if neg_exp:\n            n, d = d, n\n            exp = -exp\n        return self.func(n, exp), self.func(d, exp)\n\n    def matches(self, expr, repl_dict={}, old=False):\n        expr = _sympify(expr)\n\n        # special case, pattern = 1 and expr.exp can match to 0\n        if expr is S.One:\n            d = repl_dict.copy()\n            d = self.exp.matches(S.Zero, d)\n            if d is not None:\n                return d\n\n        # make sure the expression to be matched is an Expr\n        if not isinstance(expr, Expr):\n            return None\n\n        b, e = expr.as_base_exp()\n\n        # special case number\n        sb, se = self.as_base_exp()\n        if sb.is_Symbol and se.is_Integer and expr:\n            if e.is_rational:\n                return sb.matches(b**(e/se), repl_dict)\n            return sb.matches(expr**(1/se), repl_dict)\n\n        d = repl_dict.copy()\n        d = self.base.matches(b, d)\n        if d is None:\n            return None\n\n        d = self.exp.xreplace(d).matches(e, d)\n        if d is None:\n            return Expr.matches(self, expr, repl_dict)\n        return d\n\n    def _eval_nseries(self, x, n, logx):\n        # NOTE! This function is an important part of the gruntz algorithm\n        #       for computing limits. It has to return a generalized power\n        #       series with coefficients in C(log, log(x)). In more detail:\n        # It has to return an expression\n        #     c_0*x**e_0 + c_1*x**e_1 + ... (finitely many terms)\n        # where e_i are numbers (not necessarily integers) and c_i are\n        # expressions involving only numbers, the log function, and log(x).\n        from sympy import ceiling, collect, exp, log, O, Order, powsimp\n        b, e = self.args\n        if e.is_Integer:\n            if e > 0:\n                # positive integer powers are easy to expand, e.g.:\n                # sin(x)**4 = (x-x**3/3+...)**4 = ...\n                return expand_multinomial(self.func(b._eval_nseries(x, n=n,\n                    logx=logx), e), deep=False)\n            elif e is S.NegativeOne:\n                # this is also easy to expand using the formula:\n                # 1/(1 + x) = 1 - x + x**2 - x**3 ...\n                # so we need to rewrite base to the form \"1+x\"\n\n                nuse = n\n                cf = 1\n\n                try:\n                    ord = b.as_leading_term(x)\n                    cf = Order(ord, x).getn()\n                    if cf and cf.is_Number:\n                        nuse = n + 2*ceiling(cf)\n                    else:\n                        cf = 1\n                except NotImplementedError:\n                    pass\n\n                b_orig, prefactor = b, O(1, x)\n                while prefactor.is_Order:\n                    nuse += 1\n                    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\n                    prefactor = b.as_leading_term(x)\n\n                # express \"rest\" as: rest = 1 + k*x**l + ... + O(x**n)\n                rest = expand_mul((b - prefactor)/prefactor)\n\n                if rest.is_Order:\n                    return 1/prefactor + rest/prefactor + O(x**n, x)\n\n                k, l = rest.leadterm(x)\n                if l.is_Rational and l > 0:\n                    pass\n                elif l.is_number and l > 0:\n                    l = l.evalf()\n                elif l == 0:\n                    k = k.simplify()\n                    if k == 0:\n                        # if prefactor == w**4 + x**2*w**4 + 2*x*w**4, we need to\n                        # factor the w**4 out using collect:\n                        return 1/collect(prefactor, x)\n                    else:\n                        raise NotImplementedError()\n                else:\n                    raise NotImplementedError()\n\n                if cf < 0:\n                    cf = S.One/abs(cf)\n\n                try:\n                    dn = Order(1/prefactor, x).getn()\n                    if dn and dn < 0:\n                        pass\n                    else:\n                        dn = 0\n                except NotImplementedError:\n                    dn = 0\n\n                terms = [1/prefactor]\n                for m in range(1, ceiling((n - dn)/l*cf)):\n                    new_term = terms[-1]*(-rest)\n                    if new_term.is_Pow:\n                        new_term = new_term._eval_expand_multinomial(\n                            deep=False)\n                    else:\n                        new_term = expand_mul(new_term, deep=False)\n                    terms.append(new_term)\n                terms.append(O(x**n, x))\n                return powsimp(Add(*terms), deep=True, combine='exp')\n            else:\n                # negative powers are rewritten to the cases above, for\n                # example:\n                # sin(x)**(-4) = 1/( sin(x)**4) = ...\n                # and expand the denominator:\n                nuse, denominator = n, O(1, x)\n                while denominator.is_Order:\n                    denominator = (b**(-e))._eval_nseries(x, n=nuse, logx=logx)\n                    nuse += 1\n                if 1/denominator == self:\n                    return self\n                # now we have a type 1/f(x), that we know how to expand\n                return (1/denominator)._eval_nseries(x, n=n, logx=logx)\n\n        if e.has(Symbol):\n            return exp(e*log(b))._eval_nseries(x, n=n, logx=logx)\n\n        # see if the base is as simple as possible\n        bx = b\n        while bx.is_Pow and bx.exp.is_Rational:\n            bx = bx.base\n        if bx == x:\n            return self\n\n        # work for b(x)**e where e is not an Integer and does not contain x\n        # and hopefully has no other symbols\n\n        def e2int(e):\n            \"\"\"return the integer value (if possible) of e and a\n            flag indicating whether it is bounded or not.\"\"\"\n            n = e.limit(x, 0)\n            infinite = n.is_infinite\n            if not infinite:\n                # XXX was int or floor intended? int used to behave like floor\n                # so int(-Rational(1, 2)) returned -1 rather than int's 0\n                try:\n                    n = int(n)\n                except TypeError:\n                    #well, the n is something more complicated (like 1+log(2))\n                    try:\n                        n = int(n.evalf()) + 1  # XXX why is 1 being added?\n                    except TypeError:\n                        pass  # hope that base allows this to be resolved\n                n = _sympify(n)\n            return n, infinite\n\n        order = O(x**n, x)\n        ei, infinite = e2int(e)\n        b0 = b.limit(x, 0)\n        if infinite and (b0 is S.One or b0.has(Symbol)):\n            # XXX what order\n            if b0 is S.One:\n                resid = (b - 1)\n                if resid.is_positive:\n                    return S.Infinity\n                elif resid.is_negative:\n                    return S.Zero\n                raise ValueError('cannot determine sign of %s' % resid)\n\n            return b0**ei\n\n        if (b0 is S.Zero or b0.is_infinite):\n            if infinite is not False:\n                return b0**e  # XXX what order\n\n            if not ei.is_number:  # if not, how will we proceed?\n                raise ValueError(\n                    'expecting numerical exponent but got %s' % ei)\n\n            nuse = n - ei\n\n            if e.is_real and e.is_positive:\n                lt = b.as_leading_term(x)\n\n                # Try to correct nuse (= m) guess from:\n                # (lt + rest + O(x**m))**e =\n                # lt**e*(1 + rest/lt + O(x**m)/lt)**e =\n                # lt**e + ... + O(x**m)*lt**(e - 1) = ... + O(x**n)\n                try:\n                    cf = Order(lt, x).getn()\n                    nuse = ceiling(n - cf*(e - 1))\n                except NotImplementedError:\n                    pass\n\n            bs = b._eval_nseries(x, n=nuse, logx=logx)\n            terms = bs.removeO()\n            if terms.is_Add:\n                bs = terms\n                lt = terms.as_leading_term(x)\n\n                # bs -> lt + rest -> lt*(1 + (bs/lt - 1))\n                return ((self.func(lt, e) * self.func((bs/lt).expand(), e).nseries(\n                    x, n=nuse, logx=logx)).expand() + order)\n\n            if bs.is_Add:\n                from sympy import O\n                # So, bs + O() == terms\n                c = Dummy('c')\n                res = []\n                for arg in bs.args:\n                    if arg.is_Order:\n                        arg = c*arg.expr\n                    res.append(arg)\n                bs = Add(*res)\n                rv = (bs**e).series(x).subs(c, O(1, x))\n                rv += order\n                return rv\n\n            rv = bs**e\n            if terms != bs:\n                rv += order\n            return rv\n\n        # either b0 is bounded but neither 1 nor 0 or e is infinite\n        # b -> b0 + (b-b0) -> b0 * (1 + (b/b0-1))\n        o2 = order*(b0**-e)\n        z = (b/b0 - 1)\n        o = O(z, x)\n        if o is S.Zero or o2 is S.Zero:\n            infinite = True\n        else:\n            if o.expr.is_number:\n                e2 = log(o2.expr*x)/log(x)\n            else:\n                e2 = log(o2.expr)/log(o.expr)\n            n, infinite = e2int(e2)\n        if infinite:\n            # requested accuracy gives infinite series,\n            # order is probably non-polynomial e.g. O(exp(-1/x), x).\n            r = 1 + z\n        else:\n            l = []\n            g = None\n            for i in range(n + 2):\n                g = self._taylor_term(i, z, g)\n                g = g.nseries(x, n=n, logx=logx)\n                l.append(g)\n            r = Add(*l)\n        return expand_mul(r*b0**e) + order\n\n    def _eval_as_leading_term(self, x):\n        from sympy import exp, log\n        if not self.exp.has(x):\n            return self.func(self.base.as_leading_term(x), self.exp)\n        return exp(self.exp * log(self.base)).as_leading_term(x)\n\n    @cacheit\n    def _taylor_term(self, n, x, *previous_terms): # of (1+x)**e\n        from sympy import binomial\n        return binomial(self.exp, n) * self.func(x, n)\n\n    def _sage_(self):\n        return self.args[0]._sage_()**self.args[1]._sage_()\n\n    def as_content_primitive(self, radical=False):\n        \"\"\"Return the tuple (R, self/R) where R is the positive Rational\n        extracted from self.\n\n        Examples\n        ========\n\n        >>> from sympy import sqrt\n        >>> sqrt(4 + 4*sqrt(2)).as_content_primitive()\n        (2, sqrt(1 + sqrt(2)))\n        >>> sqrt(3 + 3*sqrt(2)).as_content_primitive()\n        (1, sqrt(3)*sqrt(1 + sqrt(2)))\n\n        >>> from sympy import expand_power_base, powsimp, Mul\n        >>> from sympy.abc import x, y\n\n        >>> ((2*x + 2)**2).as_content_primitive()\n        (4, (x + 1)**2)\n        >>> (4**((1 + y)/2)).as_content_primitive()\n        (2, 4**(y/2))\n        >>> (3**((1 + y)/2)).as_content_primitive()\n        (1, 3**((y + 1)/2))\n        >>> (3**((5 + y)/2)).as_content_primitive()\n        (9, 3**((y + 1)/2))\n        >>> eq = 3**(2 + 2*x)\n        >>> powsimp(eq) == eq\n        True\n        >>> eq.as_content_primitive()\n        (9, 3**(2*x))\n        >>> powsimp(Mul(*_))\n        3**(2*x + 2)\n\n        >>> eq = (2 + 2*x)**y\n        >>> s = expand_power_base(eq); s.is_Mul, s\n        (False, (2*x + 2)**y)\n        >>> eq.as_content_primitive()\n        (1, (2*(x + 1))**y)\n        >>> s = expand_power_base(_[1]); s.is_Mul, s\n        (True, 2**y*(x + 1)**y)\n\n        See docstring of Expr.as_content_primitive for more examples.\n        \"\"\"\n\n        b, e = self.as_base_exp()\n        b = _keep_coeff(*b.as_content_primitive(radical=radical))\n        ce, pe = e.as_content_primitive(radical=radical)\n        if b.is_Rational:\n            #e\n            #= ce*pe\n            #= ce*(h + t)\n            #= ce*h + ce*t\n            #=> self\n            #= b**(ce*h)*b**(ce*t)\n            #= b**(cehp/cehq)*b**(ce*t)\n            #= b**(iceh+r/cehq)*b**(ce*t)\n            #= b**(iceh)*b**(r/cehq)*b**(ce*t)\n            #= b**(iceh)*b**(ce*t + r/cehq)\n            h, t = pe.as_coeff_Add()\n            if h.is_Rational:\n                ceh = ce*h\n                c = self.func(b, ceh)\n                r = S.Zero\n                if not c.is_Rational:\n                    iceh, r = divmod(ceh.p, ceh.q)\n                    c = self.func(b, iceh)\n                return c, self.func(b, _keep_coeff(ce, t + r/ce/ceh.q))\n        e = _keep_coeff(ce, pe)\n        # b**e = (h*t)**e = h**e*t**e = c*m*t**e\n        if e.is_Rational and b.is_Mul:\n            h, t = b.as_content_primitive(radical=radical)  # h is positive\n            c, m = self.func(h, e).as_coeff_Mul()  # so c is positive\n            m, me = m.as_base_exp()\n            if m is S.One or me == e:  # probably always true\n                # return the following, not return c, m*Pow(t, e)\n                # which would change Pow into Mul; we let sympy\n                # decide what to do by using the unevaluated Mul, e.g\n                # should it stay as sqrt(2 + 2*sqrt(5)) or become\n                # sqrt(2)*sqrt(1 + sqrt(5))\n                return c, self.func(_keep_coeff(m, t), e)\n        return S.One, self.func(b, e)\n\n    def is_constant(self, *wrt, **flags):\n        expr = self\n        if flags.get('simplify', True):\n            expr = expr.simplify()\n        b, e = expr.as_base_exp()\n        bz = b.equals(0)\n        if bz:  # recalculate with assumptions in case it's unevaluated\n            new = b**e\n            if new != expr:\n                return new.is_constant()\n        econ = e.is_constant(*wrt)\n        bcon = b.is_constant(*wrt)\n        if bcon:\n            if econ:\n                return True\n            bz = b.equals(0)\n            if bz is False:\n                return False\n        elif bcon is None:\n            return None\n\n        return e.equals(0)\n\n    def _eval_difference_delta(self, n, step):\n        b, e = self.args\n        if e.has(n) and not b.has(n):\n            new_e = e.subs(n, n + step)\n            return (b**(new_e - e) - 1) * self"
        },
        {
          "file": "sympy/core/power.py",
          "type": "class",
          "name": "Pow",
          "code": "class Pow(Expr):\n    \"\"\"\n    Defines the expression x**y as \"x raised to a power y\"\n\n    Singleton definitions involving (0, 1, -1, oo, -oo):\n\n    +--------------+---------+-----------------------------------------------+\n    | expr         | value   | reason                                        |\n    +==============+=========+===============================================+\n    | z**0         | 1       | Although arguments over 0**0 exist, see [2].  |\n    +--------------+---------+-----------------------------------------------+\n    | z**1         | z       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-oo)**(-1)  | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-1)**-1     | -1      |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | S.Zero**-1   | zoo     | This is not strictly true, as 0**-1 may be    |\n    |              |         | undefined, but is convenient in some contexts |\n    |              |         | where the base is assumed to be positive.     |\n    +--------------+---------+-----------------------------------------------+\n    | 1**-1        | 1       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**-1       | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | 0**oo        | 0       | Because for all complex numbers z near        |\n    |              |         | 0, z**oo -> 0.                                |\n    +--------------+---------+-----------------------------------------------+\n    | 0**-oo       | zoo     | This is not strictly true, as 0**oo may be    |\n    |              |         | oscillating between positive and negative     |\n    |              |         | values or rotating in the complex plane.      |\n    |              |         | It is convenient, however, when the base      |\n    |              |         | is positive.                                  |\n    +--------------+---------+-----------------------------------------------+\n    | 1**oo        | nan     | Because there are various cases where         |\n    | 1**-oo       |         | lim(x(t),t)=1, lim(y(t),t)=oo (or -oo),       |\n    | 1**zoo       |         | but lim( x(t)**y(t), t) != 1.  See [3].       |\n    +--------------+---------+-----------------------------------------------+\n    | (-1)**oo     | nan     | Because of oscillations in the limit.         |\n    | (-1)**(-oo)  |         |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**oo       | oo      |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**-oo      | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-oo)**oo    | nan     |                                               |\n    | (-oo)**-oo   |         |                                               |\n    +--------------+---------+-----------------------------------------------+\n\n    Because symbolic computations are more flexible that floating point\n    calculations and we prefer to never return an incorrect answer,\n    we choose not to conform to all IEEE 754 conventions.  This helps\n    us avoid extra test-case code in the calculation of limits.\n\n    See Also\n    ========\n\n    sympy.core.numbers.Infinity\n    sympy.core.numbers.NegativeInfinity\n    sympy.core.numbers.NaN\n\n    References\n    ==========\n\n    .. [1] http://en.wikipedia.org/wiki/Exponentiation\n    .. [2] http://en.wikipedia.org/wiki/Exponentiation#Zero_to_the_power_of_zero\n    .. [3] http://en.wikipedia.org/wiki/Indeterminate_forms\n\n    \"\"\"\n    is_Pow = True\n\n    __slots__ = ['is_commutative']\n\n    @cacheit\n    def __new__(cls, b, e, evaluate=None):\n        if evaluate is None:\n            evaluate = global_evaluate[0]\n        from sympy.functions.elementary.exponential import exp_polar\n\n        b = _sympify(b)\n        e = _sympify(e)\n        if evaluate:\n            if e is S.Zero:\n                return S.One\n            elif e is S.One:\n                return b\n            # Only perform autosimplification if exponent or base is a Symbol or number\n            elif (b.is_Symbol or b.is_number) and (e.is_Symbol or e.is_number) and\\\n                e.is_integer and _coeff_isneg(b):\n                if e.is_even:\n                    b = -b\n                elif e.is_odd:\n                    return -Pow(-b, e)\n            if S.NaN in (b, e):  # XXX S.NaN**x -> S.NaN under assumption that x != 0\n                return S.NaN\n            elif b is S.One:\n                if abs(e).is_infinite:\n                    return S.NaN\n                return S.One\n            else:\n                # recognize base as E\n                if not e.is_Atom and b is not S.Exp1 and b.func is not exp_polar:\n                    from sympy import numer, denom, log, sign, im, factor_terms\n                    c, ex = factor_terms(e, sign=False).as_coeff_Mul()\n                    den = denom(ex)\n                    if den.func is log and den.args[0] == b:\n                        return S.Exp1**(c*numer(ex))\n                    elif den.is_Add:\n                        s = sign(im(b))\n                        if s.is_Number and s and den == \\\n                                log(-factor_terms(b, sign=False)) + s*S.ImaginaryUnit*S.Pi:\n                            return S.Exp1**(c*numer(ex))\n\n                obj = b._eval_power(e)\n                if obj is not None:\n                    return obj\n        obj = Expr.__new__(cls, b, e)\n        obj.is_commutative = (b.is_commutative and e.is_commutative)\n        return obj\n\n    @property\n    def base(self):\n        return self._args[0]\n\n    @property\n    def exp(self):\n        return self._args[1]\n\n    @classmethod\n    def class_key(cls):\n        return 3, 2, cls.__name__\n\n    def _eval_refine(self):\n        b, e = self.as_base_exp()\n        if e.is_integer and _coeff_isneg(b):\n            if e.is_even:\n                return Pow(-b, e)\n            elif e.is_odd:\n                return -Pow(-b, e)\n\n    def _eval_power(self, other):\n        from sympy import Abs, arg, exp, floor, im, log, re, sign, refine\n        b, e = self.as_base_exp()\n        if b is S.NaN:\n            return (b**e)**other  # let __new__ handle it\n\n        s = None\n        if other.is_integer:\n            s = 1\n        elif b.is_polar:  # e.g. exp_polar, besselj, var('p', polar=True)...\n            s = 1\n        elif e.is_real is not None:\n            # helper functions ===========================\n            def _half(e):\n                \"\"\"Return True if the exponent has a literal 2 as the\n                denominator, else None.\"\"\"\n                if getattr(e, 'q', None) == 2:\n                    return True\n                n, d = e.as_numer_denom()\n                if n.is_integer and d == 2:\n                    return True\n            def _n2(e):\n                \"\"\"Return ``e`` evaluated to a Number with 2 significant\n                digits, else None.\"\"\"\n                try:\n                    rv = e.evalf(2, strict=True)\n                    if rv.is_Number:\n                        return rv\n                except PrecisionExhausted:\n                    pass\n            # ===================================================\n            if e.is_real:\n                # we need _half(other) with constant floor or\n                # floor(S.Half - e*arg(b)/2/pi) == 0\n\n                # handle -1 as special case\n                if (e == -1) == True:\n                    # floor arg. is 1/2 + arg(b)/2/pi\n                    if _half(other):\n                        if b.is_negative is True:\n                            return S.NegativeOne**other*Pow(-b, e*other)\n                        if b.is_real is False:\n                            return Pow(b.conjugate()/Abs(b)**2, other)\n                elif e.is_even:\n                    if b.is_real:\n                        b = refine(abs(b))\n                    if b.is_imaginary:\n                        b = refine(abs(im(b)))*S.ImaginaryUnit\n\n                if (abs(e) < 1) == True or (e == 1) == True:\n                    s = 1  # floor = 0\n                elif b.is_nonnegative:\n                    s = 1  # floor = 0\n                elif re(b).is_nonnegative and (abs(e) < 2) == True:\n                    s = 1  # floor = 0\n                elif fuzzy_not(im(b).is_zero) and (abs(e) == 2) == True:\n                    s = 1  # floor = 0\n                elif _half(other):\n                    s = exp(2*S.Pi*S.ImaginaryUnit*other*floor(\n                        S.Half - e*arg(b)/(2*S.Pi)))\n                    if s.is_real and _n2(sign(s) - s) == 0:\n                        s = sign(s)\n                    else:\n                        s = None\n            else:\n                # e.is_real is False requires:\n                #     _half(other) with constant floor or\n                #     floor(S.Half - im(e*log(b))/2/pi) == 0\n                try:\n                    s = exp(2*S.ImaginaryUnit*S.Pi*other*\n                        floor(S.Half - im(e*log(b))/2/S.Pi))\n                    # be careful to test that s is -1 or 1 b/c sign(I) == I:\n                    # so check that s is real\n                    if s.is_real and _n2(sign(s) - s) == 0:\n                        s = sign(s)\n                    else:\n                        s = None\n                except PrecisionExhausted:\n                    s = None\n\n        if s is not None:\n            return s*Pow(b, e*other)\n\n    def _eval_is_even(self):\n        if self.exp.is_integer and self.exp.is_positive:\n            return self.base.is_even\n\n    def _eval_is_positive(self):\n        from sympy import log\n        if self.base == self.exp:\n            if self.base.is_nonnegative:\n                return True\n        elif self.base.is_positive:\n            if self.exp.is_real:\n                return True\n        elif self.base.is_negative:\n            if self.exp.is_even:\n                return True\n            if self.exp.is_odd:\n                return False\n        elif self.base.is_nonpositive:\n            if self.exp.is_odd:\n                return False\n        elif self.base.is_imaginary:\n            if self.exp.is_integer:\n                m = self.exp % 4\n                if m.is_zero:\n                    return True\n                if m.is_integer and m.is_zero is False:\n                    return False\n            if self.exp.is_imaginary:\n                return log(self.base).is_imaginary\n\n    def _eval_is_negative(self):\n        if self.base.is_negative:\n            if self.exp.is_odd:\n                return True\n            if self.exp.is_even:\n                return False\n        elif self.base.is_positive:\n            if self.exp.is_real:\n                return False\n        elif self.base.is_nonnegative:\n            if self.exp.is_nonnegative:\n                return False\n        elif self.base.is_nonpositive:\n            if self.exp.is_even:\n                return False\n        elif self.base.is_real:\n            if self.exp.is_even:\n                return False\n\n    def _eval_is_zero(self):\n        if self.base.is_zero:\n            if self.exp.is_positive:\n                return True\n            elif self.exp.is_nonpositive:\n                return False\n        elif self.base.is_zero is False:\n            if self.exp.is_finite:\n                return False\n            elif self.exp.is_infinite:\n                if (1 - abs(self.base)).is_positive:\n                    return self.exp.is_positive\n                elif (1 - abs(self.base)).is_negative:\n                    return self.exp.is_negative\n        else:\n            # when self.base.is_zero is None\n            return None\n\n    def _eval_is_integer(self):\n        b, e = self.args\n        if b.is_rational:\n            if b.is_integer is False and e.is_positive:\n                return False  # rat**nonneg\n        if b.is_integer and e.is_integer:\n            if b is S.NegativeOne:\n                return True\n            if e.is_nonnegative or e.is_positive:\n                return True\n        if b.is_integer and e.is_negative and (e.is_finite or e.is_integer):\n            if fuzzy_not((b - 1).is_zero) and fuzzy_not((b + 1).is_zero):\n                return False\n        if b.is_Number and e.is_Number:\n            check = self.func(*self.args)\n            return check.is_Integer\n\n    def _eval_is_real(self):\n        from sympy import arg, exp, log, Mul\n        real_b = self.base.is_real\n        if real_b is None:\n            if self.base.func == exp and self.base.args[0].is_imaginary:\n                return self.exp.is_imaginary\n            return\n        real_e = self.exp.is_real\n        if real_e is None:\n            return\n        if real_b and real_e:\n            if self.base.is_positive:\n                return True\n            elif self.base.is_nonnegative:\n                if self.exp.is_nonnegative:\n                    return True\n            else:\n                if self.exp.is_integer:\n                    return True\n                elif self.base.is_negative:\n                    if self.exp.is_Rational:\n                        return False\n        if real_e and self.exp.is_negative:\n            return Pow(self.base, -self.exp).is_real\n        im_b = self.base.is_imaginary\n        im_e = self.exp.is_imaginary\n        if im_b:\n            if self.exp.is_integer:\n                if self.exp.is_even:\n                    return True\n                elif self.exp.is_odd:\n                    return False\n            elif im_e and log(self.base).is_imaginary:\n                return True\n            elif self.exp.is_Add:\n                c, a = self.exp.as_coeff_Add()\n                if c and c.is_Integer:\n                    return Mul(\n                        self.base**c, self.base**a, evaluate=False).is_real\n            elif self.base in (-S.ImaginaryUnit, S.ImaginaryUnit):\n                if (self.exp/2).is_integer is False:\n                    return False\n        if real_b and im_e:\n            if self.base is S.NegativeOne:\n                return True\n            c = self.exp.coeff(S.ImaginaryUnit)\n            if c:\n                ok = (c*log(self.base)/S.Pi).is_Integer\n                if ok is not None:\n                    return ok\n\n        if real_b is False:  # we already know it's not imag\n            i = arg(self.base)*self.exp/S.Pi\n            return i.is_integer\n\n    def _eval_is_complex(self):\n        if all(a.is_complex for a in self.args):\n            return True\n\n    def _eval_is_imaginary(self):\n        from sympy import arg, log\n        if self.base.is_imaginary:\n            if self.exp.is_integer:\n                odd = self.exp.is_odd\n                if odd is not None:\n                    return odd\n                return\n\n        if self.exp.is_imaginary:\n            imlog = log(self.base).is_imaginary\n            if imlog is not None:\n                return False  # I**i -> real; (2*I)**i -> complex ==> not imaginary\n\n        if self.base.is_real and self.exp.is_real:\n            if self.base.is_positive:\n                return False\n            else:\n                rat = self.exp.is_rational\n                if not rat:\n                    return rat\n                if self.exp.is_integer:\n                    return False\n                else:\n                    half = (2*self.exp).is_integer\n                    if half:\n                        return self.base.is_negative\n                    return half\n\n        if self.base.is_real is False:  # we already know it's not imag\n            i = arg(self.base)*self.exp/S.Pi\n            return (2*i).is_odd\n\n    def _eval_is_odd(self):\n        if self.exp.is_integer:\n            if self.exp.is_positive:\n                return self.base.is_odd\n            elif self.exp.is_nonnegative and self.base.is_odd:\n                return True\n            elif self.base is S.NegativeOne:\n                return True\n\n    def _eval_is_finite(self):\n        if self.exp.is_negative:\n            if self.base.is_zero:\n                return False\n            if self.base.is_infinite:\n                return True\n        c1 = self.base.is_finite\n        if c1 is None:\n            return\n        c2 = self.exp.is_finite\n        if c2 is None:\n            return\n        if c1 and c2:\n            if self.exp.is_nonnegative or fuzzy_not(self.base.is_zero):\n                return True\n\n    def _eval_is_prime(self):\n        if self.exp == S.One:\n            return self.base.is_prime\n        if self.is_number:\n            return self.doit().is_prime\n\n        if self.is_integer and self.is_positive:\n            \"\"\"\n            a Power will be non-prime only if both base and exponent\n            are greater than 1\n            \"\"\"\n            if (self.base-1).is_positive or (self.exp-1).is_positive:\n                return False\n\n    def _eval_is_polar(self):\n        return self.base.is_polar\n\n    def _eval_subs(self, old, new):\n        from sympy import exp, log, Symbol\n        def _check(ct1, ct2, old):\n            \"\"\"Return bool, pow where, if bool is True, then the exponent of\n            Pow `old` will combine with `pow` so the substitution is valid,\n            otherwise bool will be False,\n\n            cti are the coefficient and terms of an exponent of self or old\n            In this _eval_subs routine a change like (b**(2*x)).subs(b**x, y)\n            will give y**2 since (b**x)**2 == b**(2*x); if that equality does\n            not hold then the substitution should not occur so `bool` will be\n            False.\n            \"\"\"\n            coeff1, terms1 = ct1\n            coeff2, terms2 = ct2\n            if terms1 == terms2:\n                pow = coeff1/coeff2\n                try:\n                    pow = as_int(pow)\n                    combines = True\n                except ValueError:\n                    combines = Pow._eval_power(\n                        Pow(*old.as_base_exp(), evaluate=False),\n                        pow) is not None\n                return combines, pow\n            return False, None\n\n        if old == self.base:\n            return new**self.exp._subs(old, new)\n\n        if old.func is self.func and self.base == old.base:\n            if self.exp.is_Add is False:\n                ct1 = self.exp.as_independent(Symbol, as_Add=False)\n                ct2 = old.exp.as_independent(Symbol, as_Add=False)\n                ok, pow = _check(ct1, ct2, old)\n                if ok:\n                    # issue 5180: (x**(6*y)).subs(x**(3*y),z)->z**2\n                    return self.func(new, pow)\n            else:  # b**(6*x+a).subs(b**(3*x), y) -> y**2 * b**a\n                # exp(exp(x) + exp(x**2)).subs(exp(exp(x)), w) -> w * exp(exp(x**2))\n                oarg = old.exp\n                new_l = []\n                o_al = []\n                ct2 = oarg.as_coeff_mul()\n                for a in self.exp.args:\n                    newa = a._subs(old, new)\n                    ct1 = newa.as_coeff_mul()\n                    ok, pow = _check(ct1, ct2, old)\n                    if ok:\n                        new_l.append(new**pow)\n                        continue\n                    o_al.append(newa)\n                if new_l:\n                    new_l.append(Pow(self.base, Add(*o_al), evaluate=False))\n                    return Mul(*new_l)\n\n        if old.func is exp and self.exp.is_real and self.base.is_positive:\n            ct1 = old.args[0].as_independent(Symbol, as_Add=False)\n            ct2 = (self.exp*log(self.base)).as_independent(\n                Symbol, as_Add=False)\n            ok, pow = _check(ct1, ct2, old)\n            if ok:\n                return self.func(new, pow)  # (2**x).subs(exp(x*log(2)), z) -> z\n\n    def as_base_exp(self):\n        \"\"\"Return base and exp of self.\n\n        If base is 1/Integer, then return Integer, -exp. If this extra\n        processing is not needed, the base and exp properties will\n        give the raw arguments\n\n        Examples\n        ========\n\n        >>> from sympy import Pow, S\n        >>> p = Pow(S.Half, 2, evaluate=False)\n        >>> p.as_base_exp()\n        (2, -2)\n        >>> p.args\n        (1/2, 2)\n\n        \"\"\"\n\n        b, e = self.args\n        if b.is_Rational and b.p == 1 and b.q != 1:\n            return Integer(b.q), -e\n        return b, e\n\n    def _eval_adjoint(self):\n        from sympy.functions.elementary.complexes import adjoint\n        i, p = self.exp.is_integer, self.base.is_positive\n        if i:\n            return adjoint(self.base)**self.exp\n        if p:\n            return self.base**adjoint(self.exp)\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return adjoint(expanded)\n\n    def _eval_conjugate(self):\n        from sympy.functions.elementary.complexes import conjugate as c\n        i, p = self.exp.is_integer, self.base.is_positive\n        if i:\n            return c(self.base)**self.exp\n        if p:\n            return self.base**c(self.exp)\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return c(expanded)\n\n    def _eval_transpose(self):\n        from sympy.functions.elementary.complexes import transpose\n        i, p = self.exp.is_integer, self.base.is_complex\n        if p:\n            return self.base**self.exp\n        if i:\n            return transpose(self.base)**self.exp\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return transpose(expanded)\n\n    def _eval_expand_power_exp(self, **hints):\n        \"\"\"a**(n+m) -> a**n*a**m\"\"\"\n        b = self.base\n        e = self.exp\n        if e.is_Add and e.is_commutative:\n            expr = []\n            for x in e.args:\n                expr.append(self.func(self.base, x))\n            return Mul(*expr)\n        return self.func(b, e)\n\n    def _eval_expand_power_base(self, **hints):\n        \"\"\"(a*b)**n -> a**n * b**n\"\"\"\n        force = hints.get('force', False)\n\n        b = self.base\n        e = self.exp\n        if not b.is_Mul:\n            return self\n\n        cargs, nc = b.args_cnc(split_1=False)\n\n        # expand each term - this is top-level-only\n        # expansion but we have to watch out for things\n        # that don't have an _eval_expand method\n        if nc:\n            nc = [i._eval_expand_power_base(**hints)\n                if hasattr(i, '_eval_expand_power_base') else i\n                for i in nc]\n\n            if e.is_Integer:\n                if e.is_positive:\n                    rv = Mul(*nc*e)\n                else:\n                    rv = 1/Mul(*nc*-e)\n                if cargs:\n                    rv *= Mul(*cargs)**e\n                return rv\n\n            if not cargs:\n                return self.func(Mul(*nc), e, evaluate=False)\n\n            nc = [Mul(*nc)]\n\n        # sift the commutative bases\n        def pred(x):\n            if x is S.ImaginaryUnit:\n                return S.ImaginaryUnit\n            polar = x.is_polar\n            if polar:\n                return True\n            if polar is None:\n                return fuzzy_bool(x.is_nonnegative)\n        sifted = sift(cargs, pred)\n        nonneg = sifted[True]\n        other = sifted[None]\n        neg = sifted[False]\n        imag = sifted[S.ImaginaryUnit]\n        if imag:\n            I = S.ImaginaryUnit\n            i = len(imag) % 4\n            if i == 0:\n                pass\n            elif i == 1:\n                other.append(I)\n            elif i == 2:\n                if neg:\n                    nonn = -neg.pop()\n                    if nonn is not S.One:\n                        nonneg.append(nonn)\n                else:\n                    neg.append(S.NegativeOne)\n            else:\n                if neg:\n                    nonn = -neg.pop()\n                    if nonn is not S.One:\n                        nonneg.append(nonn)\n                else:\n                    neg.append(S.NegativeOne)\n                other.append(I)\n            del imag\n\n        # bring out the bases that can be separated from the base\n\n        if force or e.is_integer:\n            # treat all commutatives the same and put nc in other\n            cargs = nonneg + neg + other\n            other = nc\n        else:\n            # this is just like what is happening automatically, except\n            # that now we are doing it for an arbitrary exponent for which\n            # no automatic expansion is done\n\n            assert not e.is_Integer\n\n            # handle negatives by making them all positive and putting\n            # the residual -1 in other\n            if len(neg) > 1:\n                o = S.One\n                if not other and neg[0].is_Number:\n                    o *= neg.pop(0)\n                if len(neg) % 2:\n                    o = -o\n                for n in neg:\n                    nonneg.append(-n)\n                if o is not S.One:\n                    other.append(o)\n            elif neg and other:\n                if neg[0].is_Number and neg[0] is not S.NegativeOne:\n                    other.append(S.NegativeOne)\n                    nonneg.append(-neg[0])\n                else:\n                    other.extend(neg)\n            else:\n                other.extend(neg)\n            del neg\n\n            cargs = nonneg\n            other += nc\n\n        rv = S.One\n        if cargs:\n            rv *= Mul(*[self.func(b, e, evaluate=False) for b in cargs])\n        if other:\n            rv *= self.func(Mul(*other), e, evaluate=False)\n        return rv\n\n    def _eval_expand_multinomial(self, **hints):\n        \"\"\"(a+b+..) ** n -> a**n + n*a**(n-1)*b + .., n is nonzero integer\"\"\"\n\n        base, exp = self.args\n        result = self\n\n        if exp.is_Rational and exp.p > 0 and base.is_Add:\n            if not exp.is_Integer:\n                n = Integer(exp.p // exp.q)\n\n                if not n:\n                    return result\n                else:\n                    radical, result = self.func(base, exp - n), []\n\n                    expanded_base_n = self.func(base, n)\n                    if expanded_base_n.is_Pow:\n                        expanded_base_n = \\\n                            expanded_base_n._eval_expand_multinomial()\n                    for term in Add.make_args(expanded_base_n):\n                        result.append(term*radical)\n\n                    return Add(*result)\n\n            n = int(exp)\n\n            if base.is_commutative:\n                order_terms, other_terms = [], []\n\n                for b in base.args:\n                    if b.is_Order:\n                        order_terms.append(b)\n                    else:\n                        other_terms.append(b)\n\n                if order_terms:\n                    # (f(x) + O(x^n))^m -> f(x)^m + m*f(x)^{m-1} *O(x^n)\n                    f = Add(*other_terms)\n                    o = Add(*order_terms)\n\n                    if n == 2:\n                        return expand_multinomial(f**n, deep=False) + n*f*o\n                    else:\n                        g = expand_multinomial(f**(n - 1), deep=False)\n                        return expand_mul(f*g, deep=False) + n*g*o\n\n                if base.is_number:\n                    # Efficiently expand expressions of the form (a + b*I)**n\n                    # where 'a' and 'b' are real numbers and 'n' is integer.\n                    a, b = base.as_real_imag()\n\n                    if a.is_Rational and b.is_Rational:\n                        if not a.is_Integer:\n                            if not b.is_Integer:\n                                k = self.func(a.q * b.q, n)\n                                a, b = a.p*b.q, a.q*b.p\n                            else:\n                                k = self.func(a.q, n)\n                                a, b = a.p, a.q*b\n                        elif not b.is_Integer:\n                            k = self.func(b.q, n)\n                            a, b = a*b.q, b.p\n                        else:\n                            k = 1\n\n                        a, b, c, d = int(a), int(b), 1, 0\n\n                        while n:\n                            if n & 1:\n                                c, d = a*c - b*d, b*c + a*d\n                                n -= 1\n                            a, b = a*a - b*b, 2*a*b\n                            n //= 2\n\n                        I = S.ImaginaryUnit\n\n                        if k == 1:\n                            return c + I*d\n                        else:\n                            return Integer(c)/k + I*d/k\n\n                p = other_terms\n                # (x+y)**3 -> x**3 + 3*x**2*y + 3*x*y**2 + y**3\n                # in this particular example:\n                # p = [x,y]; n = 3\n                # so now it's easy to get the correct result -- we get the\n                # coefficients first:\n                from sympy import multinomial_coefficients\n                from sympy.polys.polyutils import basic_from_dict\n                expansion_dict = multinomial_coefficients(len(p), n)\n                # in our example: {(3, 0): 1, (1, 2): 3, (0, 3): 1, (2, 1): 3}\n                # and now construct the expression.\n                return basic_from_dict(expansion_dict, *p)\n            else:\n                if n == 2:\n                    return Add(*[f*g for f in base.args for g in base.args])\n                else:\n                    multi = (base**(n - 1))._eval_expand_multinomial()\n                    if multi.is_Add:\n                        return Add(*[f*g for f in base.args\n                            for g in multi.args])\n                    else:\n                        # XXX can this ever happen if base was an Add?\n                        return Add(*[f*multi for f in base.args])\n        elif (exp.is_Rational and exp.p < 0 and base.is_Add and\n                abs(exp.p) > exp.q):\n            return 1 / self.func(base, -exp)._eval_expand_multinomial()\n        elif exp.is_Add and base.is_Number:\n            #  a + b      a  b\n            # n      --> n  n  , where n, a, b are Numbers\n\n            coeff, tail = S.One, S.Zero\n            for term in exp.args:\n                if term.is_Number:\n                    coeff *= self.func(base, term)\n                else:\n                    tail += term\n\n            return coeff * self.func(base, tail)\n        else:\n            return result\n\n    def as_real_imag(self, deep=True, **hints):\n        from sympy import atan2, cos, im, re, sin\n        from sympy.polys.polytools import poly\n\n        if self.exp.is_Integer:\n            exp = self.exp\n            re, im = self.base.as_real_imag(deep=deep)\n            if not im:\n                return self, S.Zero\n            a, b = symbols('a b', cls=Dummy)\n            if exp >= 0:\n                if re.is_Number and im.is_Number:\n                    # We can be more efficient in this case\n                    expr = expand_multinomial(self.base**exp)\n                    return expr.as_real_imag()\n\n                expr = poly(\n                    (a + b)**exp)  # a = re, b = im; expr = (a + b*I)**exp\n            else:\n                mag = re**2 + im**2\n                re, im = re/mag, -im/mag\n                if re.is_Number and im.is_Number:\n                    # We can be more efficient in this case\n                    expr = expand_multinomial((re + im*S.ImaginaryUnit)**-exp)\n                    return expr.as_real_imag()\n\n                expr = poly((a + b)**-exp)\n\n            # Terms with even b powers will be real\n            r = [i for i in expr.terms() if not i[0][1] % 2]\n            re_part = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n            # Terms with odd b powers will be imaginary\n            r = [i for i in expr.terms() if i[0][1] % 4 == 1]\n            im_part1 = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n            r = [i for i in expr.terms() if i[0][1] % 4 == 3]\n            im_part3 = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n\n            return (re_part.subs({a: re, b: S.ImaginaryUnit*im}),\n            im_part1.subs({a: re, b: im}) + im_part3.subs({a: re, b: -im}))\n\n        elif self.exp.is_Rational:\n            re, im = self.base.as_real_imag(deep=deep)\n\n            if im.is_zero and self.exp is S.Half:\n                if re.is_nonnegative:\n                    return self, S.Zero\n                if re.is_nonpositive:\n                    return S.Zero, (-self.base)**self.exp\n\n            # XXX: This is not totally correct since for x**(p/q) with\n            #      x being imaginary there are actually q roots, but\n            #      only a single one is returned from here.\n            r = self.func(self.func(re, 2) + self.func(im, 2), S.Half)\n            t = atan2(im, re)\n\n            rp, tp = self.func(r, self.exp), t*self.exp\n\n            return (rp*cos(tp), rp*sin(tp))\n        else:\n\n            if deep:\n                hints['complex'] = False\n\n                expanded = self.expand(deep, **hints)\n                if hints.get('ignore') == expanded:\n                    return None\n                else:\n                    return (re(expanded), im(expanded))\n            else:\n                return (re(self), im(self))\n\n    def _eval_derivative(self, s):\n        from sympy import log\n        dbase = self.base.diff(s)\n        dexp = self.exp.diff(s)\n        return self * (dexp * log(self.base) + dbase * self.exp/self.base)\n\n    def _eval_evalf(self, prec):\n        base, exp = self.as_base_exp()\n        base = base._evalf(prec)\n        if not exp.is_Integer:\n            exp = exp._evalf(prec)\n        if exp.is_negative and base.is_number and base.is_real is False:\n            base = base.conjugate() / (base * base.conjugate())._evalf(prec)\n            exp = -exp\n            return self.func(base, exp).expand()\n        return self.func(base, exp)\n\n    def _eval_is_polynomial(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return bool(self.base._eval_is_polynomial(syms) and\n                self.exp.is_Integer and (self.exp >= 0))\n        else:\n            return True\n\n    def _eval_is_rational(self):\n        p = self.func(*self.as_base_exp())  # in case it's unevaluated\n        if not p.is_Pow:\n            return p.is_rational\n        b, e = p.as_base_exp()\n        if e.is_Rational and b.is_Rational:\n            # we didn't check that e is not an Integer\n            # because Rational**Integer autosimplifies\n            return False\n        if e.is_integer:\n            if b.is_rational:\n                if fuzzy_not(b.is_zero) or e.is_nonnegative:\n                    return True\n                if b == e:  # always rational, even for 0**0\n                    return True\n            elif b.is_irrational:\n                return e.is_zero\n\n    def _eval_is_algebraic(self):\n        if self.base.is_zero or (self.base - 1).is_zero:\n            return True\n        elif self.exp.is_rational:\n            return self.base.is_algebraic\n        elif self.base.is_algebraic and self.exp.is_algebraic:\n            if ((fuzzy_not(self.base.is_zero)\n                and fuzzy_not((self.base - 1).is_zero))\n                or self.base.is_integer is False\n                or self.base.is_irrational):\n                return self.exp.is_rational\n\n    def _eval_is_rational_function(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return self.base._eval_is_rational_function(syms) and \\\n                self.exp.is_Integer\n        else:\n            return True\n\n    def _eval_is_algebraic_expr(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return self.base._eval_is_algebraic_expr(syms) and \\\n                self.exp.is_Rational\n        else:\n            return True\n\n    def as_numer_denom(self):\n        if not self.is_commutative:\n            return self, S.One\n        base, exp = self.as_base_exp()\n        n, d = base.as_numer_denom()\n        # this should be the same as ExpBase.as_numer_denom wrt\n        # exponent handling\n        neg_exp = exp.is_negative\n        if not neg_exp and not (-exp).is_negative:\n            neg_exp = _coeff_isneg(exp)\n        int_exp = exp.is_integer\n        # the denominator cannot be separated from the numerator if\n        # its sign is unknown unless the exponent is an integer, e.g.\n        # sqrt(a/b) != sqrt(a)/sqrt(b) when a=1 and b=-1. But if the\n        # denominator is negative the numerator and denominator can\n        # be negated and the denominator (now positive) separated.\n        if not (d.is_real or int_exp):\n            n = base\n            d = S.One\n        dnonpos = d.is_nonpositive\n        if dnonpos:\n            n, d = -n, -d\n        elif dnonpos is None and not int_exp:\n            n = base\n            d = S.One\n        if neg_exp:\n            n, d = d, n\n            exp = -exp\n        return self.func(n, exp), self.func(d, exp)\n\n    def matches(self, expr, repl_dict={}, old=False):\n        expr = _sympify(expr)\n\n        # special case, pattern = 1 and expr.exp can match to 0\n        if expr is S.One:\n            d = repl_dict.copy()\n            d = self.exp.matches(S.Zero, d)\n            if d is not None:\n                return d\n\n        # make sure the expression to be matched is an Expr\n        if not isinstance(expr, Expr):\n            return None\n\n        b, e = expr.as_base_exp()\n\n        # special case number\n        sb, se = self.as_base_exp()\n        if sb.is_Symbol and se.is_Integer and expr:\n            if e.is_rational:\n                return sb.matches(b**(e/se), repl_dict)\n            return sb.matches(expr**(1/se), repl_dict)\n\n        d = repl_dict.copy()\n        d = self.base.matches(b, d)\n        if d is None:\n            return None\n\n        d = self.exp.xreplace(d).matches(e, d)\n        if d is None:\n            return Expr.matches(self, expr, repl_dict)\n        return d\n\n    def _eval_nseries(self, x, n, logx):\n        # NOTE! This function is an important part of the gruntz algorithm\n        #       for computing limits. It has to return a generalized power\n        #       series with coefficients in C(log, log(x)). In more detail:\n        # It has to return an expression\n        #     c_0*x**e_0 + c_1*x**e_1 + ... (finitely many terms)\n        # where e_i are numbers (not necessarily integers) and c_i are\n        # expressions involving only numbers, the log function, and log(x).\n        from sympy import ceiling, collect, exp, log, O, Order, powsimp\n        b, e = self.args\n        if e.is_Integer:\n            if e > 0:\n                # positive integer powers are easy to expand, e.g.:\n                # sin(x)**4 = (x-x**3/3+...)**4 = ...\n                return expand_multinomial(self.func(b._eval_nseries(x, n=n,\n                    logx=logx), e), deep=False)\n            elif e is S.NegativeOne:\n                # this is also easy to expand using the formula:\n                # 1/(1 + x) = 1 - x + x**2 - x**3 ...\n                # so we need to rewrite base to the form \"1+x\"\n\n                nuse = n\n                cf = 1\n\n                try:\n                    ord = b.as_leading_term(x)\n                    cf = Order(ord, x).getn()\n                    if cf and cf.is_Number:\n                        nuse = n + 2*ceiling(cf)\n                    else:\n                        cf = 1\n                except NotImplementedError:\n                    pass\n\n                b_orig, prefactor = b, O(1, x)\n                while prefactor.is_Order:\n                    nuse += 1\n                    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\n                    prefactor = b.as_leading_term(x)\n\n                # express \"rest\" as: rest = 1 + k*x**l + ... + O(x**n)\n                rest = expand_mul((b - prefactor)/prefactor)\n\n                if rest.is_Order:\n                    return 1/prefactor + rest/prefactor + O(x**n, x)\n\n                k, l = rest.leadterm(x)\n                if l.is_Rational and l > 0:\n                    pass\n                elif l.is_number and l > 0:\n                    l = l.evalf()\n                elif l == 0:\n                    k = k.simplify()\n                    if k == 0:\n                        # if prefactor == w**4 + x**2*w**4 + 2*x*w**4, we need to\n                        # factor the w**4 out using collect:\n                        return 1/collect(prefactor, x)\n                    else:\n                        raise NotImplementedError()\n                else:\n                    raise NotImplementedError()\n\n                if cf < 0:\n                    cf = S.One/abs(cf)\n\n                try:\n                    dn = Order(1/prefactor, x).getn()\n                    if dn and dn < 0:\n                        pass\n                    else:\n                        dn = 0\n                except NotImplementedError:\n                    dn = 0\n\n                terms = [1/prefactor]\n                for m in range(1, ceiling((n - dn)/l*cf)):\n                    new_term = terms[-1]*(-rest)\n                    if new_term.is_Pow:\n                        new_term = new_term._eval_expand_multinomial(\n                            deep=False)\n                    else:\n                        new_term = expand_mul(new_term, deep=False)\n                    terms.append(new_term)\n                terms.append(O(x**n, x))\n                return powsimp(Add(*terms), deep=True, combine='exp')\n            else:\n                # negative powers are rewritten to the cases above, for\n                # example:\n                # sin(x)**(-4) = 1/( sin(x)**4) = ...\n                # and expand the denominator:\n                nuse, denominator = n, O(1, x)\n                while denominator.is_Order:\n                    denominator = (b**(-e))._eval_nseries(x, n=nuse, logx=logx)\n                    nuse += 1\n                if 1/denominator == self:\n                    return self\n                # now we have a type 1/f(x), that we know how to expand\n                return (1/denominator)._eval_nseries(x, n=n, logx=logx)\n\n        if e.has(Symbol):\n            return exp(e*log(b))._eval_nseries(x, n=n, logx=logx)\n\n        # see if the base is as simple as possible\n        bx = b\n        while bx.is_Pow and bx.exp.is_Rational:\n            bx = bx.base\n        if bx == x:\n            return self\n\n        # work for b(x)**e where e is not an Integer and does not contain x\n        # and hopefully has no other symbols\n\n        def e2int(e):\n            \"\"\"return the integer value (if possible) of e and a\n            flag indicating whether it is bounded or not.\"\"\"\n            n = e.limit(x, 0)\n            infinite = n.is_infinite\n            if not infinite:\n                # XXX was int or floor intended? int used to behave like floor\n                # so int(-Rational(1, 2)) returned -1 rather than int's 0\n                try:\n                    n = int(n)\n                except TypeError:\n                    #well, the n is something more complicated (like 1+log(2))\n                    try:\n                        n = int(n.evalf()) + 1  # XXX why is 1 being added?\n                    except TypeError:\n                        pass  # hope that base allows this to be resolved\n                n = _sympify(n)\n            return n, infinite\n\n        order = O(x**n, x)\n        ei, infinite = e2int(e)\n        b0 = b.limit(x, 0)\n        if infinite and (b0 is S.One or b0.has(Symbol)):\n            # XXX what order\n            if b0 is S.One:\n                resid = (b - 1)\n                if resid.is_positive:\n                    return S.Infinity\n                elif resid.is_negative:\n                    return S.Zero\n                raise ValueError('cannot determine sign of %s' % resid)\n\n            return b0**ei\n\n        if (b0 is S.Zero or b0.is_infinite):\n            if infinite is not False:\n                return b0**e  # XXX what order\n\n            if not ei.is_number:  # if not, how will we proceed?\n                raise ValueError(\n                    'expecting numerical exponent but got %s' % ei)\n\n            nuse = n - ei\n\n            if e.is_real and e.is_positive:\n                lt = b.as_leading_term(x)\n\n                # Try to correct nuse (= m) guess from:\n                # (lt + rest + O(x**m))**e =\n                # lt**e*(1 + rest/lt + O(x**m)/lt)**e =\n                # lt**e + ... + O(x**m)*lt**(e - 1) = ... + O(x**n)\n                try:\n                    cf = Order(lt, x).getn()\n                    nuse = ceiling(n - cf*(e - 1))\n                except NotImplementedError:\n                    pass\n\n            bs = b._eval_nseries(x, n=nuse, logx=logx)\n            terms = bs.removeO()\n            if terms.is_Add:\n                bs = terms\n                lt = terms.as_leading_term(x)\n\n                # bs -> lt + rest -> lt*(1 + (bs/lt - 1))\n                return ((self.func(lt, e) * self.func((bs/lt).expand(), e).nseries(\n                    x, n=nuse, logx=logx)).expand() + order)\n\n            if bs.is_Add:\n                from sympy import O\n                # So, bs + O() == terms\n                c = Dummy('c')\n                res = []\n                for arg in bs.args:\n                    if arg.is_Order:\n                        arg = c*arg.expr\n                    res.append(arg)\n                bs = Add(*res)\n                rv = (bs**e).series(x).subs(c, O(1, x))\n                rv += order\n                return rv\n\n            rv = bs**e\n            if terms != bs:\n                rv += order\n            return rv\n\n        # either b0 is bounded but neither 1 nor 0 or e is infinite\n        # b -> b0 + (b-b0) -> b0 * (1 + (b/b0-1))\n        o2 = order*(b0**-e)\n        z = (b/b0 - 1)\n        o = O(z, x)\n        if o is S.Zero or o2 is S.Zero:\n            infinite = True\n        else:\n            if o.expr.is_number:\n                e2 = log(o2.expr*x)/log(x)\n            else:\n                e2 = log(o2.expr)/log(o.expr)\n            n, infinite = e2int(e2)\n        if infinite:\n            # requested accuracy gives infinite series,\n            # order is probably non-polynomial e.g. O(exp(-1/x), x).\n            r = 1 + z\n        else:\n            l = []\n            g = None\n            for i in range(n + 2):\n                g = self._taylor_term(i, z, g)\n                g = g.nseries(x, n=n, logx=logx)\n                l.append(g)\n            r = Add(*l)\n        return expand_mul(r*b0**e) + order\n\n    def _eval_as_leading_term(self, x):\n        from sympy import exp, log\n        if not self.exp.has(x):\n            return self.func(self.base.as_leading_term(x), self.exp)\n        return exp(self.exp * log(self.base)).as_leading_term(x)\n\n    @cacheit\n    def _taylor_term(self, n, x, *previous_terms): # of (1+x)**e\n        from sympy import binomial\n        return binomial(self.exp, n) * self.func(x, n)\n\n    def _sage_(self):\n        return self.args[0]._sage_()**self.args[1]._sage_()\n\n    def as_content_primitive(self, radical=False):\n        \"\"\"Return the tuple (R, self/R) where R is the positive Rational\n        extracted from self.\n\n        Examples\n        ========\n\n        >>> from sympy import sqrt\n        >>> sqrt(4 + 4*sqrt(2)).as_content_primitive()\n        (2, sqrt(1 + sqrt(2)))\n        >>> sqrt(3 + 3*sqrt(2)).as_content_primitive()\n        (1, sqrt(3)*sqrt(1 + sqrt(2)))\n\n        >>> from sympy import expand_power_base, powsimp, Mul\n        >>> from sympy.abc import x, y\n\n        >>> ((2*x + 2)**2).as_content_primitive()\n        (4, (x + 1)**2)\n        >>> (4**((1 + y)/2)).as_content_primitive()\n        (2, 4**(y/2))\n        >>> (3**((1 + y)/2)).as_content_primitive()\n        (1, 3**((y + 1)/2))\n        >>> (3**((5 + y)/2)).as_content_primitive()\n        (9, 3**((y + 1)/2))\n        >>> eq = 3**(2 + 2*x)\n        >>> powsimp(eq) == eq\n        True\n        >>> eq.as_content_primitive()\n        (9, 3**(2*x))\n        >>> powsimp(Mul(*_))\n        3**(2*x + 2)\n\n        >>> eq = (2 + 2*x)**y\n        >>> s = expand_power_base(eq); s.is_Mul, s\n        (False, (2*x + 2)**y)\n        >>> eq.as_content_primitive()\n        (1, (2*(x + 1))**y)\n        >>> s = expand_power_base(_[1]); s.is_Mul, s\n        (True, 2**y*(x + 1)**y)\n\n        See docstring of Expr.as_content_primitive for more examples.\n        \"\"\"\n\n        b, e = self.as_base_exp()\n        b = _keep_coeff(*b.as_content_primitive(radical=radical))\n        ce, pe = e.as_content_primitive(radical=radical)\n        if b.is_Rational:\n            #e\n            #= ce*pe\n            #= ce*(h + t)\n            #= ce*h + ce*t\n            #=> self\n            #= b**(ce*h)*b**(ce*t)\n            #= b**(cehp/cehq)*b**(ce*t)\n            #= b**(iceh+r/cehq)*b**(ce*t)\n            #= b**(iceh)*b**(r/cehq)*b**(ce*t)\n            #= b**(iceh)*b**(ce*t + r/cehq)\n            h, t = pe.as_coeff_Add()\n            if h.is_Rational:\n                ceh = ce*h\n                c = self.func(b, ceh)\n                r = S.Zero\n                if not c.is_Rational:\n                    iceh, r = divmod(ceh.p, ceh.q)\n                    c = self.func(b, iceh)\n                return c, self.func(b, _keep_coeff(ce, t + r/ce/ceh.q))\n        e = _keep_coeff(ce, pe)\n        # b**e = (h*t)**e = h**e*t**e = c*m*t**e\n        if e.is_Rational and b.is_Mul:\n            h, t = b.as_content_primitive(radical=radical)  # h is positive\n            c, m = self.func(h, e).as_coeff_Mul()  # so c is positive\n            m, me = m.as_base_exp()\n            if m is S.One or me == e:  # probably always true\n                # return the following, not return c, m*Pow(t, e)\n                # which would change Pow into Mul; we let sympy\n                # decide what to do by using the unevaluated Mul, e.g\n                # should it stay as sqrt(2 + 2*sqrt(5)) or become\n                # sqrt(2)*sqrt(1 + sqrt(5))\n                return c, self.func(_keep_coeff(m, t), e)\n        return S.One, self.func(b, e)\n\n    def is_constant(self, *wrt, **flags):\n        expr = self\n        if flags.get('simplify', True):\n            expr = expr.simplify()\n        b, e = expr.as_base_exp()\n        bz = b.equals(0)\n        if bz:  # recalculate with assumptions in case it's unevaluated\n            new = b**e\n            if new != expr:\n                return new.is_constant()\n        econ = e.is_constant(*wrt)\n        bcon = b.is_constant(*wrt)\n        if bcon:\n            if econ:\n                return True\n            bz = b.equals(0)\n            if bz is False:\n                return False\n        elif bcon is None:\n            return None\n\n        return e.equals(0)\n\n    def _eval_difference_delta(self, n, step):\n        b, e = self.args\n        if e.has(n) and not b.has(n):\n            new_e = e.subs(n, n + step)\n            return (b**(new_e - e) - 1) * self"
        }
      ]
    },
    {
      "pr_number": 8682,
      "pr_title": "_random: added ValueError to handled exceptions (fixes #8662)",
      "pr_body": "I think this completely resolves the issue, and it does not break any tests. I'm not sure it is the best solution because I'm not overwhelmingly familiar with the codebase. I could have also fixed this by making the _new_args_filter() function in miscellaneous.py throw a TypeError - which _random already handles - instead of a ValueError.\n",
      "issue_id": 8662,
      "issue_title": "Expr._random() fails to catch ValueError exception",
      "issue_body": "When I run the following code, it fails with a \"ValueError\" exception. The problem is that is_constant calls _random, which eventually calls MinMaxBase._new_args_filter in miscellaneous.py. This function has an explicit check for conditions which can result in a ValueError, but _random only catches TypeError.\n\nI'm happy to fix this and make a pull request, but I am not sure what the correct fix is. I currently added ValueError to the list of exceptions caught by _random so that it just returns None in this case. It could be that instead I should make _new_args_filter throw a TypeError instead of a ValueError.\n\n```\n# test sympy problem\nfrom sympy import S\nproblem_expr_s = \"\"\"\n    -SPANCALC_OFF + Piecewise((SPANCALC_PCT, And(Pcl_Loop_Type > 0, \n    sqrt((-Pcl_Kink1_XY_Offset - (-Neck1L_x1*Pcl_Loop_Height - \n    Pcl_Loop_Height**2*neck1L_x2 + Pcl_Loop_Height - neck1L_c)*\n    tan(pi*(-Pcl_Loop_Height**2*neck2A_x2/180 - Pcl_Loop_Height*neck2A_x1/180 \n    - neck2A_c/180 + 1/2)) + Piecewise((Pcl_Span01_XY_Offset + \n    Piecewise((Min(bond_dist, Max(Pcl_Span_Percent*bond_dist, (-Neck1L_x1*\n    Pcl_Loop_Height - Pcl_Loop_Height**2*neck1L_x2 + Pcl_Loop_Height - neck1L_c)\n    *tan(pi*(-Pcl_Loop_Height**2*neck2A_x2/180 - Pcl_Loop_Height*neck2A_x1/180 - \n    neck2A_c/180 + 1/2)))), Pcl_Loop_Type > 0), ((-Neck1L_x1*Pcl_Loop_Height - \n    Pcl_Loop_Height**2*neck1L_x2 + Pcl_Loop_Height - neck1L_c)*tan(pi*(\n    -Pcl_Loop_Height**2*neck2A_x2/180 - Pcl_Loop_Height*neck2A_x1/180 - \n    neck2A_c/180 + 1/2)), True)), Pcl_Loop_Type > 0), (Pcl_Kink1_XY_Offset + \n    (-Neck1L_x1*Pcl_Loop_Height - Pcl_Loop_Height**2*neck1L_x2 + Pcl_Loop_Height\n    - neck1L_c)*tan(pi*(-Pcl_Loop_Height**2*neck2A_x2/180 - Pcl_Loop_Height*\n    neck2A_x1/180 - neck2A_c/180 + 1/2)), True)))**2 + (-Pcl_Kink1_Z_Offset - \n    Pcl_Loop_Height + Max(-pcl_bond_height_diff, Pcl_Span01_Z_Offset + Max(\n    Pcl_Loop_Height, -pcl_bond_height_diff)))**2) > sqrt((Pcl_Kink1_Z_Offset + \n    Pcl_Loop_Height - Max(0, Neck1L_x1*Pcl_Loop_Height + Pcl_Kink2_Z_Offset + \n    Pcl_Loop_Height**2*neck1L_x2 + neck1L_c))**2 + (Pcl_Kink1_XY_Offset - \n    Pcl_Kink2_XY_Offset - pcl_dflt_kink2_xy + (-Neck1L_x1*Pcl_Loop_Height - \n    Pcl_Loop_Height**2*neck1L_x2 + Pcl_Loop_Height - neck1L_c)*tan(pi*(\n    -Pcl_Loop_Height**2*neck2A_x2/180 - Pcl_Loop_Height*neck2A_x1/180 - \n    neck2A_c/180 + 1/2)))**2))), (SPANCALC_OFF, True))\n\"\"\"\nproblem_expr = S(problem_expr_s)\n# the real problem occured in a different context, but this will replicate the problem\nproblem_expr.is_constant(simplify=False)\n# this is the problem call:\nproblem_expr._random()\n```\n",
      "issue_closed_at": "2015-01-10T09:44:19Z",
      "base_commit": "1fff22f3950a2125580fcc4b1760b18f3ce8874b",
      "changes": [
        {
          "file": "sympy/core/expr.py",
          "type": "function",
          "name": "_random",
          "class_name": "Expr",
          "code": "def _random(self, n=None, re_min=-1, im_min=-1, re_max=1, im_max=1):\n        \"\"\"Return self evaluated, if possible, replacing free symbols with\n        random complex values, if necessary.\n\n        The random complex value for each free symbol is generated\n        by the random_complex_number routine giving real and imaginary\n        parts in the range given by the re_min, re_max, im_min, and im_max\n        values. The returned value is evaluated to a precision of n\n        (if given) else the maximum of 15 and the precision needed\n        to get more than 1 digit of precision. If the expression\n        could not be evaluated to a number, or could not be evaluated\n        to more than 1 digit of precision, then None is returned.\n\n        Examples\n        ========\n\n        >>> from sympy import sqrt\n        >>> from sympy.abc import x, y\n        >>> x._random()                         # doctest: +SKIP\n        0.0392918155679172 + 0.916050214307199*I\n        >>> x._random(2)                        # doctest: +SKIP\n        -0.77 - 0.87*I\n        >>> (x + y/2)._random(2)                # doctest: +SKIP\n        -0.57 + 0.16*I\n        >>> sqrt(2)._random(2)\n        1.4\n\n        See Also\n        ========\n\n        sympy.utilities.randtest.random_complex_number\n        \"\"\"\n\n        free = self.free_symbols\n        prec = 1\n        if free:\n            from sympy.utilities.randtest import random_complex_number\n            a, c, b, d = re_min, re_max, im_min, im_max\n            reps = dict(list(zip(free, [random_complex_number(a, b, c, d, rational=True)\n                           for zi in free])))\n            try:\n                nmag = abs(self.evalf(2, subs=reps))\n            except TypeError:\n                # if an out of range value resulted in evalf problems\n                # then return None -- XXX is there a way to know how to\n                # select a good random number for a given expression?\n                # e.g. when calculating n! negative values for n should not\n                # be used\n                return None\n        else:\n            reps = {}\n            nmag = abs(self.evalf(2))\n\n        if not hasattr(nmag, '_prec'):\n            # e.g. exp_polar(2*I*pi) doesn't evaluate but is_number is True\n            return None\n\n        if nmag._prec == 1:\n            # increase the precision up to the default maximum\n            # precision to see if we can get any significance\n\n            from mpmath.libmp.libintmath import giant_steps\n            from sympy.core.evalf import DEFAULT_MAXPREC as target\n\n            # evaluate\n            for prec in giant_steps(2, target):\n                nmag = abs(self.evalf(prec, subs=reps))\n                if nmag._prec != 1:\n                    break\n\n        if nmag._prec != 1:\n            if n is None:\n                n = max(prec, 15)\n            return self.evalf(n, subs=reps)\n\n        # never got any significance\n        return None"
        }
      ]
    }
  ]
}