{
    "Selected_candidate": {
        "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"
            }
        ]
    },
    "Justification": "Candidate D has high structural similarity due to both the CURRENT bug and Candidate D encountering a recursion depth error. The fundamental issue in Candidate D is related to handling complex exponentiation, which aligns well with the CURRENT bug involving a recursion error when evaluating an expression to check if it's zero. Understanding how Candidate D resolved its recursion error could provide critical insights into addressing the CURRENT bug effectively, particularly in handling similar recursive calls."
}