{
  "instance_id": "sympy__sympy-24909",
  "repo": "sympy/sympy",
  "created_at": "2023-03-13T14:24:25Z",
  "problem_statement": "Bug with milli prefix\nWhat happened:\r\n```\r\nIn [1]: from sympy.physics.units import milli, W\r\nIn [2]: milli*W == 1\r\nOut[2]: True\r\nIn [3]: W*milli\r\nOut[3]: watt*Prefix(milli, m, -3, 10)\r\n```\r\nWhat I expected to happen: milli*W should evaluate to milli watts / mW\r\n\r\n`milli*W` or more generally `milli` times some unit evaluates to the number 1. I have tried this with Watts and Volts, I'm not sure what other cases this happens. I'm using sympy version 1.11.1-1 on Arch Linux with Python 3.10.9. If you cannot reproduce I would be happy to be of any assitance.\n",
  "patch": "diff --git a/sympy/physics/units/prefixes.py b/sympy/physics/units/prefixes.py\n--- a/sympy/physics/units/prefixes.py\n+++ b/sympy/physics/units/prefixes.py\n@@ -6,7 +6,7 @@\n \"\"\"\n from sympy.core.expr import Expr\n from sympy.core.sympify import sympify\n-\n+from sympy.core.singleton import S\n \n class Prefix(Expr):\n     \"\"\"\n@@ -85,9 +85,9 @@ def __mul__(self, other):\n \n         fact = self.scale_factor * other.scale_factor\n \n-        if fact == 1:\n-            return 1\n-        elif isinstance(other, Prefix):\n+        if isinstance(other, Prefix):\n+            if fact == 1:\n+                return S.One\n             # simplify prefix\n             for p in PREFIXES:\n                 if PREFIXES[p].scale_factor == fact:\n@@ -103,7 +103,7 @@ def __truediv__(self, other):\n         fact = self.scale_factor / other.scale_factor\n \n         if fact == 1:\n-            return 1\n+            return S.One\n         elif isinstance(other, Prefix):\n             for p in PREFIXES:\n                 if PREFIXES[p].scale_factor == fact:\n",
  "similar_bug_items": [
    {
      "pr_number": 24854,
      "pr_title": "tensor: Fix dispatch bug in array_derivates.py",
      "pr_body": "This bug prevent simplification of the array expr when possible.\r\n\r\n<!-- Your title above should be a short description of what\r\nwas changed. Do not include the issue number in the title. -->\r\n\r\n#### References to other Issues or PRs\r\n<!-- If this pull request fixes an issue, write \"Fixes #NNNN\" in that exact\r\nformat, e.g. \"Fixes #1234\" (see\r\nhttps://tinyurl.com/auto-closing for more information). Also, please\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\n\r\n\r\n#### Brief description of what is fixed or changed\r\nFixes bug in array_derivatives dispatch. Fix #24742 \r\n\r\n#### Other comments\r\n\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below between the BEGIN and END\r\nstatements. The basic format is a bulleted list with the name of the subpackage\r\nand the release note for this PR. For example:\r\n\r\n* solvers\r\n  * Added a new solver for logarithmic equations.\r\n\r\n* functions\r\n  * Fixed a bug with log of integers. Formerly, `log(-x)` incorrectly gave `-log(x)`.\r\n\r\n* physics.units\r\n  * Corrected a semantical error in the conversion between volt and statvolt which\r\n    reported the volt as being larger than the statvolt.\r\n\r\nor if no release note(s) should be included use:\r\n\r\nNO ENTRY\r\n\r\nSee https://github.com/sympy/sympy/wiki/Writing-Release-Notes for more\r\ninformation on how to write release notes. The bot will check your release\r\nnotes automatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n* tensor\r\n  * fix bug in array_derivatives dispatch logic that prevented simplification of array exprs.\r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 24742,
      "issue_title": "Potential Bug in sympy/tensor/array/array_derivatives.py",
      "issue_body": "I was doing some static analysis and found an if statement that looks like a bug on line 112: https://github.com/sympy/sympy/blob/b0a27be36c69dc48d7b2145be82b77d5bffc56a0/sympy/tensor/array/array_derivatives.py#L115\r\n```python\r\nif isinstance(expr, MatrixCommon) or isinstance(expr, MatrixCommon):\r\n```\r\n , but both sides of that expression are redundant. Is it suppose to be?\r\n```python\r\nif isinstance(expr, MatrixCommon) or isinstance(v, MatrixCommon):\r\n```",
      "issue_closed_at": "2023-03-06T20:59:02Z",
      "base_commit": "9e63683f77484eeb3077d2cab9eb0919ec2d6b9f",
      "changes": [
        {
          "file": "sympy/tensor/array/array_derivatives.py",
          "type": "function",
          "name": "_dispatch_eval_derivative_n_times",
          "class_name": "ArrayDerivative",
          "code": "def _dispatch_eval_derivative_n_times(cls, expr, v, count):\n        # Evaluate the derivative `n` times.  If\n        # `_eval_derivative_n_times` is not overridden by the current\n        # object, the default in `Basic` will call a loop over\n        # `_eval_derivative`:\n\n        if not isinstance(count, (int, Integer)) or ((count <= 0) == True):\n            return None\n\n        # TODO: this could be done with multiple-dispatching:\n        if expr.is_scalar:\n            if isinstance(v, MatrixCommon):\n                result = cls._call_derive_scalar_by_matrix(expr, v)\n            elif isinstance(v, MatrixExpr):\n                result = cls._call_derive_scalar_by_matexpr(expr, v)\n            elif isinstance(v, NDimArray):\n                result = cls._call_derive_scalar_by_array(expr, v)\n            elif v.is_scalar:\n                # scalar by scalar has a special\n                return super()._dispatch_eval_derivative_n_times(expr, v, count)\n            else:\n                return None\n        elif v.is_scalar:\n            if isinstance(expr, MatrixCommon):\n                result = cls._call_derive_matrix_by_scalar(expr, v)\n            elif isinstance(expr, MatrixExpr):\n                result = cls._call_derive_matexpr_by_scalar(expr, v)\n            elif isinstance(expr, NDimArray):\n                result = cls._call_derive_array_by_scalar(expr, v)\n            else:\n                return None\n        else:\n            # Both `expr` and `v` are some array/matrix type:\n            if isinstance(expr, MatrixCommon) or isinstance(expr, MatrixCommon):\n                result = derive_by_array(expr, v)\n            elif isinstance(expr, MatrixExpr) and isinstance(v, MatrixExpr):\n                result = cls._call_derive_default(expr, v)\n            elif isinstance(expr, MatrixExpr) or isinstance(v, MatrixExpr):\n                # if one expression is a symbolic matrix expression while the other isn't, don't evaluate:\n                return None\n            else:\n                result = derive_by_array(expr, v)\n        if result is None:\n            return None\n        if count == 1:\n            return result\n        else:\n            return cls._dispatch_eval_derivative_n_times(result, v, count - 1)"
        }
      ]
    },
    {
      "pr_number": 15519,
      "pr_title": "Exit _eval_derivative_n_times when None is obtained",
      "pr_body": "#### References to other Issues or PRs\r\n\r\nFixes #15518 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nThe method `_eval_derivative_n_times` contains a loop that involves calling `_eval_derivative`. The latter may return None when evaluation is not implemented. In such a case the loop should be aborted (returning None) instead of trying to differentiate None.\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below. See\r\nhttps://github.com/sympy/sympy/wiki/Writing-Release-Notes for more information\r\non how to write release notes. The bot will check your release notes\r\nautomatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n* core\r\n  * Fixed a bug in the creation of higher order derivatives that cannot be evaluated.  \r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 15518,
      "issue_title": "Higher order derivatives that cannot be evaluated, like re(x).diff(x, 2), raise an exception",
      "issue_body": "This issue arose in a [comment on another issue]( https://github.com/sympy/sympy/issues/15457#issuecomment-436453327) but since it's actually unrelated, is posted here separately. \r\n```\r\n>>> re(x).diff(x, 2)\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/ubuntu/sympy/sympy/core/expr.py\", line 3047, in diff\r\n    return Derivative(self, *symbols, **assumptions)\r\n  File \"/home/ubuntu/sympy/sympy/core/function.py\", line 1370, in __new__\r\n    obj = expr._eval_derivative_n_times(v, count)\r\n  File \"/home/ubuntu/sympy/sympy/core/basic.py\", line 1688, in _eval_derivative_n_times\r\n    obj2 = obj._accept_eval_derivative(s)\r\nAttributeError: 'NoneType' object has no attribute '_accept_eval_derivative'\r\n```\r\nThis happens whenever a higher-order derivative is requested for a function that does not have an explicit derivative. The expected output is \r\n```\r\nDerivative(re(x), (x, 2))\r\n```\r\nA PR is forthcoming. \r\n",
      "issue_closed_at": "2018-11-24T11:36:42Z",
      "base_commit": "61e5c20c02328815270ddda385f0108a2b40d24d",
      "changes": [
        {
          "file": "sympy/core/basic.py",
          "type": "function",
          "name": "_eval_derivative_n_times",
          "class_name": "Basic",
          "code": "def _eval_derivative_n_times(self, s, n):\n        # This is the default evaluator for derivatives (as called by `diff`\n        # and `Derivative`), it will attempt a loop to derive the expression\n        # `n` times by calling the corresponding `_eval_derivative` method,\n        # while leaving the derivative unevaluated if `n` is symbolic.  This\n        # method should be overridden if the object has a closed form for its\n        # symbolic n-th derivative.\n        from sympy import Integer\n        if isinstance(n, (int, Integer)):\n            obj = self\n            for i in range(n):\n                obj2 = obj._accept_eval_derivative(s)\n                if obj == obj2:\n                    break\n                obj = obj2\n            return obj\n        else:\n            return None"
        }
      ]
    },
    {
      "pr_number": 13437,
      "pr_title": "Fix bell(n) for n=oo, and negative/non-integer 'n'",
      "pr_body": "This PR uses commits of #9198 (maintaining ownership to original author). And tries to address the requested changes on PR #9198 .\r\nFixes #9184",
      "issue_id": 9184,
      "issue_title": "bell(n).limit(n, oo) should be oo rather than bell(oo)",
      "issue_body": "`bell(n).limit(n,oo)` should take the value infinity, but the current output is `bell(oo)`. As the Bell numbers represent the number of partitions of a set, it seems natural that `bell(oo)` should be able to be evaluated rather than be returned unevaluated. This issue is also in line with the recent fixes to the corresponding limit for the Fibonacci numbers and Lucas numbers.\n\n```\nfrom sympy import *\nn = symbols('n')\nbell(n).limit(n,oo)\n\nOutput:\nbell(oo)\n```\n\nI'm new to Sympy, so I'd appreciate the opportunity to fix this bug myself if that's alright.\n",
      "issue_closed_at": "2017-10-13T04:35:13Z",
      "base_commit": "674afc619d7f5c519b6a5393a8b0532a131e57e0",
      "changes": [
        {
          "file": "sympy/functions/combinatorial/numbers.py",
          "type": "function",
          "name": "_bell_incomplete_poly",
          "class_name": "bell",
          "code": "def _bell_incomplete_poly(n, k, symbols):\n        r\"\"\"\n        The second kind of Bell polynomials (incomplete Bell polynomials).\n\n        Calculated by recurrence formula:\n\n        .. math:: B_{n,k}(x_1, x_2, \\dotsc, x_{n-k+1}) =\n                \\sum_{m=1}^{n-k+1}\n                \\x_m \\binom{n-1}{m-1} B_{n-m,k-1}(x_1, x_2, \\dotsc, x_{n-m-k})\n\n        where\n            B_{0,0} = 1;\n            B_{n,0} = 0; for n>=1\n            B_{0,k} = 0; for k>=1\n\n        \"\"\"\n        if (n == 0) and (k == 0):\n            return S.One\n        elif (n == 0) or (k == 0):\n            return S.Zero\n        s = S.Zero\n        a = S.One\n        for m in range(1, n - k + 2):\n            s += a * bell._bell_incomplete_poly(\n                n - m, k - 1, symbols) * symbols[m - 1]\n            a = a * (n - m) / m\n        return expand_mul(s)"
        }
      ]
    },
    {
      "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": 7928,
      "pr_title": "give MaxMinBase an evalf routine",
      "pr_body": "Although Or, And, etc... will not have a number as an\nargument, Min and Max can. When the operations version\nof _eval_evalf is called a call to as_independent is\nmade. This creates an x (=1) that is assumed to be an\nargument of the object so Max(0,y).n() becomes Max(1, 0, y) -> Max(1, y).\nTo avoid this an evalf routine was added to handle MaxMinBase separately.\n\nfixes #7233\n",
      "issue_id": 7233,
      "issue_title": "N(Max(0.0, n + m)) returns Max(1.0, n + m)",
      "issue_body": "```\nThe following code does not return what is expected,\n\nn = sympy.Symbol('n')\nm = sympy.Symbol('m')\na = sympy.Max(0.0, n + m)\nprint a\nprint sympy.N(a)\n\noutputs:\n>> Max(0.0, m + n)\n>> Max(1.0, m + n)\n```\n\nOriginal issue for #7233: http://code.google.com/p/sympy/issues/detail?id=4134\nOriginal author: https://code.google.com/u/100679098312105897492/\n",
      "issue_closed_at": "2014-08-29T23:58:03Z",
      "base_commit": "d365f932a26c28c4c57b2b9f6dddee2ca94a5c66",
      "changes": [
        {
          "file": "sympy/functions/elementary/miscellaneous.py",
          "type": "function",
          "name": "_eval_derivative",
          "class_name": "MinMaxBase",
          "code": "def _eval_derivative(self, s):\n        # f(x).diff(s) -> x.diff(s) * f.fdiff(1)(s)\n        i = 0\n        l = []\n        for a in self.args:\n            i += 1\n            da = a.diff(s)\n            if da is S.Zero:\n                continue\n            try:\n                df = self.fdiff(i)\n            except ArgumentIndexError:\n                df = Function.fdiff(self, i)\n            l.append(df * da)\n        return Add(*l)"
        }
      ]
    }
  ]
}