{
  "instance_id": "sympy__sympy-11870",
  "repo": "sympy/sympy",
  "created_at": "2016-11-17T21:36:03Z",
  "problem_statement": "simplifying exponential -> trig identities\n```\r\nf = 1 / 2 * (-I*exp(I*k) + I*exp(-I*k))\r\ntrigsimp(f)\r\n```\r\n\r\nIdeally, this would yield `sin(k)`. Is there a way to do this?\r\n\r\nAs a corollary, it would be awesome if \r\n\r\n```\r\nf = 1 / 2 / k* (-I*exp(I*k) + I*exp(-I*k))\r\ntrigsimp(f)\r\n```\r\n\r\ncould yield `sinc(k)`. Thank you for your consideration!\n",
  "patch": "diff --git a/sympy/functions/elementary/trigonometric.py b/sympy/functions/elementary/trigonometric.py\n--- a/sympy/functions/elementary/trigonometric.py\n+++ b/sympy/functions/elementary/trigonometric.py\n@@ -16,6 +16,8 @@\n from sympy.sets.sets import FiniteSet\n from sympy.utilities.iterables import numbered_symbols\n from sympy.core.compatibility import range\n+from sympy.core.relational import Ne\n+from sympy.functions.elementary.piecewise import Piecewise\n \n ###############################################################################\n ########################## TRIGONOMETRIC FUNCTIONS ############################\n@@ -400,6 +402,9 @@ def _eval_rewrite_as_csc(self, arg):\n     def _eval_rewrite_as_sec(self, arg):\n         return 1 / sec(arg - S.Pi / 2, evaluate=False)\n \n+    def _eval_rewrite_as_sinc(self, arg):\n+        return arg*sinc(arg)\n+\n     def _eval_conjugate(self):\n         return self.func(self.args[0].conjugate())\n \n@@ -1789,7 +1794,7 @@ def _eval_rewrite_as_jn(self, arg):\n         return jn(0, arg)\n \n     def _eval_rewrite_as_sin(self, arg):\n-        return sin(arg) / arg\n+        return Piecewise((sin(arg)/arg, Ne(arg, 0)), (1, True))\n \n \n ###############################################################################\n",
  "similar_bug_items": [
    {
      "pr_number": 8627,
      "pr_title": "Bug Fix #8626",
      "pr_body": "Let me know if a test case is needed\n",
      "issue_id": 8626,
      "issue_title": "bug in physics/mechanics/lagrange.py",
      "issue_body": "When providing a `forcelist` with more than one force, not all terms are computed,\nthis comes from the fact that the iterator `flist = zip(*_f_list_parser(self.forcelist, N))` is consumed in the first iteration of the loop.\n\nI propose a following PR that fixes the bug, let me know if I need to also provide a test case.\n\nBest,\nGuillaume\n",
      "issue_closed_at": "2015-01-06T16:57:16Z",
      "base_commit": "65f7c8c2c9c1927eaa8520c4ce06864f93a20ad1",
      "changes": [
        {
          "file": "sympy/physics/mechanics/lagrange.py",
          "type": "function",
          "name": "form_lagranges_equations",
          "class_name": "LagrangesMethod",
          "code": "def form_lagranges_equations(self):\n        \"\"\"Method to form Lagrange's equations of motion.\n\n        Returns a vector of equations of motion using Lagrange's equations of\n        the second kind.\n        \"\"\"\n\n        qds = self._qdots\n        qdd_zero = dict((i, 0) for i in self._qdoubledots)\n        n = len(self.q)\n\n        # Internally we represent the EOM as four terms:\n        # EOM = term1 - term2 - term3 - term4 = 0\n\n        # First term\n        self._term1 = self._L.jacobian(qds)\n        self._term1 = self._term1.diff(dynamicsymbols._t).T\n\n        # Second term\n        self._term2 = self._L.jacobian(self.q).T\n\n        # Third term\n        if self.coneqs:\n            coneqs = self.coneqs\n            m = len(coneqs)\n            # Creating the multipliers\n            self.lam_vec = Matrix(dynamicsymbols('lam1:' + str(m + 1)))\n            self.lam_coeffs = -coneqs.jacobian(qds)\n            self._term3 = self.lam_coeffs.T * self.lam_vec\n            # Extracting the coeffecients of the qdds from the diff coneqs\n            diffconeqs = coneqs.diff(dynamicsymbols._t)\n            self._m_cd = diffconeqs.jacobian(self._qdoubledots)\n            # The remaining terms i.e. the 'forcing' terms in diff coneqs\n            self._f_cd = -diffconeqs.subs(qdd_zero)\n        else:\n            self._term3 = zeros(n, 1)\n\n        # Fourth term\n        if self.forcelist:\n            N = self.inertial\n            self._term4 = zeros(n, 1)\n            flist = zip(*_f_list_parser(self.forcelist, N))\n            for i, qd in enumerate(qds):\n                for obj, force in self.forcelist:\n                    self._term4[i] = sum(v.diff(qd, N) & f for (v, f) in flist)\n        else:\n            self._term4 = zeros(n, 1)\n\n        # Form the dynamic mass and forcing matrices\n        without_lam = self._term1 - self._term2 - self._term4\n        self._m_d = without_lam.jacobian(self._qdoubledots)\n        self._f_d = -without_lam.subs(qdd_zero)\n\n        # Form the EOM\n        self.eom = without_lam - self._term3\n        return self.eom"
        }
      ]
    },
    {
      "pr_number": 8548,
      "pr_title": "Issue #6988: expand_log(exp(x), force=True) = x",
      "pr_body": "This is a try to fix issue #6988. If I made some mistake just let me know, as I'm still new to sympy development.\n\n```\nIn [9]: expand_log(log(exp(x)), force=True)\nOut[9]: x\n\nIn [10]: expand_log(log(y**(x)), force=True)\nOut[10]: x\u22c5log(y)\n```\n",
      "issue_id": 6988,
      "issue_title": "expand_log(exp(x), force=True) should give x",
      "issue_body": "```\nIn [5]: expand_log(log(exp(x)), force=True)\nOut[5]:\n   \u239b x\u239e\nlog\u239d\u212f \u23a0\n\nIn [6]: expand_log(log(y**(x)), force=True)\nOut[6]: x\u22c5log(y) Issue 1799 is probably to blame.\n```\n\nOriginal issue for #6988: http://code.google.com/p/sympy/issues/detail?id=3889\nOriginal author: https://code.google.com/u/asmeurer@gmail.com/\n",
      "issue_closed_at": "2014-12-03T13:34:14Z",
      "base_commit": "e6fc53f27ee872b27bc79b96529fc4bf34d4f023",
      "changes": [
        {
          "file": "sympy/functions/elementary/exponential.py",
          "type": "function",
          "name": "_eval_expand_log",
          "class_name": "log",
          "code": "def _eval_expand_log(self, deep=True, **hints):\n        from sympy import unpolarify\n        from sympy.concrete import Sum, Product\n        force = hints.get('force', False)\n        arg = self.args[0]\n        if arg.is_Integer:\n            # remove perfect powers\n            p = perfect_power(int(arg))\n            if p is not False:\n                return p[1]*self.func(p[0])\n        elif arg.is_Mul:\n            expr = []\n            nonpos = []\n            for x in arg.args:\n                if force or x.is_positive or x.is_polar:\n                    a = self.func(x)\n                    if isinstance(a, log):\n                        expr.append(self.func(x)._eval_expand_log(**hints))\n                    else:\n                        expr.append(a)\n                elif x.is_negative:\n                    a = self.func(-x)\n                    expr.append(a)\n                    nonpos.append(S.NegativeOne)\n                else:\n                    nonpos.append(x)\n            return Add(*expr) + log(Mul(*nonpos))\n        elif arg.is_Pow:\n            if force or (arg.exp.is_real and arg.base.is_positive) or \\\n                    arg.base.is_polar:\n                b = arg.base\n                e = arg.exp\n                a = self.func(b)\n                if isinstance(a, log):\n                    return unpolarify(e) * a._eval_expand_log(**hints)\n                else:\n                    return unpolarify(e) * a\n        elif isinstance(arg, Product):\n            if arg.function.is_positive:\n                return Sum(log(arg.function), *arg.limits)\n\n        return self.func(arg)"
        }
      ]
    },
    {
      "pr_number": 10029,
      "pr_title": "oo**e for non-real complex `e` handling",
      "pr_body": "fixes #10020\n",
      "issue_id": 10020,
      "issue_title": "oo**I raises RunTimeError",
      "issue_body": "```\ngxyd@swap:~/Public/sympy$ python3.4\nPython 3.4.3 (default, Jul 28 2015, 18:20:59) \n[GCC 4.8.4] on linux\nType \"help\", \"copyright\", \"credits\" or \"license\" for more information.\n>>> from sympy import *\n>>> oo**I\nTraceback (most recent call last):\n  File \"<stdin>\", line 1, in <module>\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/expr.py\", line 151, in __pow__\n    return Pow(self, other)\n  File \"/home/gxyd/Public/sympy/sympy/core/cache.py\", line 93, in wrapper\n    retval = cfunc(*args, **kwargs)\n  File \"/usr/lib/python3.4/functools.py\", line 472, in wrapper\n    result = user_function(*args, **kwds)\n  File \"/home/gxyd/Public/sympy/sympy/core/power.py\", line 192, in __new__\n    obj = b._eval_power(e)\n  File \"/home/gxyd/Public/sympy/sympy/core/numbers.py\", line 2474, in _eval_power\n    return self**expt.evalf()\n  File \"/home/gxyd/Public/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\nRuntimeError: maximum recursion depth exceeded while calling a Python object\n```\n\nSome part of traceback has been removed to keep it short\n",
      "issue_closed_at": "2015-12-08T15:49:18Z",
      "base_commit": "41fc8f5a4dabd350f2f23a4aef53db728ca8ee0d",
      "changes": [
        {
          "file": "sympy/core/numbers.py",
          "type": "function",
          "name": "_eval_power",
          "class_name": "ImaginaryUnit",
          "code": "def _eval_power(self, expt):\n        \"\"\"\n        b is I = sqrt(-1)\n        e is symbolic object but not equal to 0, 1\n\n        I**r -> (-1)**(r/2) -> exp(r/2*Pi*I) -> sin(Pi*r/2) + cos(Pi*r/2)*I, r is decimal\n        I**0 mod 4 -> 1\n        I**1 mod 4 -> I\n        I**2 mod 4 -> -1\n        I**3 mod 4 -> -I\n        \"\"\"\n\n        if isinstance(expt, Number):\n            if isinstance(expt, Integer):\n                expt = expt.p % 4\n                if expt == 0:\n                    return S.One\n                if expt == 1:\n                    return S.ImaginaryUnit\n                if expt == 2:\n                    return -S.One\n                return -S.ImaginaryUnit\n            return (S.NegativeOne)**(expt*S.Half)\n        return"
        },
        {
          "file": "sympy/core/numbers.py",
          "type": "function",
          "name": "_eval_power",
          "class_name": "ImaginaryUnit",
          "code": "def _eval_power(self, expt):\n        \"\"\"\n        b is I = sqrt(-1)\n        e is symbolic object but not equal to 0, 1\n\n        I**r -> (-1)**(r/2) -> exp(r/2*Pi*I) -> sin(Pi*r/2) + cos(Pi*r/2)*I, r is decimal\n        I**0 mod 4 -> 1\n        I**1 mod 4 -> I\n        I**2 mod 4 -> -1\n        I**3 mod 4 -> -I\n        \"\"\"\n\n        if isinstance(expt, Number):\n            if isinstance(expt, Integer):\n                expt = expt.p % 4\n                if expt == 0:\n                    return S.One\n                if expt == 1:\n                    return S.ImaginaryUnit\n                if expt == 2:\n                    return -S.One\n                return -S.ImaginaryUnit\n            return (S.NegativeOne)**(expt*S.Half)\n        return"
        },
        {
          "file": "sympy/core/numbers.py",
          "type": "function",
          "name": "_eval_power",
          "class_name": "ImaginaryUnit",
          "code": "def _eval_power(self, expt):\n        \"\"\"\n        b is I = sqrt(-1)\n        e is symbolic object but not equal to 0, 1\n\n        I**r -> (-1)**(r/2) -> exp(r/2*Pi*I) -> sin(Pi*r/2) + cos(Pi*r/2)*I, r is decimal\n        I**0 mod 4 -> 1\n        I**1 mod 4 -> I\n        I**2 mod 4 -> -1\n        I**3 mod 4 -> -I\n        \"\"\"\n\n        if isinstance(expt, Number):\n            if isinstance(expt, Integer):\n                expt = expt.p % 4\n                if expt == 0:\n                    return S.One\n                if expt == 1:\n                    return S.ImaginaryUnit\n                if expt == 2:\n                    return -S.One\n                return -S.ImaginaryUnit\n            return (S.NegativeOne)**(expt*S.Half)\n        return"
        },
        {
          "file": "sympy/core/power.py",
          "type": "class",
          "name": "Pow",
          "code": "class Pow(Expr):\n    \"\"\"\n    Defines the expression x**y as \"x raised to a power y\"\n\n    Singleton definitions involving (0, 1, -1, oo, -oo):\n\n    +--------------+---------+-----------------------------------------------+\n    | expr         | value   | reason                                        |\n    +==============+=========+===============================================+\n    | z**0         | 1       | Although arguments over 0**0 exist, see [2].  |\n    +--------------+---------+-----------------------------------------------+\n    | z**1         | z       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-oo)**(-1)  | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-1)**-1     | -1      |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | S.Zero**-1   | zoo     | This is not strictly true, as 0**-1 may be    |\n    |              |         | undefined, but is convenient in some contexts |\n    |              |         | where the base is assumed to be positive.     |\n    +--------------+---------+-----------------------------------------------+\n    | 1**-1        | 1       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**-1       | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | 0**oo        | 0       | Because for all complex numbers z near        |\n    |              |         | 0, z**oo -> 0.                                |\n    +--------------+---------+-----------------------------------------------+\n    | 0**-oo       | zoo     | This is not strictly true, as 0**oo may be    |\n    |              |         | oscillating between positive and negative     |\n    |              |         | values or rotating in the complex plane.      |\n    |              |         | It is convenient, however, when the base      |\n    |              |         | is positive.                                  |\n    +--------------+---------+-----------------------------------------------+\n    | 1**oo        | nan     | Because there are various cases where         |\n    | 1**-oo       |         | lim(x(t),t)=1, lim(y(t),t)=oo (or -oo),       |\n    | 1**zoo       |         | but lim( x(t)**y(t), t) != 1.  See [3].       |\n    +--------------+---------+-----------------------------------------------+\n    | (-1)**oo     | nan     | Because of oscillations in the limit.         |\n    | (-1)**(-oo)  |         |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**oo       | oo      |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**-oo      | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-oo)**oo    | nan     |                                               |\n    | (-oo)**-oo   |         |                                               |\n    +--------------+---------+-----------------------------------------------+\n\n    Because symbolic computations are more flexible that floating point\n    calculations and we prefer to never return an incorrect answer,\n    we choose not to conform to all IEEE 754 conventions.  This helps\n    us avoid extra test-case code in the calculation of limits.\n\n    See Also\n    ========\n\n    sympy.core.numbers.Infinity\n    sympy.core.numbers.NegativeInfinity\n    sympy.core.numbers.NaN\n\n    References\n    ==========\n\n    .. [1] http://en.wikipedia.org/wiki/Exponentiation\n    .. [2] http://en.wikipedia.org/wiki/Exponentiation#Zero_to_the_power_of_zero\n    .. [3] http://en.wikipedia.org/wiki/Indeterminate_forms\n\n    \"\"\"\n    is_Pow = True\n\n    __slots__ = ['is_commutative']\n\n    @cacheit\n    def __new__(cls, b, e, evaluate=None):\n        if evaluate is None:\n            evaluate = global_evaluate[0]\n        from sympy.functions.elementary.exponential import exp_polar\n\n        b = _sympify(b)\n        e = _sympify(e)\n        if evaluate:\n            if e is S.Zero:\n                return S.One\n            elif e is S.One:\n                return b\n            # Only perform autosimplification if exponent or base is a Symbol or number\n            elif (b.is_Symbol or b.is_number) and (e.is_Symbol or e.is_number) and\\\n                e.is_integer and _coeff_isneg(b):\n                if e.is_even:\n                    b = -b\n                elif e.is_odd:\n                    return -Pow(-b, e)\n            if S.NaN in (b, e):  # XXX S.NaN**x -> S.NaN under assumption that x != 0\n                return S.NaN\n            elif b is S.One:\n                if abs(e).is_infinite:\n                    return S.NaN\n                return S.One\n            else:\n                # recognize base as E\n                if not e.is_Atom and b is not S.Exp1 and b.func is not exp_polar:\n                    from sympy import numer, denom, log, sign, im, factor_terms\n                    c, ex = factor_terms(e, sign=False).as_coeff_Mul()\n                    den = denom(ex)\n                    if den.func is log and den.args[0] == b:\n                        return S.Exp1**(c*numer(ex))\n                    elif den.is_Add:\n                        s = sign(im(b))\n                        if s.is_Number and s and den == \\\n                                log(-factor_terms(b, sign=False)) + s*S.ImaginaryUnit*S.Pi:\n                            return S.Exp1**(c*numer(ex))\n\n                obj = b._eval_power(e)\n                if obj is not None:\n                    return obj\n        obj = Expr.__new__(cls, b, e)\n        obj.is_commutative = (b.is_commutative and e.is_commutative)\n        return obj\n\n    @property\n    def base(self):\n        return self._args[0]\n\n    @property\n    def exp(self):\n        return self._args[1]\n\n    @classmethod\n    def class_key(cls):\n        return 3, 2, cls.__name__\n\n    def _eval_refine(self):\n        b, e = self.as_base_exp()\n        if e.is_integer and _coeff_isneg(b):\n            if e.is_even:\n                return Pow(-b, e)\n            elif e.is_odd:\n                return -Pow(-b, e)\n\n    def _eval_power(self, other):\n        from sympy import Abs, arg, exp, floor, im, log, re, sign, refine\n        b, e = self.as_base_exp()\n        if b is S.NaN:\n            return (b**e)**other  # let __new__ handle it\n\n        s = None\n        if other.is_integer:\n            s = 1\n        elif b.is_polar:  # e.g. exp_polar, besselj, var('p', polar=True)...\n            s = 1\n        elif e.is_real is not None:\n            # helper functions ===========================\n            def _half(e):\n                \"\"\"Return True if the exponent has a literal 2 as the\n                denominator, else None.\"\"\"\n                if getattr(e, 'q', None) == 2:\n                    return True\n                n, d = e.as_numer_denom()\n                if n.is_integer and d == 2:\n                    return True\n            def _n2(e):\n                \"\"\"Return ``e`` evaluated to a Number with 2 significant\n                digits, else None.\"\"\"\n                try:\n                    rv = e.evalf(2, strict=True)\n                    if rv.is_Number:\n                        return rv\n                except PrecisionExhausted:\n                    pass\n            # ===================================================\n            if e.is_real:\n                # we need _half(other) with constant floor or\n                # floor(S.Half - e*arg(b)/2/pi) == 0\n\n                # handle -1 as special case\n                if (e == -1) == True:\n                    # floor arg. is 1/2 + arg(b)/2/pi\n                    if _half(other):\n                        if b.is_negative is True:\n                            return S.NegativeOne**other*Pow(-b, e*other)\n                        if b.is_real is False:\n                            return Pow(b.conjugate()/Abs(b)**2, other)\n                elif e.is_even:\n                    if b.is_real:\n                        b = refine(abs(b))\n                    if b.is_imaginary:\n                        b = refine(abs(im(b)))*S.ImaginaryUnit\n\n                if (abs(e) < 1) == True or (e == 1) == True:\n                    s = 1  # floor = 0\n                elif b.is_nonnegative:\n                    s = 1  # floor = 0\n                elif re(b).is_nonnegative and (abs(e) < 2) == True:\n                    s = 1  # floor = 0\n                elif fuzzy_not(im(b).is_zero) and (abs(e) == 2) == True:\n                    s = 1  # floor = 0\n                elif _half(other):\n                    s = exp(2*S.Pi*S.ImaginaryUnit*other*floor(\n                        S.Half - e*arg(b)/(2*S.Pi)))\n                    if s.is_real and _n2(sign(s) - s) == 0:\n                        s = sign(s)\n                    else:\n                        s = None\n            else:\n                # e.is_real is False requires:\n                #     _half(other) with constant floor or\n                #     floor(S.Half - im(e*log(b))/2/pi) == 0\n                try:\n                    s = exp(2*S.ImaginaryUnit*S.Pi*other*\n                        floor(S.Half - im(e*log(b))/2/S.Pi))\n                    # be careful to test that s is -1 or 1 b/c sign(I) == I:\n                    # so check that s is real\n                    if s.is_real and _n2(sign(s) - s) == 0:\n                        s = sign(s)\n                    else:\n                        s = None\n                except PrecisionExhausted:\n                    s = None\n\n        if s is not None:\n            return s*Pow(b, e*other)\n\n    def _eval_is_even(self):\n        if self.exp.is_integer and self.exp.is_positive:\n            return self.base.is_even\n\n    def _eval_is_positive(self):\n        from sympy import log\n        if self.base == self.exp:\n            if self.base.is_nonnegative:\n                return True\n        elif self.base.is_positive:\n            if self.exp.is_real:\n                return True\n        elif self.base.is_negative:\n            if self.exp.is_even:\n                return True\n            if self.exp.is_odd:\n                return False\n        elif self.base.is_nonpositive:\n            if self.exp.is_odd:\n                return False\n        elif self.base.is_imaginary:\n            if self.exp.is_integer:\n                m = self.exp % 4\n                if m.is_zero:\n                    return True\n                if m.is_integer and m.is_zero is False:\n                    return False\n            if self.exp.is_imaginary:\n                return log(self.base).is_imaginary\n\n    def _eval_is_negative(self):\n        if self.base.is_negative:\n            if self.exp.is_odd:\n                return True\n            if self.exp.is_even:\n                return False\n        elif self.base.is_positive:\n            if self.exp.is_real:\n                return False\n        elif self.base.is_nonnegative:\n            if self.exp.is_nonnegative:\n                return False\n        elif self.base.is_nonpositive:\n            if self.exp.is_even:\n                return False\n        elif self.base.is_real:\n            if self.exp.is_even:\n                return False\n\n    def _eval_is_zero(self):\n        if self.base.is_zero:\n            if self.exp.is_positive:\n                return True\n            elif self.exp.is_nonpositive:\n                return False\n        elif self.base.is_zero is False:\n            if self.exp.is_finite:\n                return False\n            elif self.exp.is_infinite:\n                if (1 - abs(self.base)).is_positive:\n                    return self.exp.is_positive\n                elif (1 - abs(self.base)).is_negative:\n                    return self.exp.is_negative\n        else:\n            # when self.base.is_zero is None\n            return None\n\n    def _eval_is_integer(self):\n        b, e = self.args\n        if b.is_rational:\n            if b.is_integer is False and e.is_positive:\n                return False  # rat**nonneg\n        if b.is_integer and e.is_integer:\n            if b is S.NegativeOne:\n                return True\n            if e.is_nonnegative or e.is_positive:\n                return True\n        if b.is_integer and e.is_negative and (e.is_finite or e.is_integer):\n            if fuzzy_not((b - 1).is_zero) and fuzzy_not((b + 1).is_zero):\n                return False\n        if b.is_Number and e.is_Number:\n            check = self.func(*self.args)\n            return check.is_Integer\n\n    def _eval_is_real(self):\n        from sympy import arg, exp, log, Mul\n        real_b = self.base.is_real\n        if real_b is None:\n            if self.base.func == exp and self.base.args[0].is_imaginary:\n                return self.exp.is_imaginary\n            return\n        real_e = self.exp.is_real\n        if real_e is None:\n            return\n        if real_b and real_e:\n            if self.base.is_positive:\n                return True\n            elif self.base.is_nonnegative:\n                if self.exp.is_nonnegative:\n                    return True\n            else:\n                if self.exp.is_integer:\n                    return True\n                elif self.base.is_negative:\n                    if self.exp.is_Rational:\n                        return False\n        if real_e and self.exp.is_negative:\n            return Pow(self.base, -self.exp).is_real\n        im_b = self.base.is_imaginary\n        im_e = self.exp.is_imaginary\n        if im_b:\n            if self.exp.is_integer:\n                if self.exp.is_even:\n                    return True\n                elif self.exp.is_odd:\n                    return False\n            elif im_e and log(self.base).is_imaginary:\n                return True\n            elif self.exp.is_Add:\n                c, a = self.exp.as_coeff_Add()\n                if c and c.is_Integer:\n                    return Mul(\n                        self.base**c, self.base**a, evaluate=False).is_real\n            elif self.base in (-S.ImaginaryUnit, S.ImaginaryUnit):\n                if (self.exp/2).is_integer is False:\n                    return False\n        if real_b and im_e:\n            if self.base is S.NegativeOne:\n                return True\n            c = self.exp.coeff(S.ImaginaryUnit)\n            if c:\n                ok = (c*log(self.base)/S.Pi).is_Integer\n                if ok is not None:\n                    return ok\n\n        if real_b is False:  # we already know it's not imag\n            i = arg(self.base)*self.exp/S.Pi\n            return i.is_integer\n\n    def _eval_is_complex(self):\n        if all(a.is_complex for a in self.args):\n            return True\n\n    def _eval_is_imaginary(self):\n        from sympy import arg, log\n        if self.base.is_imaginary:\n            if self.exp.is_integer:\n                odd = self.exp.is_odd\n                if odd is not None:\n                    return odd\n                return\n\n        if self.exp.is_imaginary:\n            imlog = log(self.base).is_imaginary\n            if imlog is not None:\n                return False  # I**i -> real; (2*I)**i -> complex ==> not imaginary\n\n        if self.base.is_real and self.exp.is_real:\n            if self.base.is_positive:\n                return False\n            else:\n                rat = self.exp.is_rational\n                if not rat:\n                    return rat\n                if self.exp.is_integer:\n                    return False\n                else:\n                    half = (2*self.exp).is_integer\n                    if half:\n                        return self.base.is_negative\n                    return half\n\n        if self.base.is_real is False:  # we already know it's not imag\n            i = arg(self.base)*self.exp/S.Pi\n            return (2*i).is_odd\n\n    def _eval_is_odd(self):\n        if self.exp.is_integer:\n            if self.exp.is_positive:\n                return self.base.is_odd\n            elif self.exp.is_nonnegative and self.base.is_odd:\n                return True\n            elif self.base is S.NegativeOne:\n                return True\n\n    def _eval_is_finite(self):\n        if self.exp.is_negative:\n            if self.base.is_zero:\n                return False\n            if self.base.is_infinite:\n                return True\n        c1 = self.base.is_finite\n        if c1 is None:\n            return\n        c2 = self.exp.is_finite\n        if c2 is None:\n            return\n        if c1 and c2:\n            if self.exp.is_nonnegative or fuzzy_not(self.base.is_zero):\n                return True\n\n    def _eval_is_prime(self):\n        if self.exp == S.One:\n            return self.base.is_prime\n        if self.is_number:\n            return self.doit().is_prime\n\n        if self.is_integer and self.is_positive:\n            \"\"\"\n            a Power will be non-prime only if both base and exponent\n            are greater than 1\n            \"\"\"\n            if (self.base-1).is_positive or (self.exp-1).is_positive:\n                return False\n\n    def _eval_is_polar(self):\n        return self.base.is_polar\n\n    def _eval_subs(self, old, new):\n        from sympy import exp, log, Symbol\n        def _check(ct1, ct2, old):\n            \"\"\"Return bool, pow where, if bool is True, then the exponent of\n            Pow `old` will combine with `pow` so the substitution is valid,\n            otherwise bool will be False,\n\n            cti are the coefficient and terms of an exponent of self or old\n            In this _eval_subs routine a change like (b**(2*x)).subs(b**x, y)\n            will give y**2 since (b**x)**2 == b**(2*x); if that equality does\n            not hold then the substitution should not occur so `bool` will be\n            False.\n            \"\"\"\n            coeff1, terms1 = ct1\n            coeff2, terms2 = ct2\n            if terms1 == terms2:\n                pow = coeff1/coeff2\n                try:\n                    pow = as_int(pow)\n                    combines = True\n                except ValueError:\n                    combines = Pow._eval_power(\n                        Pow(*old.as_base_exp(), evaluate=False),\n                        pow) is not None\n                return combines, pow\n            return False, None\n\n        if old == self.base:\n            return new**self.exp._subs(old, new)\n\n        if old.func is self.func and self.base == old.base:\n            if self.exp.is_Add is False:\n                ct1 = self.exp.as_independent(Symbol, as_Add=False)\n                ct2 = old.exp.as_independent(Symbol, as_Add=False)\n                ok, pow = _check(ct1, ct2, old)\n                if ok:\n                    # issue 5180: (x**(6*y)).subs(x**(3*y),z)->z**2\n                    return self.func(new, pow)\n            else:  # b**(6*x+a).subs(b**(3*x), y) -> y**2 * b**a\n                # exp(exp(x) + exp(x**2)).subs(exp(exp(x)), w) -> w * exp(exp(x**2))\n                oarg = old.exp\n                new_l = []\n                o_al = []\n                ct2 = oarg.as_coeff_mul()\n                for a in self.exp.args:\n                    newa = a._subs(old, new)\n                    ct1 = newa.as_coeff_mul()\n                    ok, pow = _check(ct1, ct2, old)\n                    if ok:\n                        new_l.append(new**pow)\n                        continue\n                    o_al.append(newa)\n                if new_l:\n                    new_l.append(Pow(self.base, Add(*o_al), evaluate=False))\n                    return Mul(*new_l)\n\n        if old.func is exp and self.exp.is_real and self.base.is_positive:\n            ct1 = old.args[0].as_independent(Symbol, as_Add=False)\n            ct2 = (self.exp*log(self.base)).as_independent(\n                Symbol, as_Add=False)\n            ok, pow = _check(ct1, ct2, old)\n            if ok:\n                return self.func(new, pow)  # (2**x).subs(exp(x*log(2)), z) -> z\n\n    def as_base_exp(self):\n        \"\"\"Return base and exp of self.\n\n        If base is 1/Integer, then return Integer, -exp. If this extra\n        processing is not needed, the base and exp properties will\n        give the raw arguments\n\n        Examples\n        ========\n\n        >>> from sympy import Pow, S\n        >>> p = Pow(S.Half, 2, evaluate=False)\n        >>> p.as_base_exp()\n        (2, -2)\n        >>> p.args\n        (1/2, 2)\n\n        \"\"\"\n\n        b, e = self.args\n        if b.is_Rational and b.p == 1 and b.q != 1:\n            return Integer(b.q), -e\n        return b, e\n\n    def _eval_adjoint(self):\n        from sympy.functions.elementary.complexes import adjoint\n        i, p = self.exp.is_integer, self.base.is_positive\n        if i:\n            return adjoint(self.base)**self.exp\n        if p:\n            return self.base**adjoint(self.exp)\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return adjoint(expanded)\n\n    def _eval_conjugate(self):\n        from sympy.functions.elementary.complexes import conjugate as c\n        i, p = self.exp.is_integer, self.base.is_positive\n        if i:\n            return c(self.base)**self.exp\n        if p:\n            return self.base**c(self.exp)\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return c(expanded)\n\n    def _eval_transpose(self):\n        from sympy.functions.elementary.complexes import transpose\n        i, p = self.exp.is_integer, self.base.is_complex\n        if p:\n            return self.base**self.exp\n        if i:\n            return transpose(self.base)**self.exp\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return transpose(expanded)\n\n    def _eval_expand_power_exp(self, **hints):\n        \"\"\"a**(n+m) -> a**n*a**m\"\"\"\n        b = self.base\n        e = self.exp\n        if e.is_Add and e.is_commutative:\n            expr = []\n            for x in e.args:\n                expr.append(self.func(self.base, x))\n            return Mul(*expr)\n        return self.func(b, e)\n\n    def _eval_expand_power_base(self, **hints):\n        \"\"\"(a*b)**n -> a**n * b**n\"\"\"\n        force = hints.get('force', False)\n\n        b = self.base\n        e = self.exp\n        if not b.is_Mul:\n            return self\n\n        cargs, nc = b.args_cnc(split_1=False)\n\n        # expand each term - this is top-level-only\n        # expansion but we have to watch out for things\n        # that don't have an _eval_expand method\n        if nc:\n            nc = [i._eval_expand_power_base(**hints)\n                if hasattr(i, '_eval_expand_power_base') else i\n                for i in nc]\n\n            if e.is_Integer:\n                if e.is_positive:\n                    rv = Mul(*nc*e)\n                else:\n                    rv = 1/Mul(*nc*-e)\n                if cargs:\n                    rv *= Mul(*cargs)**e\n                return rv\n\n            if not cargs:\n                return self.func(Mul(*nc), e, evaluate=False)\n\n            nc = [Mul(*nc)]\n\n        # sift the commutative bases\n        def pred(x):\n            if x is S.ImaginaryUnit:\n                return S.ImaginaryUnit\n            polar = x.is_polar\n            if polar:\n                return True\n            if polar is None:\n                return fuzzy_bool(x.is_nonnegative)\n        sifted = sift(cargs, pred)\n        nonneg = sifted[True]\n        other = sifted[None]\n        neg = sifted[False]\n        imag = sifted[S.ImaginaryUnit]\n        if imag:\n            I = S.ImaginaryUnit\n            i = len(imag) % 4\n            if i == 0:\n                pass\n            elif i == 1:\n                other.append(I)\n            elif i == 2:\n                if neg:\n                    nonn = -neg.pop()\n                    if nonn is not S.One:\n                        nonneg.append(nonn)\n                else:\n                    neg.append(S.NegativeOne)\n            else:\n                if neg:\n                    nonn = -neg.pop()\n                    if nonn is not S.One:\n                        nonneg.append(nonn)\n                else:\n                    neg.append(S.NegativeOne)\n                other.append(I)\n            del imag\n\n        # bring out the bases that can be separated from the base\n\n        if force or e.is_integer:\n            # treat all commutatives the same and put nc in other\n            cargs = nonneg + neg + other\n            other = nc\n        else:\n            # this is just like what is happening automatically, except\n            # that now we are doing it for an arbitrary exponent for which\n            # no automatic expansion is done\n\n            assert not e.is_Integer\n\n            # handle negatives by making them all positive and putting\n            # the residual -1 in other\n            if len(neg) > 1:\n                o = S.One\n                if not other and neg[0].is_Number:\n                    o *= neg.pop(0)\n                if len(neg) % 2:\n                    o = -o\n                for n in neg:\n                    nonneg.append(-n)\n                if o is not S.One:\n                    other.append(o)\n            elif neg and other:\n                if neg[0].is_Number and neg[0] is not S.NegativeOne:\n                    other.append(S.NegativeOne)\n                    nonneg.append(-neg[0])\n                else:\n                    other.extend(neg)\n            else:\n                other.extend(neg)\n            del neg\n\n            cargs = nonneg\n            other += nc\n\n        rv = S.One\n        if cargs:\n            rv *= Mul(*[self.func(b, e, evaluate=False) for b in cargs])\n        if other:\n            rv *= self.func(Mul(*other), e, evaluate=False)\n        return rv\n\n    def _eval_expand_multinomial(self, **hints):\n        \"\"\"(a+b+..) ** n -> a**n + n*a**(n-1)*b + .., n is nonzero integer\"\"\"\n\n        base, exp = self.args\n        result = self\n\n        if exp.is_Rational and exp.p > 0 and base.is_Add:\n            if not exp.is_Integer:\n                n = Integer(exp.p // exp.q)\n\n                if not n:\n                    return result\n                else:\n                    radical, result = self.func(base, exp - n), []\n\n                    expanded_base_n = self.func(base, n)\n                    if expanded_base_n.is_Pow:\n                        expanded_base_n = \\\n                            expanded_base_n._eval_expand_multinomial()\n                    for term in Add.make_args(expanded_base_n):\n                        result.append(term*radical)\n\n                    return Add(*result)\n\n            n = int(exp)\n\n            if base.is_commutative:\n                order_terms, other_terms = [], []\n\n                for b in base.args:\n                    if b.is_Order:\n                        order_terms.append(b)\n                    else:\n                        other_terms.append(b)\n\n                if order_terms:\n                    # (f(x) + O(x^n))^m -> f(x)^m + m*f(x)^{m-1} *O(x^n)\n                    f = Add(*other_terms)\n                    o = Add(*order_terms)\n\n                    if n == 2:\n                        return expand_multinomial(f**n, deep=False) + n*f*o\n                    else:\n                        g = expand_multinomial(f**(n - 1), deep=False)\n                        return expand_mul(f*g, deep=False) + n*g*o\n\n                if base.is_number:\n                    # Efficiently expand expressions of the form (a + b*I)**n\n                    # where 'a' and 'b' are real numbers and 'n' is integer.\n                    a, b = base.as_real_imag()\n\n                    if a.is_Rational and b.is_Rational:\n                        if not a.is_Integer:\n                            if not b.is_Integer:\n                                k = self.func(a.q * b.q, n)\n                                a, b = a.p*b.q, a.q*b.p\n                            else:\n                                k = self.func(a.q, n)\n                                a, b = a.p, a.q*b\n                        elif not b.is_Integer:\n                            k = self.func(b.q, n)\n                            a, b = a*b.q, b.p\n                        else:\n                            k = 1\n\n                        a, b, c, d = int(a), int(b), 1, 0\n\n                        while n:\n                            if n & 1:\n                                c, d = a*c - b*d, b*c + a*d\n                                n -= 1\n                            a, b = a*a - b*b, 2*a*b\n                            n //= 2\n\n                        I = S.ImaginaryUnit\n\n                        if k == 1:\n                            return c + I*d\n                        else:\n                            return Integer(c)/k + I*d/k\n\n                p = other_terms\n                # (x+y)**3 -> x**3 + 3*x**2*y + 3*x*y**2 + y**3\n                # in this particular example:\n                # p = [x,y]; n = 3\n                # so now it's easy to get the correct result -- we get the\n                # coefficients first:\n                from sympy import multinomial_coefficients\n                from sympy.polys.polyutils import basic_from_dict\n                expansion_dict = multinomial_coefficients(len(p), n)\n                # in our example: {(3, 0): 1, (1, 2): 3, (0, 3): 1, (2, 1): 3}\n                # and now construct the expression.\n                return basic_from_dict(expansion_dict, *p)\n            else:\n                if n == 2:\n                    return Add(*[f*g for f in base.args for g in base.args])\n                else:\n                    multi = (base**(n - 1))._eval_expand_multinomial()\n                    if multi.is_Add:\n                        return Add(*[f*g for f in base.args\n                            for g in multi.args])\n                    else:\n                        # XXX can this ever happen if base was an Add?\n                        return Add(*[f*multi for f in base.args])\n        elif (exp.is_Rational and exp.p < 0 and base.is_Add and\n                abs(exp.p) > exp.q):\n            return 1 / self.func(base, -exp)._eval_expand_multinomial()\n        elif exp.is_Add and base.is_Number:\n            #  a + b      a  b\n            # n      --> n  n  , where n, a, b are Numbers\n\n            coeff, tail = S.One, S.Zero\n            for term in exp.args:\n                if term.is_Number:\n                    coeff *= self.func(base, term)\n                else:\n                    tail += term\n\n            return coeff * self.func(base, tail)\n        else:\n            return result\n\n    def as_real_imag(self, deep=True, **hints):\n        from sympy import atan2, cos, im, re, sin\n        from sympy.polys.polytools import poly\n\n        if self.exp.is_Integer:\n            exp = self.exp\n            re, im = self.base.as_real_imag(deep=deep)\n            if not im:\n                return self, S.Zero\n            a, b = symbols('a b', cls=Dummy)\n            if exp >= 0:\n                if re.is_Number and im.is_Number:\n                    # We can be more efficient in this case\n                    expr = expand_multinomial(self.base**exp)\n                    return expr.as_real_imag()\n\n                expr = poly(\n                    (a + b)**exp)  # a = re, b = im; expr = (a + b*I)**exp\n            else:\n                mag = re**2 + im**2\n                re, im = re/mag, -im/mag\n                if re.is_Number and im.is_Number:\n                    # We can be more efficient in this case\n                    expr = expand_multinomial((re + im*S.ImaginaryUnit)**-exp)\n                    return expr.as_real_imag()\n\n                expr = poly((a + b)**-exp)\n\n            # Terms with even b powers will be real\n            r = [i for i in expr.terms() if not i[0][1] % 2]\n            re_part = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n            # Terms with odd b powers will be imaginary\n            r = [i for i in expr.terms() if i[0][1] % 4 == 1]\n            im_part1 = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n            r = [i for i in expr.terms() if i[0][1] % 4 == 3]\n            im_part3 = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n\n            return (re_part.subs({a: re, b: S.ImaginaryUnit*im}),\n            im_part1.subs({a: re, b: im}) + im_part3.subs({a: re, b: -im}))\n\n        elif self.exp.is_Rational:\n            re, im = self.base.as_real_imag(deep=deep)\n\n            if im.is_zero and self.exp is S.Half:\n                if re.is_nonnegative:\n                    return self, S.Zero\n                if re.is_nonpositive:\n                    return S.Zero, (-self.base)**self.exp\n\n            # XXX: This is not totally correct since for x**(p/q) with\n            #      x being imaginary there are actually q roots, but\n            #      only a single one is returned from here.\n            r = self.func(self.func(re, 2) + self.func(im, 2), S.Half)\n            t = atan2(im, re)\n\n            rp, tp = self.func(r, self.exp), t*self.exp\n\n            return (rp*cos(tp), rp*sin(tp))\n        else:\n\n            if deep:\n                hints['complex'] = False\n\n                expanded = self.expand(deep, **hints)\n                if hints.get('ignore') == expanded:\n                    return None\n                else:\n                    return (re(expanded), im(expanded))\n            else:\n                return (re(self), im(self))\n\n    def _eval_derivative(self, s):\n        from sympy import log\n        dbase = self.base.diff(s)\n        dexp = self.exp.diff(s)\n        return self * (dexp * log(self.base) + dbase * self.exp/self.base)\n\n    def _eval_evalf(self, prec):\n        base, exp = self.as_base_exp()\n        base = base._evalf(prec)\n        if not exp.is_Integer:\n            exp = exp._evalf(prec)\n        if exp.is_negative and base.is_number and base.is_real is False:\n            base = base.conjugate() / (base * base.conjugate())._evalf(prec)\n            exp = -exp\n            return self.func(base, exp).expand()\n        return self.func(base, exp)\n\n    def _eval_is_polynomial(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return bool(self.base._eval_is_polynomial(syms) and\n                self.exp.is_Integer and (self.exp >= 0))\n        else:\n            return True\n\n    def _eval_is_rational(self):\n        p = self.func(*self.as_base_exp())  # in case it's unevaluated\n        if not p.is_Pow:\n            return p.is_rational\n        b, e = p.as_base_exp()\n        if e.is_Rational and b.is_Rational:\n            # we didn't check that e is not an Integer\n            # because Rational**Integer autosimplifies\n            return False\n        if e.is_integer:\n            if b.is_rational:\n                if fuzzy_not(b.is_zero) or e.is_nonnegative:\n                    return True\n                if b == e:  # always rational, even for 0**0\n                    return True\n            elif b.is_irrational:\n                return e.is_zero\n\n    def _eval_is_algebraic(self):\n        if self.base.is_zero or (self.base - 1).is_zero:\n            return True\n        elif self.exp.is_rational:\n            return self.base.is_algebraic\n        elif self.base.is_algebraic and self.exp.is_algebraic:\n            if ((fuzzy_not(self.base.is_zero)\n                and fuzzy_not((self.base - 1).is_zero))\n                or self.base.is_integer is False\n                or self.base.is_irrational):\n                return self.exp.is_rational\n\n    def _eval_is_rational_function(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return self.base._eval_is_rational_function(syms) and \\\n                self.exp.is_Integer\n        else:\n            return True\n\n    def _eval_is_algebraic_expr(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return self.base._eval_is_algebraic_expr(syms) and \\\n                self.exp.is_Rational\n        else:\n            return True\n\n    def as_numer_denom(self):\n        if not self.is_commutative:\n            return self, S.One\n        base, exp = self.as_base_exp()\n        n, d = base.as_numer_denom()\n        # this should be the same as ExpBase.as_numer_denom wrt\n        # exponent handling\n        neg_exp = exp.is_negative\n        if not neg_exp and not (-exp).is_negative:\n            neg_exp = _coeff_isneg(exp)\n        int_exp = exp.is_integer\n        # the denominator cannot be separated from the numerator if\n        # its sign is unknown unless the exponent is an integer, e.g.\n        # sqrt(a/b) != sqrt(a)/sqrt(b) when a=1 and b=-1. But if the\n        # denominator is negative the numerator and denominator can\n        # be negated and the denominator (now positive) separated.\n        if not (d.is_real or int_exp):\n            n = base\n            d = S.One\n        dnonpos = d.is_nonpositive\n        if dnonpos:\n            n, d = -n, -d\n        elif dnonpos is None and not int_exp:\n            n = base\n            d = S.One\n        if neg_exp:\n            n, d = d, n\n            exp = -exp\n        return self.func(n, exp), self.func(d, exp)\n\n    def matches(self, expr, repl_dict={}, old=False):\n        expr = _sympify(expr)\n\n        # special case, pattern = 1 and expr.exp can match to 0\n        if expr is S.One:\n            d = repl_dict.copy()\n            d = self.exp.matches(S.Zero, d)\n            if d is not None:\n                return d\n\n        # make sure the expression to be matched is an Expr\n        if not isinstance(expr, Expr):\n            return None\n\n        b, e = expr.as_base_exp()\n\n        # special case number\n        sb, se = self.as_base_exp()\n        if sb.is_Symbol and se.is_Integer and expr:\n            if e.is_rational:\n                return sb.matches(b**(e/se), repl_dict)\n            return sb.matches(expr**(1/se), repl_dict)\n\n        d = repl_dict.copy()\n        d = self.base.matches(b, d)\n        if d is None:\n            return None\n\n        d = self.exp.xreplace(d).matches(e, d)\n        if d is None:\n            return Expr.matches(self, expr, repl_dict)\n        return d\n\n    def _eval_nseries(self, x, n, logx):\n        # NOTE! This function is an important part of the gruntz algorithm\n        #       for computing limits. It has to return a generalized power\n        #       series with coefficients in C(log, log(x)). In more detail:\n        # It has to return an expression\n        #     c_0*x**e_0 + c_1*x**e_1 + ... (finitely many terms)\n        # where e_i are numbers (not necessarily integers) and c_i are\n        # expressions involving only numbers, the log function, and log(x).\n        from sympy import ceiling, collect, exp, log, O, Order, powsimp\n        b, e = self.args\n        if e.is_Integer:\n            if e > 0:\n                # positive integer powers are easy to expand, e.g.:\n                # sin(x)**4 = (x-x**3/3+...)**4 = ...\n                return expand_multinomial(self.func(b._eval_nseries(x, n=n,\n                    logx=logx), e), deep=False)\n            elif e is S.NegativeOne:\n                # this is also easy to expand using the formula:\n                # 1/(1 + x) = 1 - x + x**2 - x**3 ...\n                # so we need to rewrite base to the form \"1+x\"\n\n                nuse = n\n                cf = 1\n\n                try:\n                    ord = b.as_leading_term(x)\n                    cf = Order(ord, x).getn()\n                    if cf and cf.is_Number:\n                        nuse = n + 2*ceiling(cf)\n                    else:\n                        cf = 1\n                except NotImplementedError:\n                    pass\n\n                b_orig, prefactor = b, O(1, x)\n                while prefactor.is_Order:\n                    nuse += 1\n                    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\n                    prefactor = b.as_leading_term(x)\n\n                # express \"rest\" as: rest = 1 + k*x**l + ... + O(x**n)\n                rest = expand_mul((b - prefactor)/prefactor)\n\n                if rest.is_Order:\n                    return 1/prefactor + rest/prefactor + O(x**n, x)\n\n                k, l = rest.leadterm(x)\n                if l.is_Rational and l > 0:\n                    pass\n                elif l.is_number and l > 0:\n                    l = l.evalf()\n                elif l == 0:\n                    k = k.simplify()\n                    if k == 0:\n                        # if prefactor == w**4 + x**2*w**4 + 2*x*w**4, we need to\n                        # factor the w**4 out using collect:\n                        return 1/collect(prefactor, x)\n                    else:\n                        raise NotImplementedError()\n                else:\n                    raise NotImplementedError()\n\n                if cf < 0:\n                    cf = S.One/abs(cf)\n\n                try:\n                    dn = Order(1/prefactor, x).getn()\n                    if dn and dn < 0:\n                        pass\n                    else:\n                        dn = 0\n                except NotImplementedError:\n                    dn = 0\n\n                terms = [1/prefactor]\n                for m in range(1, ceiling((n - dn)/l*cf)):\n                    new_term = terms[-1]*(-rest)\n                    if new_term.is_Pow:\n                        new_term = new_term._eval_expand_multinomial(\n                            deep=False)\n                    else:\n                        new_term = expand_mul(new_term, deep=False)\n                    terms.append(new_term)\n                terms.append(O(x**n, x))\n                return powsimp(Add(*terms), deep=True, combine='exp')\n            else:\n                # negative powers are rewritten to the cases above, for\n                # example:\n                # sin(x)**(-4) = 1/( sin(x)**4) = ...\n                # and expand the denominator:\n                nuse, denominator = n, O(1, x)\n                while denominator.is_Order:\n                    denominator = (b**(-e))._eval_nseries(x, n=nuse, logx=logx)\n                    nuse += 1\n                if 1/denominator == self:\n                    return self\n                # now we have a type 1/f(x), that we know how to expand\n                return (1/denominator)._eval_nseries(x, n=n, logx=logx)\n\n        if e.has(Symbol):\n            return exp(e*log(b))._eval_nseries(x, n=n, logx=logx)\n\n        # see if the base is as simple as possible\n        bx = b\n        while bx.is_Pow and bx.exp.is_Rational:\n            bx = bx.base\n        if bx == x:\n            return self\n\n        # work for b(x)**e where e is not an Integer and does not contain x\n        # and hopefully has no other symbols\n\n        def e2int(e):\n            \"\"\"return the integer value (if possible) of e and a\n            flag indicating whether it is bounded or not.\"\"\"\n            n = e.limit(x, 0)\n            infinite = n.is_infinite\n            if not infinite:\n                # XXX was int or floor intended? int used to behave like floor\n                # so int(-Rational(1, 2)) returned -1 rather than int's 0\n                try:\n                    n = int(n)\n                except TypeError:\n                    #well, the n is something more complicated (like 1+log(2))\n                    try:\n                        n = int(n.evalf()) + 1  # XXX why is 1 being added?\n                    except TypeError:\n                        pass  # hope that base allows this to be resolved\n                n = _sympify(n)\n            return n, infinite\n\n        order = O(x**n, x)\n        ei, infinite = e2int(e)\n        b0 = b.limit(x, 0)\n        if infinite and (b0 is S.One or b0.has(Symbol)):\n            # XXX what order\n            if b0 is S.One:\n                resid = (b - 1)\n                if resid.is_positive:\n                    return S.Infinity\n                elif resid.is_negative:\n                    return S.Zero\n                raise ValueError('cannot determine sign of %s' % resid)\n\n            return b0**ei\n\n        if (b0 is S.Zero or b0.is_infinite):\n            if infinite is not False:\n                return b0**e  # XXX what order\n\n            if not ei.is_number:  # if not, how will we proceed?\n                raise ValueError(\n                    'expecting numerical exponent but got %s' % ei)\n\n            nuse = n - ei\n\n            if e.is_real and e.is_positive:\n                lt = b.as_leading_term(x)\n\n                # Try to correct nuse (= m) guess from:\n                # (lt + rest + O(x**m))**e =\n                # lt**e*(1 + rest/lt + O(x**m)/lt)**e =\n                # lt**e + ... + O(x**m)*lt**(e - 1) = ... + O(x**n)\n                try:\n                    cf = Order(lt, x).getn()\n                    nuse = ceiling(n - cf*(e - 1))\n                except NotImplementedError:\n                    pass\n\n            bs = b._eval_nseries(x, n=nuse, logx=logx)\n            terms = bs.removeO()\n            if terms.is_Add:\n                bs = terms\n                lt = terms.as_leading_term(x)\n\n                # bs -> lt + rest -> lt*(1 + (bs/lt - 1))\n                return ((self.func(lt, e) * self.func((bs/lt).expand(), e).nseries(\n                    x, n=nuse, logx=logx)).expand() + order)\n\n            if bs.is_Add:\n                from sympy import O\n                # So, bs + O() == terms\n                c = Dummy('c')\n                res = []\n                for arg in bs.args:\n                    if arg.is_Order:\n                        arg = c*arg.expr\n                    res.append(arg)\n                bs = Add(*res)\n                rv = (bs**e).series(x).subs(c, O(1, x))\n                rv += order\n                return rv\n\n            rv = bs**e\n            if terms != bs:\n                rv += order\n            return rv\n\n        # either b0 is bounded but neither 1 nor 0 or e is infinite\n        # b -> b0 + (b-b0) -> b0 * (1 + (b/b0-1))\n        o2 = order*(b0**-e)\n        z = (b/b0 - 1)\n        o = O(z, x)\n        if o is S.Zero or o2 is S.Zero:\n            infinite = True\n        else:\n            if o.expr.is_number:\n                e2 = log(o2.expr*x)/log(x)\n            else:\n                e2 = log(o2.expr)/log(o.expr)\n            n, infinite = e2int(e2)\n        if infinite:\n            # requested accuracy gives infinite series,\n            # order is probably non-polynomial e.g. O(exp(-1/x), x).\n            r = 1 + z\n        else:\n            l = []\n            g = None\n            for i in range(n + 2):\n                g = self._taylor_term(i, z, g)\n                g = g.nseries(x, n=n, logx=logx)\n                l.append(g)\n            r = Add(*l)\n        return expand_mul(r*b0**e) + order\n\n    def _eval_as_leading_term(self, x):\n        from sympy import exp, log\n        if not self.exp.has(x):\n            return self.func(self.base.as_leading_term(x), self.exp)\n        return exp(self.exp * log(self.base)).as_leading_term(x)\n\n    @cacheit\n    def _taylor_term(self, n, x, *previous_terms): # of (1+x)**e\n        from sympy import binomial\n        return binomial(self.exp, n) * self.func(x, n)\n\n    def _sage_(self):\n        return self.args[0]._sage_()**self.args[1]._sage_()\n\n    def as_content_primitive(self, radical=False):\n        \"\"\"Return the tuple (R, self/R) where R is the positive Rational\n        extracted from self.\n\n        Examples\n        ========\n\n        >>> from sympy import sqrt\n        >>> sqrt(4 + 4*sqrt(2)).as_content_primitive()\n        (2, sqrt(1 + sqrt(2)))\n        >>> sqrt(3 + 3*sqrt(2)).as_content_primitive()\n        (1, sqrt(3)*sqrt(1 + sqrt(2)))\n\n        >>> from sympy import expand_power_base, powsimp, Mul\n        >>> from sympy.abc import x, y\n\n        >>> ((2*x + 2)**2).as_content_primitive()\n        (4, (x + 1)**2)\n        >>> (4**((1 + y)/2)).as_content_primitive()\n        (2, 4**(y/2))\n        >>> (3**((1 + y)/2)).as_content_primitive()\n        (1, 3**((y + 1)/2))\n        >>> (3**((5 + y)/2)).as_content_primitive()\n        (9, 3**((y + 1)/2))\n        >>> eq = 3**(2 + 2*x)\n        >>> powsimp(eq) == eq\n        True\n        >>> eq.as_content_primitive()\n        (9, 3**(2*x))\n        >>> powsimp(Mul(*_))\n        3**(2*x + 2)\n\n        >>> eq = (2 + 2*x)**y\n        >>> s = expand_power_base(eq); s.is_Mul, s\n        (False, (2*x + 2)**y)\n        >>> eq.as_content_primitive()\n        (1, (2*(x + 1))**y)\n        >>> s = expand_power_base(_[1]); s.is_Mul, s\n        (True, 2**y*(x + 1)**y)\n\n        See docstring of Expr.as_content_primitive for more examples.\n        \"\"\"\n\n        b, e = self.as_base_exp()\n        b = _keep_coeff(*b.as_content_primitive(radical=radical))\n        ce, pe = e.as_content_primitive(radical=radical)\n        if b.is_Rational:\n            #e\n            #= ce*pe\n            #= ce*(h + t)\n            #= ce*h + ce*t\n            #=> self\n            #= b**(ce*h)*b**(ce*t)\n            #= b**(cehp/cehq)*b**(ce*t)\n            #= b**(iceh+r/cehq)*b**(ce*t)\n            #= b**(iceh)*b**(r/cehq)*b**(ce*t)\n            #= b**(iceh)*b**(ce*t + r/cehq)\n            h, t = pe.as_coeff_Add()\n            if h.is_Rational:\n                ceh = ce*h\n                c = self.func(b, ceh)\n                r = S.Zero\n                if not c.is_Rational:\n                    iceh, r = divmod(ceh.p, ceh.q)\n                    c = self.func(b, iceh)\n                return c, self.func(b, _keep_coeff(ce, t + r/ce/ceh.q))\n        e = _keep_coeff(ce, pe)\n        # b**e = (h*t)**e = h**e*t**e = c*m*t**e\n        if e.is_Rational and b.is_Mul:\n            h, t = b.as_content_primitive(radical=radical)  # h is positive\n            c, m = self.func(h, e).as_coeff_Mul()  # so c is positive\n            m, me = m.as_base_exp()\n            if m is S.One or me == e:  # probably always true\n                # return the following, not return c, m*Pow(t, e)\n                # which would change Pow into Mul; we let sympy\n                # decide what to do by using the unevaluated Mul, e.g\n                # should it stay as sqrt(2 + 2*sqrt(5)) or become\n                # sqrt(2)*sqrt(1 + sqrt(5))\n                return c, self.func(_keep_coeff(m, t), e)\n        return S.One, self.func(b, e)\n\n    def is_constant(self, *wrt, **flags):\n        expr = self\n        if flags.get('simplify', True):\n            expr = expr.simplify()\n        b, e = expr.as_base_exp()\n        bz = b.equals(0)\n        if bz:  # recalculate with assumptions in case it's unevaluated\n            new = b**e\n            if new != expr:\n                return new.is_constant()\n        econ = e.is_constant(*wrt)\n        bcon = b.is_constant(*wrt)\n        if bcon:\n            if econ:\n                return True\n            bz = b.equals(0)\n            if bz is False:\n                return False\n        elif bcon is None:\n            return None\n\n        return e.equals(0)\n\n    def _eval_difference_delta(self, n, step):\n        b, e = self.args\n        if e.has(n) and not b.has(n):\n            new_e = e.subs(n, n + step)\n            return (b**(new_e - e) - 1) * self"
        },
        {
          "file": "sympy/core/power.py",
          "type": "class",
          "name": "Pow",
          "code": "class Pow(Expr):\n    \"\"\"\n    Defines the expression x**y as \"x raised to a power y\"\n\n    Singleton definitions involving (0, 1, -1, oo, -oo):\n\n    +--------------+---------+-----------------------------------------------+\n    | expr         | value   | reason                                        |\n    +==============+=========+===============================================+\n    | z**0         | 1       | Although arguments over 0**0 exist, see [2].  |\n    +--------------+---------+-----------------------------------------------+\n    | z**1         | z       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-oo)**(-1)  | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-1)**-1     | -1      |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | S.Zero**-1   | zoo     | This is not strictly true, as 0**-1 may be    |\n    |              |         | undefined, but is convenient in some contexts |\n    |              |         | where the base is assumed to be positive.     |\n    +--------------+---------+-----------------------------------------------+\n    | 1**-1        | 1       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**-1       | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | 0**oo        | 0       | Because for all complex numbers z near        |\n    |              |         | 0, z**oo -> 0.                                |\n    +--------------+---------+-----------------------------------------------+\n    | 0**-oo       | zoo     | This is not strictly true, as 0**oo may be    |\n    |              |         | oscillating between positive and negative     |\n    |              |         | values or rotating in the complex plane.      |\n    |              |         | It is convenient, however, when the base      |\n    |              |         | is positive.                                  |\n    +--------------+---------+-----------------------------------------------+\n    | 1**oo        | nan     | Because there are various cases where         |\n    | 1**-oo       |         | lim(x(t),t)=1, lim(y(t),t)=oo (or -oo),       |\n    | 1**zoo       |         | but lim( x(t)**y(t), t) != 1.  See [3].       |\n    +--------------+---------+-----------------------------------------------+\n    | (-1)**oo     | nan     | Because of oscillations in the limit.         |\n    | (-1)**(-oo)  |         |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**oo       | oo      |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | oo**-oo      | 0       |                                               |\n    +--------------+---------+-----------------------------------------------+\n    | (-oo)**oo    | nan     |                                               |\n    | (-oo)**-oo   |         |                                               |\n    +--------------+---------+-----------------------------------------------+\n\n    Because symbolic computations are more flexible that floating point\n    calculations and we prefer to never return an incorrect answer,\n    we choose not to conform to all IEEE 754 conventions.  This helps\n    us avoid extra test-case code in the calculation of limits.\n\n    See Also\n    ========\n\n    sympy.core.numbers.Infinity\n    sympy.core.numbers.NegativeInfinity\n    sympy.core.numbers.NaN\n\n    References\n    ==========\n\n    .. [1] http://en.wikipedia.org/wiki/Exponentiation\n    .. [2] http://en.wikipedia.org/wiki/Exponentiation#Zero_to_the_power_of_zero\n    .. [3] http://en.wikipedia.org/wiki/Indeterminate_forms\n\n    \"\"\"\n    is_Pow = True\n\n    __slots__ = ['is_commutative']\n\n    @cacheit\n    def __new__(cls, b, e, evaluate=None):\n        if evaluate is None:\n            evaluate = global_evaluate[0]\n        from sympy.functions.elementary.exponential import exp_polar\n\n        b = _sympify(b)\n        e = _sympify(e)\n        if evaluate:\n            if e is S.Zero:\n                return S.One\n            elif e is S.One:\n                return b\n            # Only perform autosimplification if exponent or base is a Symbol or number\n            elif (b.is_Symbol or b.is_number) and (e.is_Symbol or e.is_number) and\\\n                e.is_integer and _coeff_isneg(b):\n                if e.is_even:\n                    b = -b\n                elif e.is_odd:\n                    return -Pow(-b, e)\n            if S.NaN in (b, e):  # XXX S.NaN**x -> S.NaN under assumption that x != 0\n                return S.NaN\n            elif b is S.One:\n                if abs(e).is_infinite:\n                    return S.NaN\n                return S.One\n            else:\n                # recognize base as E\n                if not e.is_Atom and b is not S.Exp1 and b.func is not exp_polar:\n                    from sympy import numer, denom, log, sign, im, factor_terms\n                    c, ex = factor_terms(e, sign=False).as_coeff_Mul()\n                    den = denom(ex)\n                    if den.func is log and den.args[0] == b:\n                        return S.Exp1**(c*numer(ex))\n                    elif den.is_Add:\n                        s = sign(im(b))\n                        if s.is_Number and s and den == \\\n                                log(-factor_terms(b, sign=False)) + s*S.ImaginaryUnit*S.Pi:\n                            return S.Exp1**(c*numer(ex))\n\n                obj = b._eval_power(e)\n                if obj is not None:\n                    return obj\n        obj = Expr.__new__(cls, b, e)\n        obj.is_commutative = (b.is_commutative and e.is_commutative)\n        return obj\n\n    @property\n    def base(self):\n        return self._args[0]\n\n    @property\n    def exp(self):\n        return self._args[1]\n\n    @classmethod\n    def class_key(cls):\n        return 3, 2, cls.__name__\n\n    def _eval_refine(self):\n        b, e = self.as_base_exp()\n        if e.is_integer and _coeff_isneg(b):\n            if e.is_even:\n                return Pow(-b, e)\n            elif e.is_odd:\n                return -Pow(-b, e)\n\n    def _eval_power(self, other):\n        from sympy import Abs, arg, exp, floor, im, log, re, sign, refine\n        b, e = self.as_base_exp()\n        if b is S.NaN:\n            return (b**e)**other  # let __new__ handle it\n\n        s = None\n        if other.is_integer:\n            s = 1\n        elif b.is_polar:  # e.g. exp_polar, besselj, var('p', polar=True)...\n            s = 1\n        elif e.is_real is not None:\n            # helper functions ===========================\n            def _half(e):\n                \"\"\"Return True if the exponent has a literal 2 as the\n                denominator, else None.\"\"\"\n                if getattr(e, 'q', None) == 2:\n                    return True\n                n, d = e.as_numer_denom()\n                if n.is_integer and d == 2:\n                    return True\n            def _n2(e):\n                \"\"\"Return ``e`` evaluated to a Number with 2 significant\n                digits, else None.\"\"\"\n                try:\n                    rv = e.evalf(2, strict=True)\n                    if rv.is_Number:\n                        return rv\n                except PrecisionExhausted:\n                    pass\n            # ===================================================\n            if e.is_real:\n                # we need _half(other) with constant floor or\n                # floor(S.Half - e*arg(b)/2/pi) == 0\n\n                # handle -1 as special case\n                if (e == -1) == True:\n                    # floor arg. is 1/2 + arg(b)/2/pi\n                    if _half(other):\n                        if b.is_negative is True:\n                            return S.NegativeOne**other*Pow(-b, e*other)\n                        if b.is_real is False:\n                            return Pow(b.conjugate()/Abs(b)**2, other)\n                elif e.is_even:\n                    if b.is_real:\n                        b = refine(abs(b))\n                    if b.is_imaginary:\n                        b = refine(abs(im(b)))*S.ImaginaryUnit\n\n                if (abs(e) < 1) == True or (e == 1) == True:\n                    s = 1  # floor = 0\n                elif b.is_nonnegative:\n                    s = 1  # floor = 0\n                elif re(b).is_nonnegative and (abs(e) < 2) == True:\n                    s = 1  # floor = 0\n                elif fuzzy_not(im(b).is_zero) and (abs(e) == 2) == True:\n                    s = 1  # floor = 0\n                elif _half(other):\n                    s = exp(2*S.Pi*S.ImaginaryUnit*other*floor(\n                        S.Half - e*arg(b)/(2*S.Pi)))\n                    if s.is_real and _n2(sign(s) - s) == 0:\n                        s = sign(s)\n                    else:\n                        s = None\n            else:\n                # e.is_real is False requires:\n                #     _half(other) with constant floor or\n                #     floor(S.Half - im(e*log(b))/2/pi) == 0\n                try:\n                    s = exp(2*S.ImaginaryUnit*S.Pi*other*\n                        floor(S.Half - im(e*log(b))/2/S.Pi))\n                    # be careful to test that s is -1 or 1 b/c sign(I) == I:\n                    # so check that s is real\n                    if s.is_real and _n2(sign(s) - s) == 0:\n                        s = sign(s)\n                    else:\n                        s = None\n                except PrecisionExhausted:\n                    s = None\n\n        if s is not None:\n            return s*Pow(b, e*other)\n\n    def _eval_is_even(self):\n        if self.exp.is_integer and self.exp.is_positive:\n            return self.base.is_even\n\n    def _eval_is_positive(self):\n        from sympy import log\n        if self.base == self.exp:\n            if self.base.is_nonnegative:\n                return True\n        elif self.base.is_positive:\n            if self.exp.is_real:\n                return True\n        elif self.base.is_negative:\n            if self.exp.is_even:\n                return True\n            if self.exp.is_odd:\n                return False\n        elif self.base.is_nonpositive:\n            if self.exp.is_odd:\n                return False\n        elif self.base.is_imaginary:\n            if self.exp.is_integer:\n                m = self.exp % 4\n                if m.is_zero:\n                    return True\n                if m.is_integer and m.is_zero is False:\n                    return False\n            if self.exp.is_imaginary:\n                return log(self.base).is_imaginary\n\n    def _eval_is_negative(self):\n        if self.base.is_negative:\n            if self.exp.is_odd:\n                return True\n            if self.exp.is_even:\n                return False\n        elif self.base.is_positive:\n            if self.exp.is_real:\n                return False\n        elif self.base.is_nonnegative:\n            if self.exp.is_nonnegative:\n                return False\n        elif self.base.is_nonpositive:\n            if self.exp.is_even:\n                return False\n        elif self.base.is_real:\n            if self.exp.is_even:\n                return False\n\n    def _eval_is_zero(self):\n        if self.base.is_zero:\n            if self.exp.is_positive:\n                return True\n            elif self.exp.is_nonpositive:\n                return False\n        elif self.base.is_zero is False:\n            if self.exp.is_finite:\n                return False\n            elif self.exp.is_infinite:\n                if (1 - abs(self.base)).is_positive:\n                    return self.exp.is_positive\n                elif (1 - abs(self.base)).is_negative:\n                    return self.exp.is_negative\n        else:\n            # when self.base.is_zero is None\n            return None\n\n    def _eval_is_integer(self):\n        b, e = self.args\n        if b.is_rational:\n            if b.is_integer is False and e.is_positive:\n                return False  # rat**nonneg\n        if b.is_integer and e.is_integer:\n            if b is S.NegativeOne:\n                return True\n            if e.is_nonnegative or e.is_positive:\n                return True\n        if b.is_integer and e.is_negative and (e.is_finite or e.is_integer):\n            if fuzzy_not((b - 1).is_zero) and fuzzy_not((b + 1).is_zero):\n                return False\n        if b.is_Number and e.is_Number:\n            check = self.func(*self.args)\n            return check.is_Integer\n\n    def _eval_is_real(self):\n        from sympy import arg, exp, log, Mul\n        real_b = self.base.is_real\n        if real_b is None:\n            if self.base.func == exp and self.base.args[0].is_imaginary:\n                return self.exp.is_imaginary\n            return\n        real_e = self.exp.is_real\n        if real_e is None:\n            return\n        if real_b and real_e:\n            if self.base.is_positive:\n                return True\n            elif self.base.is_nonnegative:\n                if self.exp.is_nonnegative:\n                    return True\n            else:\n                if self.exp.is_integer:\n                    return True\n                elif self.base.is_negative:\n                    if self.exp.is_Rational:\n                        return False\n        if real_e and self.exp.is_negative:\n            return Pow(self.base, -self.exp).is_real\n        im_b = self.base.is_imaginary\n        im_e = self.exp.is_imaginary\n        if im_b:\n            if self.exp.is_integer:\n                if self.exp.is_even:\n                    return True\n                elif self.exp.is_odd:\n                    return False\n            elif im_e and log(self.base).is_imaginary:\n                return True\n            elif self.exp.is_Add:\n                c, a = self.exp.as_coeff_Add()\n                if c and c.is_Integer:\n                    return Mul(\n                        self.base**c, self.base**a, evaluate=False).is_real\n            elif self.base in (-S.ImaginaryUnit, S.ImaginaryUnit):\n                if (self.exp/2).is_integer is False:\n                    return False\n        if real_b and im_e:\n            if self.base is S.NegativeOne:\n                return True\n            c = self.exp.coeff(S.ImaginaryUnit)\n            if c:\n                ok = (c*log(self.base)/S.Pi).is_Integer\n                if ok is not None:\n                    return ok\n\n        if real_b is False:  # we already know it's not imag\n            i = arg(self.base)*self.exp/S.Pi\n            return i.is_integer\n\n    def _eval_is_complex(self):\n        if all(a.is_complex for a in self.args):\n            return True\n\n    def _eval_is_imaginary(self):\n        from sympy import arg, log\n        if self.base.is_imaginary:\n            if self.exp.is_integer:\n                odd = self.exp.is_odd\n                if odd is not None:\n                    return odd\n                return\n\n        if self.exp.is_imaginary:\n            imlog = log(self.base).is_imaginary\n            if imlog is not None:\n                return False  # I**i -> real; (2*I)**i -> complex ==> not imaginary\n\n        if self.base.is_real and self.exp.is_real:\n            if self.base.is_positive:\n                return False\n            else:\n                rat = self.exp.is_rational\n                if not rat:\n                    return rat\n                if self.exp.is_integer:\n                    return False\n                else:\n                    half = (2*self.exp).is_integer\n                    if half:\n                        return self.base.is_negative\n                    return half\n\n        if self.base.is_real is False:  # we already know it's not imag\n            i = arg(self.base)*self.exp/S.Pi\n            return (2*i).is_odd\n\n    def _eval_is_odd(self):\n        if self.exp.is_integer:\n            if self.exp.is_positive:\n                return self.base.is_odd\n            elif self.exp.is_nonnegative and self.base.is_odd:\n                return True\n            elif self.base is S.NegativeOne:\n                return True\n\n    def _eval_is_finite(self):\n        if self.exp.is_negative:\n            if self.base.is_zero:\n                return False\n            if self.base.is_infinite:\n                return True\n        c1 = self.base.is_finite\n        if c1 is None:\n            return\n        c2 = self.exp.is_finite\n        if c2 is None:\n            return\n        if c1 and c2:\n            if self.exp.is_nonnegative or fuzzy_not(self.base.is_zero):\n                return True\n\n    def _eval_is_prime(self):\n        if self.exp == S.One:\n            return self.base.is_prime\n        if self.is_number:\n            return self.doit().is_prime\n\n        if self.is_integer and self.is_positive:\n            \"\"\"\n            a Power will be non-prime only if both base and exponent\n            are greater than 1\n            \"\"\"\n            if (self.base-1).is_positive or (self.exp-1).is_positive:\n                return False\n\n    def _eval_is_polar(self):\n        return self.base.is_polar\n\n    def _eval_subs(self, old, new):\n        from sympy import exp, log, Symbol\n        def _check(ct1, ct2, old):\n            \"\"\"Return bool, pow where, if bool is True, then the exponent of\n            Pow `old` will combine with `pow` so the substitution is valid,\n            otherwise bool will be False,\n\n            cti are the coefficient and terms of an exponent of self or old\n            In this _eval_subs routine a change like (b**(2*x)).subs(b**x, y)\n            will give y**2 since (b**x)**2 == b**(2*x); if that equality does\n            not hold then the substitution should not occur so `bool` will be\n            False.\n            \"\"\"\n            coeff1, terms1 = ct1\n            coeff2, terms2 = ct2\n            if terms1 == terms2:\n                pow = coeff1/coeff2\n                try:\n                    pow = as_int(pow)\n                    combines = True\n                except ValueError:\n                    combines = Pow._eval_power(\n                        Pow(*old.as_base_exp(), evaluate=False),\n                        pow) is not None\n                return combines, pow\n            return False, None\n\n        if old == self.base:\n            return new**self.exp._subs(old, new)\n\n        if old.func is self.func and self.base == old.base:\n            if self.exp.is_Add is False:\n                ct1 = self.exp.as_independent(Symbol, as_Add=False)\n                ct2 = old.exp.as_independent(Symbol, as_Add=False)\n                ok, pow = _check(ct1, ct2, old)\n                if ok:\n                    # issue 5180: (x**(6*y)).subs(x**(3*y),z)->z**2\n                    return self.func(new, pow)\n            else:  # b**(6*x+a).subs(b**(3*x), y) -> y**2 * b**a\n                # exp(exp(x) + exp(x**2)).subs(exp(exp(x)), w) -> w * exp(exp(x**2))\n                oarg = old.exp\n                new_l = []\n                o_al = []\n                ct2 = oarg.as_coeff_mul()\n                for a in self.exp.args:\n                    newa = a._subs(old, new)\n                    ct1 = newa.as_coeff_mul()\n                    ok, pow = _check(ct1, ct2, old)\n                    if ok:\n                        new_l.append(new**pow)\n                        continue\n                    o_al.append(newa)\n                if new_l:\n                    new_l.append(Pow(self.base, Add(*o_al), evaluate=False))\n                    return Mul(*new_l)\n\n        if old.func is exp and self.exp.is_real and self.base.is_positive:\n            ct1 = old.args[0].as_independent(Symbol, as_Add=False)\n            ct2 = (self.exp*log(self.base)).as_independent(\n                Symbol, as_Add=False)\n            ok, pow = _check(ct1, ct2, old)\n            if ok:\n                return self.func(new, pow)  # (2**x).subs(exp(x*log(2)), z) -> z\n\n    def as_base_exp(self):\n        \"\"\"Return base and exp of self.\n\n        If base is 1/Integer, then return Integer, -exp. If this extra\n        processing is not needed, the base and exp properties will\n        give the raw arguments\n\n        Examples\n        ========\n\n        >>> from sympy import Pow, S\n        >>> p = Pow(S.Half, 2, evaluate=False)\n        >>> p.as_base_exp()\n        (2, -2)\n        >>> p.args\n        (1/2, 2)\n\n        \"\"\"\n\n        b, e = self.args\n        if b.is_Rational and b.p == 1 and b.q != 1:\n            return Integer(b.q), -e\n        return b, e\n\n    def _eval_adjoint(self):\n        from sympy.functions.elementary.complexes import adjoint\n        i, p = self.exp.is_integer, self.base.is_positive\n        if i:\n            return adjoint(self.base)**self.exp\n        if p:\n            return self.base**adjoint(self.exp)\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return adjoint(expanded)\n\n    def _eval_conjugate(self):\n        from sympy.functions.elementary.complexes import conjugate as c\n        i, p = self.exp.is_integer, self.base.is_positive\n        if i:\n            return c(self.base)**self.exp\n        if p:\n            return self.base**c(self.exp)\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return c(expanded)\n\n    def _eval_transpose(self):\n        from sympy.functions.elementary.complexes import transpose\n        i, p = self.exp.is_integer, self.base.is_complex\n        if p:\n            return self.base**self.exp\n        if i:\n            return transpose(self.base)**self.exp\n        if i is False and p is False:\n            expanded = expand_complex(self)\n            if expanded != self:\n                return transpose(expanded)\n\n    def _eval_expand_power_exp(self, **hints):\n        \"\"\"a**(n+m) -> a**n*a**m\"\"\"\n        b = self.base\n        e = self.exp\n        if e.is_Add and e.is_commutative:\n            expr = []\n            for x in e.args:\n                expr.append(self.func(self.base, x))\n            return Mul(*expr)\n        return self.func(b, e)\n\n    def _eval_expand_power_base(self, **hints):\n        \"\"\"(a*b)**n -> a**n * b**n\"\"\"\n        force = hints.get('force', False)\n\n        b = self.base\n        e = self.exp\n        if not b.is_Mul:\n            return self\n\n        cargs, nc = b.args_cnc(split_1=False)\n\n        # expand each term - this is top-level-only\n        # expansion but we have to watch out for things\n        # that don't have an _eval_expand method\n        if nc:\n            nc = [i._eval_expand_power_base(**hints)\n                if hasattr(i, '_eval_expand_power_base') else i\n                for i in nc]\n\n            if e.is_Integer:\n                if e.is_positive:\n                    rv = Mul(*nc*e)\n                else:\n                    rv = 1/Mul(*nc*-e)\n                if cargs:\n                    rv *= Mul(*cargs)**e\n                return rv\n\n            if not cargs:\n                return self.func(Mul(*nc), e, evaluate=False)\n\n            nc = [Mul(*nc)]\n\n        # sift the commutative bases\n        def pred(x):\n            if x is S.ImaginaryUnit:\n                return S.ImaginaryUnit\n            polar = x.is_polar\n            if polar:\n                return True\n            if polar is None:\n                return fuzzy_bool(x.is_nonnegative)\n        sifted = sift(cargs, pred)\n        nonneg = sifted[True]\n        other = sifted[None]\n        neg = sifted[False]\n        imag = sifted[S.ImaginaryUnit]\n        if imag:\n            I = S.ImaginaryUnit\n            i = len(imag) % 4\n            if i == 0:\n                pass\n            elif i == 1:\n                other.append(I)\n            elif i == 2:\n                if neg:\n                    nonn = -neg.pop()\n                    if nonn is not S.One:\n                        nonneg.append(nonn)\n                else:\n                    neg.append(S.NegativeOne)\n            else:\n                if neg:\n                    nonn = -neg.pop()\n                    if nonn is not S.One:\n                        nonneg.append(nonn)\n                else:\n                    neg.append(S.NegativeOne)\n                other.append(I)\n            del imag\n\n        # bring out the bases that can be separated from the base\n\n        if force or e.is_integer:\n            # treat all commutatives the same and put nc in other\n            cargs = nonneg + neg + other\n            other = nc\n        else:\n            # this is just like what is happening automatically, except\n            # that now we are doing it for an arbitrary exponent for which\n            # no automatic expansion is done\n\n            assert not e.is_Integer\n\n            # handle negatives by making them all positive and putting\n            # the residual -1 in other\n            if len(neg) > 1:\n                o = S.One\n                if not other and neg[0].is_Number:\n                    o *= neg.pop(0)\n                if len(neg) % 2:\n                    o = -o\n                for n in neg:\n                    nonneg.append(-n)\n                if o is not S.One:\n                    other.append(o)\n            elif neg and other:\n                if neg[0].is_Number and neg[0] is not S.NegativeOne:\n                    other.append(S.NegativeOne)\n                    nonneg.append(-neg[0])\n                else:\n                    other.extend(neg)\n            else:\n                other.extend(neg)\n            del neg\n\n            cargs = nonneg\n            other += nc\n\n        rv = S.One\n        if cargs:\n            rv *= Mul(*[self.func(b, e, evaluate=False) for b in cargs])\n        if other:\n            rv *= self.func(Mul(*other), e, evaluate=False)\n        return rv\n\n    def _eval_expand_multinomial(self, **hints):\n        \"\"\"(a+b+..) ** n -> a**n + n*a**(n-1)*b + .., n is nonzero integer\"\"\"\n\n        base, exp = self.args\n        result = self\n\n        if exp.is_Rational and exp.p > 0 and base.is_Add:\n            if not exp.is_Integer:\n                n = Integer(exp.p // exp.q)\n\n                if not n:\n                    return result\n                else:\n                    radical, result = self.func(base, exp - n), []\n\n                    expanded_base_n = self.func(base, n)\n                    if expanded_base_n.is_Pow:\n                        expanded_base_n = \\\n                            expanded_base_n._eval_expand_multinomial()\n                    for term in Add.make_args(expanded_base_n):\n                        result.append(term*radical)\n\n                    return Add(*result)\n\n            n = int(exp)\n\n            if base.is_commutative:\n                order_terms, other_terms = [], []\n\n                for b in base.args:\n                    if b.is_Order:\n                        order_terms.append(b)\n                    else:\n                        other_terms.append(b)\n\n                if order_terms:\n                    # (f(x) + O(x^n))^m -> f(x)^m + m*f(x)^{m-1} *O(x^n)\n                    f = Add(*other_terms)\n                    o = Add(*order_terms)\n\n                    if n == 2:\n                        return expand_multinomial(f**n, deep=False) + n*f*o\n                    else:\n                        g = expand_multinomial(f**(n - 1), deep=False)\n                        return expand_mul(f*g, deep=False) + n*g*o\n\n                if base.is_number:\n                    # Efficiently expand expressions of the form (a + b*I)**n\n                    # where 'a' and 'b' are real numbers and 'n' is integer.\n                    a, b = base.as_real_imag()\n\n                    if a.is_Rational and b.is_Rational:\n                        if not a.is_Integer:\n                            if not b.is_Integer:\n                                k = self.func(a.q * b.q, n)\n                                a, b = a.p*b.q, a.q*b.p\n                            else:\n                                k = self.func(a.q, n)\n                                a, b = a.p, a.q*b\n                        elif not b.is_Integer:\n                            k = self.func(b.q, n)\n                            a, b = a*b.q, b.p\n                        else:\n                            k = 1\n\n                        a, b, c, d = int(a), int(b), 1, 0\n\n                        while n:\n                            if n & 1:\n                                c, d = a*c - b*d, b*c + a*d\n                                n -= 1\n                            a, b = a*a - b*b, 2*a*b\n                            n //= 2\n\n                        I = S.ImaginaryUnit\n\n                        if k == 1:\n                            return c + I*d\n                        else:\n                            return Integer(c)/k + I*d/k\n\n                p = other_terms\n                # (x+y)**3 -> x**3 + 3*x**2*y + 3*x*y**2 + y**3\n                # in this particular example:\n                # p = [x,y]; n = 3\n                # so now it's easy to get the correct result -- we get the\n                # coefficients first:\n                from sympy import multinomial_coefficients\n                from sympy.polys.polyutils import basic_from_dict\n                expansion_dict = multinomial_coefficients(len(p), n)\n                # in our example: {(3, 0): 1, (1, 2): 3, (0, 3): 1, (2, 1): 3}\n                # and now construct the expression.\n                return basic_from_dict(expansion_dict, *p)\n            else:\n                if n == 2:\n                    return Add(*[f*g for f in base.args for g in base.args])\n                else:\n                    multi = (base**(n - 1))._eval_expand_multinomial()\n                    if multi.is_Add:\n                        return Add(*[f*g for f in base.args\n                            for g in multi.args])\n                    else:\n                        # XXX can this ever happen if base was an Add?\n                        return Add(*[f*multi for f in base.args])\n        elif (exp.is_Rational and exp.p < 0 and base.is_Add and\n                abs(exp.p) > exp.q):\n            return 1 / self.func(base, -exp)._eval_expand_multinomial()\n        elif exp.is_Add and base.is_Number:\n            #  a + b      a  b\n            # n      --> n  n  , where n, a, b are Numbers\n\n            coeff, tail = S.One, S.Zero\n            for term in exp.args:\n                if term.is_Number:\n                    coeff *= self.func(base, term)\n                else:\n                    tail += term\n\n            return coeff * self.func(base, tail)\n        else:\n            return result\n\n    def as_real_imag(self, deep=True, **hints):\n        from sympy import atan2, cos, im, re, sin\n        from sympy.polys.polytools import poly\n\n        if self.exp.is_Integer:\n            exp = self.exp\n            re, im = self.base.as_real_imag(deep=deep)\n            if not im:\n                return self, S.Zero\n            a, b = symbols('a b', cls=Dummy)\n            if exp >= 0:\n                if re.is_Number and im.is_Number:\n                    # We can be more efficient in this case\n                    expr = expand_multinomial(self.base**exp)\n                    return expr.as_real_imag()\n\n                expr = poly(\n                    (a + b)**exp)  # a = re, b = im; expr = (a + b*I)**exp\n            else:\n                mag = re**2 + im**2\n                re, im = re/mag, -im/mag\n                if re.is_Number and im.is_Number:\n                    # We can be more efficient in this case\n                    expr = expand_multinomial((re + im*S.ImaginaryUnit)**-exp)\n                    return expr.as_real_imag()\n\n                expr = poly((a + b)**-exp)\n\n            # Terms with even b powers will be real\n            r = [i for i in expr.terms() if not i[0][1] % 2]\n            re_part = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n            # Terms with odd b powers will be imaginary\n            r = [i for i in expr.terms() if i[0][1] % 4 == 1]\n            im_part1 = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n            r = [i for i in expr.terms() if i[0][1] % 4 == 3]\n            im_part3 = Add(*[cc*a**aa*b**bb for (aa, bb), cc in r])\n\n            return (re_part.subs({a: re, b: S.ImaginaryUnit*im}),\n            im_part1.subs({a: re, b: im}) + im_part3.subs({a: re, b: -im}))\n\n        elif self.exp.is_Rational:\n            re, im = self.base.as_real_imag(deep=deep)\n\n            if im.is_zero and self.exp is S.Half:\n                if re.is_nonnegative:\n                    return self, S.Zero\n                if re.is_nonpositive:\n                    return S.Zero, (-self.base)**self.exp\n\n            # XXX: This is not totally correct since for x**(p/q) with\n            #      x being imaginary there are actually q roots, but\n            #      only a single one is returned from here.\n            r = self.func(self.func(re, 2) + self.func(im, 2), S.Half)\n            t = atan2(im, re)\n\n            rp, tp = self.func(r, self.exp), t*self.exp\n\n            return (rp*cos(tp), rp*sin(tp))\n        else:\n\n            if deep:\n                hints['complex'] = False\n\n                expanded = self.expand(deep, **hints)\n                if hints.get('ignore') == expanded:\n                    return None\n                else:\n                    return (re(expanded), im(expanded))\n            else:\n                return (re(self), im(self))\n\n    def _eval_derivative(self, s):\n        from sympy import log\n        dbase = self.base.diff(s)\n        dexp = self.exp.diff(s)\n        return self * (dexp * log(self.base) + dbase * self.exp/self.base)\n\n    def _eval_evalf(self, prec):\n        base, exp = self.as_base_exp()\n        base = base._evalf(prec)\n        if not exp.is_Integer:\n            exp = exp._evalf(prec)\n        if exp.is_negative and base.is_number and base.is_real is False:\n            base = base.conjugate() / (base * base.conjugate())._evalf(prec)\n            exp = -exp\n            return self.func(base, exp).expand()\n        return self.func(base, exp)\n\n    def _eval_is_polynomial(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return bool(self.base._eval_is_polynomial(syms) and\n                self.exp.is_Integer and (self.exp >= 0))\n        else:\n            return True\n\n    def _eval_is_rational(self):\n        p = self.func(*self.as_base_exp())  # in case it's unevaluated\n        if not p.is_Pow:\n            return p.is_rational\n        b, e = p.as_base_exp()\n        if e.is_Rational and b.is_Rational:\n            # we didn't check that e is not an Integer\n            # because Rational**Integer autosimplifies\n            return False\n        if e.is_integer:\n            if b.is_rational:\n                if fuzzy_not(b.is_zero) or e.is_nonnegative:\n                    return True\n                if b == e:  # always rational, even for 0**0\n                    return True\n            elif b.is_irrational:\n                return e.is_zero\n\n    def _eval_is_algebraic(self):\n        if self.base.is_zero or (self.base - 1).is_zero:\n            return True\n        elif self.exp.is_rational:\n            return self.base.is_algebraic\n        elif self.base.is_algebraic and self.exp.is_algebraic:\n            if ((fuzzy_not(self.base.is_zero)\n                and fuzzy_not((self.base - 1).is_zero))\n                or self.base.is_integer is False\n                or self.base.is_irrational):\n                return self.exp.is_rational\n\n    def _eval_is_rational_function(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return self.base._eval_is_rational_function(syms) and \\\n                self.exp.is_Integer\n        else:\n            return True\n\n    def _eval_is_algebraic_expr(self, syms):\n        if self.exp.has(*syms):\n            return False\n\n        if self.base.has(*syms):\n            return self.base._eval_is_algebraic_expr(syms) and \\\n                self.exp.is_Rational\n        else:\n            return True\n\n    def as_numer_denom(self):\n        if not self.is_commutative:\n            return self, S.One\n        base, exp = self.as_base_exp()\n        n, d = base.as_numer_denom()\n        # this should be the same as ExpBase.as_numer_denom wrt\n        # exponent handling\n        neg_exp = exp.is_negative\n        if not neg_exp and not (-exp).is_negative:\n            neg_exp = _coeff_isneg(exp)\n        int_exp = exp.is_integer\n        # the denominator cannot be separated from the numerator if\n        # its sign is unknown unless the exponent is an integer, e.g.\n        # sqrt(a/b) != sqrt(a)/sqrt(b) when a=1 and b=-1. But if the\n        # denominator is negative the numerator and denominator can\n        # be negated and the denominator (now positive) separated.\n        if not (d.is_real or int_exp):\n            n = base\n            d = S.One\n        dnonpos = d.is_nonpositive\n        if dnonpos:\n            n, d = -n, -d\n        elif dnonpos is None and not int_exp:\n            n = base\n            d = S.One\n        if neg_exp:\n            n, d = d, n\n            exp = -exp\n        return self.func(n, exp), self.func(d, exp)\n\n    def matches(self, expr, repl_dict={}, old=False):\n        expr = _sympify(expr)\n\n        # special case, pattern = 1 and expr.exp can match to 0\n        if expr is S.One:\n            d = repl_dict.copy()\n            d = self.exp.matches(S.Zero, d)\n            if d is not None:\n                return d\n\n        # make sure the expression to be matched is an Expr\n        if not isinstance(expr, Expr):\n            return None\n\n        b, e = expr.as_base_exp()\n\n        # special case number\n        sb, se = self.as_base_exp()\n        if sb.is_Symbol and se.is_Integer and expr:\n            if e.is_rational:\n                return sb.matches(b**(e/se), repl_dict)\n            return sb.matches(expr**(1/se), repl_dict)\n\n        d = repl_dict.copy()\n        d = self.base.matches(b, d)\n        if d is None:\n            return None\n\n        d = self.exp.xreplace(d).matches(e, d)\n        if d is None:\n            return Expr.matches(self, expr, repl_dict)\n        return d\n\n    def _eval_nseries(self, x, n, logx):\n        # NOTE! This function is an important part of the gruntz algorithm\n        #       for computing limits. It has to return a generalized power\n        #       series with coefficients in C(log, log(x)). In more detail:\n        # It has to return an expression\n        #     c_0*x**e_0 + c_1*x**e_1 + ... (finitely many terms)\n        # where e_i are numbers (not necessarily integers) and c_i are\n        # expressions involving only numbers, the log function, and log(x).\n        from sympy import ceiling, collect, exp, log, O, Order, powsimp\n        b, e = self.args\n        if e.is_Integer:\n            if e > 0:\n                # positive integer powers are easy to expand, e.g.:\n                # sin(x)**4 = (x-x**3/3+...)**4 = ...\n                return expand_multinomial(self.func(b._eval_nseries(x, n=n,\n                    logx=logx), e), deep=False)\n            elif e is S.NegativeOne:\n                # this is also easy to expand using the formula:\n                # 1/(1 + x) = 1 - x + x**2 - x**3 ...\n                # so we need to rewrite base to the form \"1+x\"\n\n                nuse = n\n                cf = 1\n\n                try:\n                    ord = b.as_leading_term(x)\n                    cf = Order(ord, x).getn()\n                    if cf and cf.is_Number:\n                        nuse = n + 2*ceiling(cf)\n                    else:\n                        cf = 1\n                except NotImplementedError:\n                    pass\n\n                b_orig, prefactor = b, O(1, x)\n                while prefactor.is_Order:\n                    nuse += 1\n                    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\n                    prefactor = b.as_leading_term(x)\n\n                # express \"rest\" as: rest = 1 + k*x**l + ... + O(x**n)\n                rest = expand_mul((b - prefactor)/prefactor)\n\n                if rest.is_Order:\n                    return 1/prefactor + rest/prefactor + O(x**n, x)\n\n                k, l = rest.leadterm(x)\n                if l.is_Rational and l > 0:\n                    pass\n                elif l.is_number and l > 0:\n                    l = l.evalf()\n                elif l == 0:\n                    k = k.simplify()\n                    if k == 0:\n                        # if prefactor == w**4 + x**2*w**4 + 2*x*w**4, we need to\n                        # factor the w**4 out using collect:\n                        return 1/collect(prefactor, x)\n                    else:\n                        raise NotImplementedError()\n                else:\n                    raise NotImplementedError()\n\n                if cf < 0:\n                    cf = S.One/abs(cf)\n\n                try:\n                    dn = Order(1/prefactor, x).getn()\n                    if dn and dn < 0:\n                        pass\n                    else:\n                        dn = 0\n                except NotImplementedError:\n                    dn = 0\n\n                terms = [1/prefactor]\n                for m in range(1, ceiling((n - dn)/l*cf)):\n                    new_term = terms[-1]*(-rest)\n                    if new_term.is_Pow:\n                        new_term = new_term._eval_expand_multinomial(\n                            deep=False)\n                    else:\n                        new_term = expand_mul(new_term, deep=False)\n                    terms.append(new_term)\n                terms.append(O(x**n, x))\n                return powsimp(Add(*terms), deep=True, combine='exp')\n            else:\n                # negative powers are rewritten to the cases above, for\n                # example:\n                # sin(x)**(-4) = 1/( sin(x)**4) = ...\n                # and expand the denominator:\n                nuse, denominator = n, O(1, x)\n                while denominator.is_Order:\n                    denominator = (b**(-e))._eval_nseries(x, n=nuse, logx=logx)\n                    nuse += 1\n                if 1/denominator == self:\n                    return self\n                # now we have a type 1/f(x), that we know how to expand\n                return (1/denominator)._eval_nseries(x, n=n, logx=logx)\n\n        if e.has(Symbol):\n            return exp(e*log(b))._eval_nseries(x, n=n, logx=logx)\n\n        # see if the base is as simple as possible\n        bx = b\n        while bx.is_Pow and bx.exp.is_Rational:\n            bx = bx.base\n        if bx == x:\n            return self\n\n        # work for b(x)**e where e is not an Integer and does not contain x\n        # and hopefully has no other symbols\n\n        def e2int(e):\n            \"\"\"return the integer value (if possible) of e and a\n            flag indicating whether it is bounded or not.\"\"\"\n            n = e.limit(x, 0)\n            infinite = n.is_infinite\n            if not infinite:\n                # XXX was int or floor intended? int used to behave like floor\n                # so int(-Rational(1, 2)) returned -1 rather than int's 0\n                try:\n                    n = int(n)\n                except TypeError:\n                    #well, the n is something more complicated (like 1+log(2))\n                    try:\n                        n = int(n.evalf()) + 1  # XXX why is 1 being added?\n                    except TypeError:\n                        pass  # hope that base allows this to be resolved\n                n = _sympify(n)\n            return n, infinite\n\n        order = O(x**n, x)\n        ei, infinite = e2int(e)\n        b0 = b.limit(x, 0)\n        if infinite and (b0 is S.One or b0.has(Symbol)):\n            # XXX what order\n            if b0 is S.One:\n                resid = (b - 1)\n                if resid.is_positive:\n                    return S.Infinity\n                elif resid.is_negative:\n                    return S.Zero\n                raise ValueError('cannot determine sign of %s' % resid)\n\n            return b0**ei\n\n        if (b0 is S.Zero or b0.is_infinite):\n            if infinite is not False:\n                return b0**e  # XXX what order\n\n            if not ei.is_number:  # if not, how will we proceed?\n                raise ValueError(\n                    'expecting numerical exponent but got %s' % ei)\n\n            nuse = n - ei\n\n            if e.is_real and e.is_positive:\n                lt = b.as_leading_term(x)\n\n                # Try to correct nuse (= m) guess from:\n                # (lt + rest + O(x**m))**e =\n                # lt**e*(1 + rest/lt + O(x**m)/lt)**e =\n                # lt**e + ... + O(x**m)*lt**(e - 1) = ... + O(x**n)\n                try:\n                    cf = Order(lt, x).getn()\n                    nuse = ceiling(n - cf*(e - 1))\n                except NotImplementedError:\n                    pass\n\n            bs = b._eval_nseries(x, n=nuse, logx=logx)\n            terms = bs.removeO()\n            if terms.is_Add:\n                bs = terms\n                lt = terms.as_leading_term(x)\n\n                # bs -> lt + rest -> lt*(1 + (bs/lt - 1))\n                return ((self.func(lt, e) * self.func((bs/lt).expand(), e).nseries(\n                    x, n=nuse, logx=logx)).expand() + order)\n\n            if bs.is_Add:\n                from sympy import O\n                # So, bs + O() == terms\n                c = Dummy('c')\n                res = []\n                for arg in bs.args:\n                    if arg.is_Order:\n                        arg = c*arg.expr\n                    res.append(arg)\n                bs = Add(*res)\n                rv = (bs**e).series(x).subs(c, O(1, x))\n                rv += order\n                return rv\n\n            rv = bs**e\n            if terms != bs:\n                rv += order\n            return rv\n\n        # either b0 is bounded but neither 1 nor 0 or e is infinite\n        # b -> b0 + (b-b0) -> b0 * (1 + (b/b0-1))\n        o2 = order*(b0**-e)\n        z = (b/b0 - 1)\n        o = O(z, x)\n        if o is S.Zero or o2 is S.Zero:\n            infinite = True\n        else:\n            if o.expr.is_number:\n                e2 = log(o2.expr*x)/log(x)\n            else:\n                e2 = log(o2.expr)/log(o.expr)\n            n, infinite = e2int(e2)\n        if infinite:\n            # requested accuracy gives infinite series,\n            # order is probably non-polynomial e.g. O(exp(-1/x), x).\n            r = 1 + z\n        else:\n            l = []\n            g = None\n            for i in range(n + 2):\n                g = self._taylor_term(i, z, g)\n                g = g.nseries(x, n=n, logx=logx)\n                l.append(g)\n            r = Add(*l)\n        return expand_mul(r*b0**e) + order\n\n    def _eval_as_leading_term(self, x):\n        from sympy import exp, log\n        if not self.exp.has(x):\n            return self.func(self.base.as_leading_term(x), self.exp)\n        return exp(self.exp * log(self.base)).as_leading_term(x)\n\n    @cacheit\n    def _taylor_term(self, n, x, *previous_terms): # of (1+x)**e\n        from sympy import binomial\n        return binomial(self.exp, n) * self.func(x, n)\n\n    def _sage_(self):\n        return self.args[0]._sage_()**self.args[1]._sage_()\n\n    def as_content_primitive(self, radical=False):\n        \"\"\"Return the tuple (R, self/R) where R is the positive Rational\n        extracted from self.\n\n        Examples\n        ========\n\n        >>> from sympy import sqrt\n        >>> sqrt(4 + 4*sqrt(2)).as_content_primitive()\n        (2, sqrt(1 + sqrt(2)))\n        >>> sqrt(3 + 3*sqrt(2)).as_content_primitive()\n        (1, sqrt(3)*sqrt(1 + sqrt(2)))\n\n        >>> from sympy import expand_power_base, powsimp, Mul\n        >>> from sympy.abc import x, y\n\n        >>> ((2*x + 2)**2).as_content_primitive()\n        (4, (x + 1)**2)\n        >>> (4**((1 + y)/2)).as_content_primitive()\n        (2, 4**(y/2))\n        >>> (3**((1 + y)/2)).as_content_primitive()\n        (1, 3**((y + 1)/2))\n        >>> (3**((5 + y)/2)).as_content_primitive()\n        (9, 3**((y + 1)/2))\n        >>> eq = 3**(2 + 2*x)\n        >>> powsimp(eq) == eq\n        True\n        >>> eq.as_content_primitive()\n        (9, 3**(2*x))\n        >>> powsimp(Mul(*_))\n        3**(2*x + 2)\n\n        >>> eq = (2 + 2*x)**y\n        >>> s = expand_power_base(eq); s.is_Mul, s\n        (False, (2*x + 2)**y)\n        >>> eq.as_content_primitive()\n        (1, (2*(x + 1))**y)\n        >>> s = expand_power_base(_[1]); s.is_Mul, s\n        (True, 2**y*(x + 1)**y)\n\n        See docstring of Expr.as_content_primitive for more examples.\n        \"\"\"\n\n        b, e = self.as_base_exp()\n        b = _keep_coeff(*b.as_content_primitive(radical=radical))\n        ce, pe = e.as_content_primitive(radical=radical)\n        if b.is_Rational:\n            #e\n            #= ce*pe\n            #= ce*(h + t)\n            #= ce*h + ce*t\n            #=> self\n            #= b**(ce*h)*b**(ce*t)\n            #= b**(cehp/cehq)*b**(ce*t)\n            #= b**(iceh+r/cehq)*b**(ce*t)\n            #= b**(iceh)*b**(r/cehq)*b**(ce*t)\n            #= b**(iceh)*b**(ce*t + r/cehq)\n            h, t = pe.as_coeff_Add()\n            if h.is_Rational:\n                ceh = ce*h\n                c = self.func(b, ceh)\n                r = S.Zero\n                if not c.is_Rational:\n                    iceh, r = divmod(ceh.p, ceh.q)\n                    c = self.func(b, iceh)\n                return c, self.func(b, _keep_coeff(ce, t + r/ce/ceh.q))\n        e = _keep_coeff(ce, pe)\n        # b**e = (h*t)**e = h**e*t**e = c*m*t**e\n        if e.is_Rational and b.is_Mul:\n            h, t = b.as_content_primitive(radical=radical)  # h is positive\n            c, m = self.func(h, e).as_coeff_Mul()  # so c is positive\n            m, me = m.as_base_exp()\n            if m is S.One or me == e:  # probably always true\n                # return the following, not return c, m*Pow(t, e)\n                # which would change Pow into Mul; we let sympy\n                # decide what to do by using the unevaluated Mul, e.g\n                # should it stay as sqrt(2 + 2*sqrt(5)) or become\n                # sqrt(2)*sqrt(1 + sqrt(5))\n                return c, self.func(_keep_coeff(m, t), e)\n        return S.One, self.func(b, e)\n\n    def is_constant(self, *wrt, **flags):\n        expr = self\n        if flags.get('simplify', True):\n            expr = expr.simplify()\n        b, e = expr.as_base_exp()\n        bz = b.equals(0)\n        if bz:  # recalculate with assumptions in case it's unevaluated\n            new = b**e\n            if new != expr:\n                return new.is_constant()\n        econ = e.is_constant(*wrt)\n        bcon = b.is_constant(*wrt)\n        if bcon:\n            if econ:\n                return True\n            bz = b.equals(0)\n            if bz is False:\n                return False\n        elif bcon is None:\n            return None\n\n        return e.equals(0)\n\n    def _eval_difference_delta(self, n, step):\n        b, e = self.args\n        if e.has(n) and not b.has(n):\n            new_e = e.subs(n, n + step)\n            return (b**(new_e - e) - 1) * self"
        }
      ]
    },
    {
      "pr_number": 8044,
      "pr_title": "simplify Mul._eval_is_negative routine",
      "pr_body": "",
      "issue_id": 8008,
      "issue_title": "Test failure in meijerint after merging #7920",
      "issue_body": "More detailed discussion can be found at the bottom of #7920.\n\nThis fails in 2.7 - 100% reproducible on my machine\n\n``` bash\nPYTHONHASHSEED=730299569 bin/test sympy/integrals/tests/test_meijerint.py -k test_meijerint --seed 68924065\n============================= test process starts =============================\nexecutable:         /home/ptb/miniconda3/envs/py27/bin/python  (2.7.8-final-0) [CPython]\narchitecture:       64-bit\ncache:              yes\nground types:       python \nrandom seed:        68924065\nhash randomization: on (PYTHONHASHSEED=730299569)\n\nsympy/integrals/tests/test_meijerint.py[2] .E                            [FAIL]\n\n_______________________________________________________________________________\n___________ sympy/integrals/tests/test_meijerint.py:test_meijerint ____________\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/tests/test_meijerint.py\", line 148, in test_meijerint\n    assert expand(meijerint_definite(exp(x), x, 0, I)[0]) == exp(I) - 1\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1795, in meijerint_definite\n    res = _meijerint_definite_2(f, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1852, in _meijerint_definite_2\n    res = _meijerint_definite_3(g, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1864, in _meijerint_definite_3\n    res = _meijerint_definite_4(f, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1944, in _meijerint_definite_4\n    return _my_unpolarify(hyperexpand(res)), cond\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2482, in hyperexpand\n    return f.replace(hyper, do_replace).replace(meijerg, do_meijer)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/basic.py\", line 1351, in replace\n    rv = bottom_up(self, rec_replace, atoms=True)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 4077, in bottom_up\n    for a in rv.args])\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 4080, in bottom_up\n    rv = F(rv)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/basic.py\", line 1336, in rec_replace\n    new = _value(expr, result)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/basic.py\", line 1280, in <lambda>\n    _value = lambda expr, result: value(*expr.args)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2479, in do_meijer\n    allow_hyper, rewrite=rewrite)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2367, in _meijergexpand\n    slater1, cond1 = do_slater(func.an, func.bm, func.ap, func.bq, z, z0)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2303, in do_slater\n    t, premult, bh, rewrite=None)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/hyperexpand.py\", line 2068, in _hyperexpand\n    return powdenest(r, polar=True).replace(hyper, hyperexpand_special)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 2442, in powdenest\n    eq, rep = polarify(eq)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 2166, in polarify\n    eq = _polarify(sympify(eq), lift)\n  File \"/home/ptb/gitrepos/sympy/sympy/simplify/simplify.py\", line 2101, in _polarify\n    return polar_lift(eq)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 375, in __new__\n    result = super(Function, cls).__new__(cls, *args, **options)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 199, in __new__\n    evaluated = cls.eval(*args)\n  File \"/home/ptb/gitrepos/sympy/sympy/functions/elementary/complexes.py\", line 651, in eval\n    ar = argument(arg)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 375, in __new__\n    result = super(Function, cls).__new__(cls, *args, **options)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 199, in __new__\n    evaluated = cls.eval(*args)\n  File \"/home/ptb/gitrepos/sympy/sympy/functions/elementary/complexes.py\", line 487, in eval\n    sign(a) for a in arg_.args])\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 379, in __new__\n    pr = max(cls._should_evalf(a) for a in result.args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 379, in <genexpr>\n    pr = max(cls._should_evalf(a) for a in result.args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/function.py\", line 398, in _should_evalf\n    re, im = arg.as_real_imag()\n  File \"/home/ptb/gitrepos/sympy/sympy/core/add.py\", line 701, in as_real_imag\n    re, im = term.as_real_imag(deep=deep)\n  File \"/home/ptb/gitrepos/sympy/sympy/functions/elementary/exponential.py\", line 330, in as_real_imag\n    return (exp(re)*cos, exp(re)*sin)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/expr.py\", line 127, in __mul__\n    return Mul(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/operations.py\", line 41, in __new__\n    c_part, nc_part, order_symbols = cls.flatten(args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 415, in flatten\n    c_part.append(Pow(b, e))\n  File \"/home/ptb/gitrepos/sympy/sympy/core/power.py\", line 170, in __new__\n    elif e.is_integer and _coeff_isneg(b):\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 180, in _ask\n    assumptions.deduce_all_facts(((fact, a),))\n  File \"/home/ptb/gitrepos/sympy/sympy/core/facts.py\", line 506, in deduce_all_facts\n    if not self._tell(k, v) or v is None:\n  File \"/home/ptb/gitrepos/sympy/sympy/core/facts.py\", line 477, in _tell\n    raise InconsistentAssumptions(self, k, v)\nInconsistentAssumptions: {\n    commutative: True,\n    complex: True,\n    composite: False,\n    even: False,\n    hermitian: True,\n    imaginary: False,\n    integer: False,\n    irrational: True,\n    negative: False,\n    noninteger: True,\n    nonnegative: True,\n    nonpositive: False,\n    nonzero: True,\n    odd: False,\n    positive: True,\n    prime: False,\n    rational: False,\n    real: True,\n    zero: False}, imaginary=True\n\n========== tests finished: 1 passed, 1 exceptions, in 10.71 seconds ===========\nDO *NOT* COMMIT!\n```\n\nFails with a different error with caching disabled\n\n``` bash\nSYMPY_USE_CACHE=NO PYTHONHASHSEED=730299569 bin/test sympy/integrals/tests/test_meijerint.py -k test_meijerint --seed 68924065============================= test process starts =============================\nexecutable:         /home/ptb/miniconda3/envs/py27/bin/python  (2.7.8-final-0) [CPython]\narchitecture:       64-bit\ncache:              no\nground types:       python \nrandom seed:        68924065\nhash randomization: on (PYTHONHASHSEED=730299569)\n\nsympy/integrals/tests/test_meijerint.py[2] .E                            [FAIL]\n\n_______________________________________________________________________________\n___________ sympy/integrals/tests/test_meijerint.py:test_meijerint ____________\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/tests/test_meijerint.py\", line 138, in test_meijerint\n    i, c = meijerint_definite(exp(-((x - mu)/(2*sigma))**2), x, 0, oo)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1766, in meijerint_definite\n    res = _meijerint_definite_2(f, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1852, in _meijerint_definite_2\n    res = _meijerint_definite_3(g, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1864, in _meijerint_definite_3\n    res = _meijerint_definite_4(f, x)\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1935, in _meijerint_definite_4\n    cond = And(cond, _check_antecedents(f1_, f2_, x))\n  File \"/home/ptb/gitrepos/sympy/sympy/integrals/meijerint.py\", line 1075, in _check_antecedents\n    conds += [And(Eq(p, q), Eq(cstar, 0), bstar.is_positive is True, omega.is_positive is True, re(mu) < 1,\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1181, in _eval_is_even\n    is_integer = self.is_integer\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 986, in _eval_is_integer\n    is_rational = self.is_rational\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 135, in getit\n    return _ask(fact, self)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 188, in _ask\n    _ask(pk, obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/assumptions.py\", line 178, in _ask\n    a = evaluate(obj)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 1037, in _eval_is_imaginary\n    return (S.ImaginaryUnit*self).is_real\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/expr.py\", line 127, in __mul__\n    return Mul(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/operations.py\", line 41, in __new__\n    c_part, nc_part, order_symbols = cls.flatten(args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 388, in flatten\n    c_powers = _gather(c_powers)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 384, in _gather\n    new_c_powers.append((b, c*t))\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1671, in __mul__\n    return Rational.__mul__(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1227, in __mul__\n    return Number.__mul__(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 361, in __mul__\n    return AtomicExpr.__mul__(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 118, in binary_op_wrapper\n    return func(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/expr.py\", line 127, in __mul__\n    return Mul(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/operations.py\", line 41, in __new__\n    c_part, nc_part, order_symbols = cls.flatten(args)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/mul.py\", line 284, in flatten\n    neg1e += S.Half\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1647, in __add__\n    return Rational.__add__(self, other)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\n    return func(a, b)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1205, in __add__\n    return Rational(self.p*other.q + self.q*other.p, self.q*other.q)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1096, in __new__\n    p = Rational(p)\n  File \"/home/ptb/gitrepos/sympy/sympy/core/numbers.py\", line 1084, in __new__\n    if isinstance(p, fractions.Fraction):\nRuntimeError: maximum recursion depth exceeded\n\n========== tests finished: 1 passed, 1 exceptions, in 41.05 seconds ===========\nDO *NOT* COMMIT!\n```\n",
      "issue_closed_at": "2014-09-16T15:27:52Z",
      "base_commit": "3d2a26cb368ab2233dc73c2857ab0c6ca7e95f9e",
      "changes": [
        {
          "file": "sympy/core/mul.py",
          "type": "function",
          "name": "_eval_is_algebraic_expr",
          "class_name": "Mul",
          "code": "def _eval_is_algebraic_expr(self, syms):\n        return all(term._eval_is_algebraic_expr(syms) for term in self.args)"
        },
        {
          "file": "sympy/core/mul.py",
          "type": "function",
          "name": "_eval_is_positive",
          "class_name": "Mul",
          "code": "def _eval_is_positive(self):\n        \"\"\"Return True if self is positive, False if not, and None if it\n        cannot be determined.\n\n        This algorithm is non-recursive and works by keeping track of the\n        sign which changes when a negative or nonpositive is encountered.\n        Whether a nonpositive or nonnegative is seen is also tracked since\n        the presence of these makes it impossible to return True, but\n        possible to return False if the end result is nonpositive. e.g.\n\n            pos * neg * nonpositive -> pos or zero -> None is returned\n            pos * neg * nonnegative -> neg or zero -> False is returned\n        \"\"\"\n\n        sign = 1\n        saw_NON = False\n        for t in self.args:\n            if t.is_positive:\n                continue\n            elif t.is_negative:\n                sign = -sign\n            elif t.is_zero:\n                return False\n            elif t.is_nonpositive:\n                sign = -sign\n                saw_NON = True\n            elif t.is_nonnegative:\n                saw_NON = True\n            else:\n                return\n        if sign == 1 and saw_NON is False:\n            return True\n        if sign < 0:\n            return False"
        },
        {
          "file": "sympy/core/mul.py",
          "type": "function",
          "name": "_eval_is_odd",
          "class_name": "Mul",
          "code": "def _eval_is_odd(self):\n        is_integer = self.is_integer\n\n        if is_integer:\n            r, acc = True, 1\n            for t in self.args:\n                if not t.is_integer:\n                    return None\n                elif t.is_even:\n                    r = False\n                elif t.is_integer:\n                    if r is False:\n                        pass\n                    elif acc != 1 and (acc + t).is_odd:\n                        r = False\n                    elif t.is_odd is None:\n                        r = None\n                acc = t\n            return r\n\n        # !integer -> !odd\n        elif is_integer is False:\n            return False"
        },
        {
          "file": "sympy/functions/elementary/exponential.py",
          "type": "function",
          "name": "_eval_is_bounded",
          "class_name": "log",
          "code": "def _eval_is_bounded(self):\n        arg = self.args[0]\n        if arg.is_zero:\n            return False\n        return arg.is_bounded"
        },
        {
          "file": "sympy/polys/numberfields.py",
          "type": "function",
          "name": "_minpoly_compose",
          "class_name": null,
          "code": "def _minpoly_compose(ex, x, dom):\n    \"\"\"\n    Computes the minimal polynomial of an algebraic element\n    using operations on minimal polynomials\n\n    Examples\n    ========\n\n    >>> from sympy import minimal_polynomial, sqrt, Rational\n    >>> from sympy.abc import x, y\n    >>> minimal_polynomial(sqrt(2) + 3*Rational(1, 3), x, compose=True)\n    x**2 - 2*x - 1\n    >>> minimal_polynomial(sqrt(y) + 1/y, x, compose=True)\n    x**2*y**2 - 2*x*y - y**3 + 1\n\n    \"\"\"\n    if ex.is_Rational:\n        return ex.q*x - ex.p\n    if ex is I:\n        return x**2 + 1\n    if hasattr(dom, 'symbols') and ex in dom.symbols:\n        return x - ex\n\n    if dom.is_QQ and _is_sum_surds(ex):\n        # eliminate the square roots\n        ex -= x\n        while 1:\n            ex1 = _separate_sq(ex)\n            if ex1 is ex:\n                return ex\n            else:\n                ex = ex1\n\n    if ex.is_Add:\n        res = _minpoly_add(x, dom, *ex.args)\n    elif ex.is_Mul:\n        f = Factors(ex).factors\n        r = sift(f.items(), lambda itx: itx[0].is_rational and itx[1].is_rational)\n        if r[True] and dom == QQ:\n            ex1 = Mul(*[bx**ex for bx, ex in r[False] + r[None]])\n            r1 = r[True]\n            dens = [y.q for _, y in r1]\n            lcmdens = reduce(lcm, dens, 1)\n            nums = [base**(y.p*lcmdens // y.q) for base, y in r1]\n            ex2 = Mul(*nums)\n            mp1 = minimal_polynomial(ex1, x)\n            # use the fact that in SymPy canonicalization products of integers\n            # raised to rational powers are organized in relatively prime\n            # bases, and that in ``base**(n/d)`` a perfect power is\n            # simplified with the root\n            mp2 = ex2.q*x**lcmdens - ex2.p\n            ex2 = ex2**Rational(1, lcmdens)\n            res = _minpoly_op_algebraic_element(Mul, ex1, ex2, x, dom, mp1=mp1, mp2=mp2)\n        else:\n            res = _minpoly_mul(x, dom, *ex.args)\n    elif ex.is_Pow:\n        res = _minpoly_pow(ex.base, ex.exp, x, dom)\n    elif ex.__class__ is C.sin:\n        res = _minpoly_sin(ex, x)\n    elif ex.__class__ is C.cos:\n        res = _minpoly_cos(ex, x)\n    elif ex.__class__ is C.exp:\n        res = _minpoly_exp(ex, x)\n    elif ex.__class__ is RootOf:\n        res = _minpoly_rootof(ex, x)\n    else:\n        raise NotAlgebraic(\"%s doesn't seem to be an algebraic element\" % ex)\n    return res"
        }
      ]
    },
    {
      "pr_number": 11384,
      "pr_title": "Update formal power series printing",
      "pr_body": "fixes #11102 \nping @asmeurer \n",
      "issue_id": 11102,
      "issue_title": "fps should print as a formal power series",
      "issue_body": "When I first used `fps`, I didn't realize it really was a formal power series as it claims to be, because it prints like a normal series (same as `series`)\n\n```\nIn [21]: fps(sin(x))\nOut[21]:\n     3     5\n    x     x     \u239b 6\u239e\nx - \u2500\u2500 + \u2500\u2500\u2500 + O\u239dx \u23a0\n    6    120\n```\n\nBut if you look at the string form, you see\n\n```\nIn [22]: print(fps(sin(x)))\nFormalPowerSeries(sin(x), x, 0, 1, (SeqFormula(Piecewise(((-1/4)**(_k/2 - 1/2)/(RisingFactorial(3/2, _k/2 - 1/2)*factorial(_k/2 - 1/2)), Eq(Mod(_k, 2), 1)), (0, True)), (_k, 2, oo)), SeqFormula(x**_k, (_k, 0, oo)), x))\n```\n\nThat is, it really does represent it as the formula `Sum((-1)**n/factorial(2*n + 1)*x**n, (n, 0, oo))` (albiet, not simplified). It out to print it like this, so you can see that that's what it's working with.\n\nSide question: if you enter something it can't compute, it just returns the function\n\n```\nIn [25]: fps(tan(x))\nOut[25]: tan(x)\n```\n\nIs that intentional? It seems like it ought to raise an exception in that case. \n\n@leosartaj \n",
      "issue_closed_at": "2016-07-14T22:47:58Z",
      "base_commit": "496e776108957d8c049cbef49522cef4c1955e2f",
      "changes": [
        {
          "file": "sympy/printing/latex.py",
          "type": "function",
          "name": "_print_FourierSeries",
          "class_name": "LatexPrinter",
          "code": "def _print_FourierSeries(self, s):\n        return self._print_Add(s.truncate()) + self._print(' + \\ldots')"
        },
        {
          "file": "sympy/printing/pretty/pretty.py",
          "type": "function",
          "name": "_print_FourierSeries",
          "class_name": "PrettyPrinter",
          "code": "def _print_FourierSeries(self, s):\n        if self._use_unicode:\n            dots = u(\"\\N{HORIZONTAL ELLIPSIS}\")\n        else:\n            dots = '...'\n        return self._print_Add(s.truncate()) + self._print(dots)"
        }
      ]
    }
  ]
}