{
  "original_problem": {
    "instance_id": "sympy__sympy-20322",
    "repo": "sympy/sympy",
    "created_at": "2020-10-22T20:39:24Z",
    "problem_statement": "Inconsistent behavior for sympify/simplify with ceiling\nIn sympy v1.5.1:\r\n```python\r\nIn [16]: sympy.sympify('4*ceiling(x/4 - 3/4)', evaluate=False).simplify()\r\nOut[16]: 4*ceiling(x/4 - 3/4)\r\n\r\nIn [17]: sympy.sympify('4*ceiling(x/4 - 3/4)', evaluate=True).simplify()\r\nOut[17]: 4*ceiling(x/4 - 3/4)\r\n```\r\n\r\nIn sympy v.1.6.2:\r\n```python\r\nIn [16]: sympy.sympify('4*ceiling(x/4 - 3/4)', evaluate=False).simplify()\r\nOut[16]: 4*ceiling(x/4) - 3\r\n\r\nIn [17]: sympy.sympify('4*ceiling(x/4 - 3/4)', evaluate=True).simplify()\r\nOut [17]: 4*ceiling(x/4 - 3/4)\r\n```\r\n\r\nIs there a way to ensure that the behavior is consistent, even though evaluate is equal to `False` when parsing?\n",
    "patch": "diff --git a/sympy/core/mul.py b/sympy/core/mul.py\n--- a/sympy/core/mul.py\n+++ b/sympy/core/mul.py\n@@ -7,7 +7,7 @@\n from .singleton import S\n from .operations import AssocOp, AssocOpDispatcher\n from .cache import cacheit\n-from .logic import fuzzy_not, _fuzzy_group, fuzzy_and\n+from .logic import fuzzy_not, _fuzzy_group\n from .compatibility import reduce\n from .expr import Expr\n from .parameters import global_parameters\n@@ -1262,27 +1262,47 @@ def _eval_is_zero(self):\n                     zero = None\n         return zero\n \n+    # without involving odd/even checks this code would suffice:\n+    #_eval_is_integer = lambda self: _fuzzy_group(\n+    #    (a.is_integer for a in self.args), quick_exit=True)\n     def _eval_is_integer(self):\n-        from sympy import fraction\n-        from sympy.core.numbers import Float\n-\n         is_rational = self._eval_is_rational()\n         if is_rational is False:\n             return False\n \n-        # use exact=True to avoid recomputing num or den\n-        n, d = fraction(self, exact=True)\n-        if is_rational:\n-            if d is S.One:\n-                return True\n-        if d.is_even:\n-            if d.is_prime:  # literal or symbolic 2\n-                return n.is_even\n-            if n.is_odd:\n-                return False  # true even if d = 0\n-        if n == d:\n-            return fuzzy_and([not bool(self.atoms(Float)),\n-            fuzzy_not(d.is_zero)])\n+        numerators = []\n+        denominators = []\n+        for a in self.args:\n+            if a.is_integer:\n+                numerators.append(a)\n+            elif a.is_Rational:\n+                n, d = a.as_numer_denom()\n+                numerators.append(n)\n+                denominators.append(d)\n+            elif a.is_Pow:\n+                b, e = a.as_base_exp()\n+                if not b.is_integer or not e.is_integer: return\n+                if e.is_negative:\n+                    denominators.append(b)\n+                else:\n+                    # for integer b and positive integer e: a = b**e would be integer\n+                    assert not e.is_positive\n+                    # for self being rational and e equal to zero: a = b**e would be 1\n+                    assert not e.is_zero\n+                    return # sign of e unknown -> self.is_integer cannot be decided\n+            else:\n+                return\n+\n+        if not denominators:\n+            return True\n+\n+        odd = lambda ints: all(i.is_odd for i in ints)\n+        even = lambda ints: any(i.is_even for i in ints)\n+\n+        if odd(numerators) and even(denominators):\n+            return False\n+        elif even(numerators) and denominators == [2]:\n+            return True\n \n     def _eval_is_polar(self):\n         has_polar = any(arg.is_polar for arg in self.args)\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_12571",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves recursion errors in limit evaluation, which is unrelated to the simplification inconsistency in the current issue."
      },
      {
        "idx": 2,
        "id": "similar_15518",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with handling derivatives and AttributeError, which does not relate to the simplification behavior inconsistency."
      },
      {
        "idx": 3,
        "id": "similar_17350",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about input validation for non-integer arguments in polygamma, which is not relevant to the simplification logic inconsistency."
      },
      {
        "idx": 4,
        "id": "similar_4615",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves asymptotic behavior in exponential expressions, which does not share reasoning patterns with the current simplification inconsistency."
      },
      {
        "idx": 5,
        "id": "similar_15873",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue concerns zero evaluation in complex expressions, which is unrelated to the simplification behavior inconsistency in the current issue."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "limit(-LambertW(-log(t))/log(t), t, 1) crashes with RecursionError",
        "issue_body": "```\r\n>>> limit(-LambertW(-log(t))/log(t), t, 1)\r\nTraceback (most recent call last):\r\n  File \"./sympy/core/assumptions.py\", line 243, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"./sympy/core/assumptions.py\", line 243, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'irrational'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"./sympy/core/assumptions.py\", line 243, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"./sympy/core/assumptions.py\", line 243, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2644, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 614, in _eval_nseries\r\n    args0 = [t.limit(x, 0) for t in args]\r\n  File \"./sympy/core/function.py\", line 614, in <listcomp>\r\n    args0 = [t.limit(x, 0) for t in args]\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2644, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/functions/elementary/exponential.py\", line 735, in _eval_nseries\r\n    a, b = s.leadterm(x)\r\n  File \"./sympy/core/expr.py\", line 2841, in leadterm\r\n    l = self.as_leading_term(x)\r\n  File \"./sympy/core/expr.py\", line 2806, in as_leading_term\r\n    obj = self._eval_as_leading_term(x)\r\n  File \"./sympy/core/add.py\", line 804, in _eval_as_leading_term\r\n    plain = expr.func(*[s for s, _ in expr.extract_leading_order(x)])\r\n  File \"./sympy/core/add.py\", line 747, in extract_leading_order\r\n    if o.contains(of) and o != of:\r\n  File \"./sympy/series/order.py\", line 386, in contains\r\n    l = ratio.limit(s, point)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 472, in calculate_series\r\n    if t.simplify():\r\n  File \"./sympy/core/expr.py\", line 3038, in simplify\r\n    return simplify(self, ratio, measure)\r\n  File \"./sympy/simplify/simplify.py\", line 545, in simplify\r\n    expr = Mul(*powsimp(expr).as_content_primitive())\r\n  File \"./sympy/simplify/powsimp.py\", line 121, in powsimp\r\n    return recurse(expr*_y, deep=False)/_y\r\n  File \"./sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\r\n    return func(a, b)\r\n  File \"./sympy/core/decorators.py\", line 118, in binary_op_wrapper\r\n    return func(self, other)\r\n  File \"./sympy/core/expr.py\", line 161, in __div__\r\n    return Mul(self, Pow(other, S.NegativeOne))\r\n  File \"./sympy/core/operations.py\", line 41, in __new__\r\n    c_part, nc_part, order_symbols = cls.flatten(args)\r\n  File \"./sympy/core/mul.py\", line 182, in flatten\r\n    if not a.is_zero and a.is_Rational:\r\n  File \"./sympy/core/assumptions.py\", line 247, in getit\r\n    return _ask(fact, self)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 290, in _ask\r\n    a = evaluate(obj)\r\n  File \"./sympy/core/mul.py\", line 1200, in _eval_is_irrational\r\n    a = t.is_irrational\r\n  File \"./sympy/core/assumptions.py\", line 247, in getit\r\n    return _ask(fact, self)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 290, in _ask\r\n    a = evaluate(obj)\r\n  File \"./sympy/core/power.py\", line 1059, in _eval_is_algebraic\r\n    if self.base.is_zero or (self.base - 1).is_zero:\r\n  File \"./sympy/core/assumptions.py\", line 247, in getit\r\n    return _ask(fact, self)\r\n  File \"./sympy/core/assumptions.py\", line 290, in _ask\r\n    a = evaluate(obj)\r\n  File \"./sympy/core/add.py\", line 513, in _eval_is_zero\r\n    if self.func(*nz).is_zero:\r\n  File \"./sympy/core/assumptions.py\", line 247, in getit\r\n    return _ask(fact, self)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 290, in _ask\r\n    a = evaluate(obj)\r\n  File \"./sympy/core/add.py\", line 637, in _eval_is_negative\r\n    v = _monotonic_sign(self)\r\n  File \"./sympy/core/exprtools.py\", line 112, in _monotonic_sign\r\n    d = self.diff(x)\r\n  File \"./sympy/core/expr.py\", line 2891, in diff\r\n    return Derivative(self, *new_symbols, **assumptions)\r\n  File \"./sympy/core/function.py\", line 1187, in __new__\r\n    obj = expr._eval_derivative(v)\r\n  File \"./sympy/core/add.py\", line 350, in _eval_derivative\r\n    return self.func(*[a.diff(s) for a in self.args])\r\n  File \"./sympy/core/add.py\", line 350, in <listcomp>\r\n    return self.func(*[a.diff(s) for a in self.args])\r\n  File \"./sympy/core/expr.py\", line 2891, in diff\r\n    return Derivative(self, *new_symbols, **assumptions)\r\n  File \"./sympy/core/function.py\", line 1085, in __new__\r\n    variables = list(sympify(variables))\r\n  File \"./sympy/core/sympify.py\", line 260, in sympify\r\n    return converter[cls](a)\r\n  File \"./sympy/core/containers.py\", line 131, in <lambda>\r\n    converter[tuple] = lambda tup: Tuple(*tup)\r\nRecursionError: maximum recursion depth exceeded\r\n```\r\n\r\nI believe the answer should be `1`. ",
        "issue_id": 12571,
        "pr_number": 17390,
        "pr_title": "Series expansion for LambertW and a number of tests",
        "pr_body": "<!-- 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://github.com/blog/1506-closing-issues-via-pull-requests . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\nFixes #7259\r\nFixes #10978\r\nFixes #12571\r\nCloses #16469 \r\n\r\nAdded tests for #4173, #10978, #14313, #14871, #15323\r\n\r\n#### Brief description of what is fixed or changed\r\nAdded series expansion for `LambertW`.\r\n\r\nAdded evaluation for some cases for `LambertW` and `uppergamma`\r\n\r\n#### Other comments\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* functions\r\n   * Added series expansion for `LambertW`.\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-08-19T00:30:44Z",
        "base_commit": "b28eadab3661a28bfeb2aadffd5c273035057fd1"
      },
      "summary": "### Summary: \nThis issue is related to a RecursionError occurring when evaluating the limit of a specific mathematical expression involving the Lambert W function and logarithms using the SymPy library. \n\n1. **Problem Description in General Terms**: The core problem is a software crash caused by an attempt to evaluate the limit of a mathematical expression. This crash results from excessive recursion, leading to a RecursionError.\n\n2. **Key Symptoms and Behaviors Observed**: The main symptom is a RecursionError indicating that the maximum recursion depth has been exceeded. This occurs during the evaluation of the limit of the expression `-LambertW(-log(t))/log(t)` as `t` approaches 1. The error manifests through repeated calls to various functions within the SymPy library, leading to an infinite loop.\n\n3. **Affected Components or Systems**: The issue primarily impacts the SymPy library, specifically within the components responsible for computing limits, series expansions, and assumptions about mathematical expressions. Functions like `gruntz`, `limitinf`, `mrv_leadterm`, and `calculate_series` within the `sympy/series/gruntz.py` file are notably involved.\n\n4. **Potential Impact or Severity**: The severity of the issue is high for users relying on SymPy for symbolic mathematics, particularly when working with limits involving complex expressions. This issue can halt computations and result in crashes, affecting the reliability of the software.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The problem arises from the recursive nature of the mathematical evaluation process in SymPy, specifically when dealing with expressions that have complex symbolic representations. The underlying cause is likely related to the handling of assumptions and series expansions, which lead to infinite recursion in particular cases.\n\nThe changes made to the code involve modifications to the `LambertW.eval` and `LambertW._eval_is_algebraic` functions in the `sympy/functions/elementary/exponential.py` file, as well as adjustments in the `sympy/functions/special/gamma_functions.py` file, specifically in the `multigamma.eval` function. These changes aim to address the recursion issue and improve the handling of such expressions in SymPy.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: limit(-LambertW(-log(t))/log(t), t, 1) crashes with RecursionError\n\nBody:\n```\r\n>>> limit(-LambertW(-log(t))/log(t), t, 1)\r\nTraceback (most recent call last):\r\n  File \"./sympy/core/assumptions.py\", line 243, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"./sympy/core/assumptions.py\", line 243, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'irrational'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"./sympy/core/assumptions.py\", line 243, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"./sympy/core/assumptions.py\", line 243, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2654, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 672, in _eval_nseries\r\n    subs = e.limit(_x, S.Zero)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2644, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/power.py\", line 1192, in _eval_nseries\r\n    b = b_orig._eval_nseries(x, n=nuse, logx=logx)\r\n  File \"./sympy/core/add.py\", line 353, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/add.py\", line 353, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/function.py\", line 614, in _eval_nseries\r\n    args0 = [t.limit(x, 0) for t in args]\r\n  File \"./sympy/core/function.py\", line 614, in <listcomp>\r\n    args0 = [t.limit(x, 0) for t in args]\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 466, in calculate_series\r\n    for t in e.lseries(x, logx=logx):\r\n  File \"./sympy/core/expr.py\", line 2579, in yield_lseries\r\n    for si in s:\r\n  File \"./sympy/core/expr.py\", line 2644, in _eval_lseries\r\n    series = self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/core/mul.py\", line 1594, in _eval_nseries\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/mul.py\", line 1594, in <listcomp>\r\n    terms = [t.nseries(x, n=n, logx=logx) for t in self.args]\r\n  File \"./sympy/core/expr.py\", line 2731, in nseries\r\n    return self._eval_nseries(x, n=n, logx=logx)\r\n  File \"./sympy/functions/elementary/exponential.py\", line 735, in _eval_nseries\r\n    a, b = s.leadterm(x)\r\n  File \"./sympy/core/expr.py\", line 2841, in leadterm\r\n    l = self.as_leading_term(x)\r\n  File \"./sympy/core/expr.py\", line 2806, in as_leading_term\r\n    obj = self._eval_as_leading_term(x)\r\n  File \"./sympy/core/add.py\", line 804, in _eval_as_leading_term\r\n    plain = expr.func(*[s for s, _ in expr.extract_leading_order(x)])\r\n  File \"./sympy/core/add.py\", line 747, in extract_leading_order\r\n    if o.contains(of) and o != of:\r\n  File \"./sympy/series/order.py\", line 386, in contains\r\n    l = ratio.limit(s, point)\r\n  File \"./sympy/core/expr.py\", line 2754, in limit\r\n    return limit(self, x, xlim, dir)\r\n  File \"./sympy/series/limits.py\", line 45, in limit\r\n    return Limit(e, z, z0, dir).doit(deep=False)\r\n  File \"./sympy/series/limits.py\", line 169, in doit\r\n    r = gruntz(e, z, z0, dir)\r\n  File \"./sympy/series/gruntz.py\", line 658, in gruntz\r\n    r = limitinf(e0, z)\r\n  File \"./sympy/series/gruntz.py\", line 428, in limitinf\r\n    c0, e0 = mrv_leadterm(e, x)\r\n  File \"./sympy/series/gruntz.py\", line 513, in mrv_leadterm\r\n    series = calculate_series(f, w, logx=logw)\r\n  File \"./sympy/series/gruntz.py\", line 472, in calculate_series\r\n    if t.simplify():\r\n  File \"./sympy/core/expr.py\", line 3038, in simplify\r\n    return simplify(self, ratio, measure)\r\n  File \"./sympy/simplify/simplify.py\", line 545, in simplify\r\n    expr = Mul(*powsimp(expr).as_content_primitive())\r\n  File \"./sympy/simplify/powsimp.py\", line 121, in powsimp\r\n    return recurse(expr*_y, deep=False)/_y\r\n  File \"./sympy/core/decorators.py\", line 77, in __sympifyit_wrapper\r\n    return func(a, b)\r\n  File \"./sympy/core/decorators.py\", line 118, in binary_op_wrapper\r\n    return func(self, other)\r\n  File \"./sympy/core/expr.py\", line 161, in __div__\r\n    return Mul(self, Pow(other, S.NegativeOne))\r\n  File \"./sympy/core/operations.py\", line 41, in __new__\r\n    c_part, nc_part, order_symbols = cls.flatten(args)\r\n  File \"./sympy/core/mul.py\", line 182, in flatten\r\n    if not a.is_zero and a.is_Rational:\r\n  File \"./sympy/core/assumptions.py\", line 247, in getit\r\n    return _ask(fact, self)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 290, in _ask\r\n    a = evaluate(obj)\r\n  File \"./sympy/core/mul.py\", line 1200, in _eval_is_irrational\r\n    a = t.is_irrational\r\n  File \"./sympy/core/assumptions.py\", line 247, in getit\r\n    return _ask(fact, self)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 290, in _ask\r\n    a = evaluate(obj)\r\n  File \"./sympy/core/power.py\", line 1059, in _eval_is_algebraic\r\n    if self.base.is_zero or (self.base - 1).is_zero:\r\n  File \"./sympy/core/assumptions.py\", line 247, in getit\r\n    return _ask(fact, self)\r\n  File \"./sympy/core/assumptions.py\", line 290, in _ask\r\n    a = evaluate(obj)\r\n  File \"./sympy/core/add.py\", line 513, in _eval_is_zero\r\n    if self.func(*nz).is_zero:\r\n  File \"./sympy/core/assumptions.py\", line 247, in getit\r\n    return _ask(fact, self)\r\n  File \"./sympy/core/assumptions.py\", line 302, in _ask\r\n    _ask(pk, obj)\r\n  File \"./sympy/core/assumptions.py\", line 290, in _ask\r\n    a = evaluate(obj)\r\n  File \"./sympy/core/add.py\", line 637, in _eval_is_negative\r\n    v = _monotonic_sign(self)\r\n  File \"./sympy/core/exprtools.py\", line 112, in _monotonic_sign\r\n    d = self.diff(x)\r\n  File \"./sympy/core/expr.py\", line 2891, in diff\r\n    return Derivative(self, *new_symbols, **assumptions)\r\n  File \"./sympy/core/function.py\", line 1187, in __new__\r\n    obj = expr._eval_derivative(v)\r\n  File \"./sympy/core/add.py\", line 350, in _eval_derivative\r\n    return self.func(*[a.diff(s) for a in self.args])\r\n  File \"./sympy/core/add.py\", line 350, in <listcomp>\r\n    return self.func(*[a.diff(s) for a in self.args])\r\n  File \"./sympy/core/expr.py\", line 2891, in diff\r\n    return Derivative(self, *new_symbols, **assumptions)\r\n  File \"./sympy/core/function.py\", line 1085, in __new__\r\n    variables = list(sympify(variables))\r\n  File \"./sympy/core/sympify.py\", line 260, in sympify\r\n    return converter[cls](a)\r\n  File \"./sympy/core/containers.py\", line 131, in <lambda>\r\n    converter[tuple] = lambda tup: Tuple(*tup)\r\nRecursionError: maximum recursion depth exceeded\r\n```\r\n\r\nI believe the answer should be `1`. \n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/functions/elementary/exponential.py\n  function: LambertW.eval\n  function: LambertW._eval_is_algebraic\n\nsympy/functions/special/gamma_functions.py\n  line: line 7\n  function: multigamma.eval\n  function: multigamma.eval\n"
    },
    {
      "similar_issue": {
        "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_id": 15518,
        "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_closed_at": "2018-11-24T11:36:42Z",
        "base_commit": "61e5c20c02328815270ddda385f0108a2b40d24d"
      },
      "summary": "### Summary:\n\nThis issue is related to the SymPy library, specifically concerning the evaluation of higher-order derivatives for functions that lack an explicit derivative. The problem arises when a user attempts to calculate a second derivative (or higher) of a function that cannot be directly differentiated, such as the real part of a complex expression, `re(x)`. Instead of returning a symbolic representation of the derivative, the system raises an `AttributeError` due to a `NoneType` object being accessed improperly. The expected behavior is to return a symbolic derivative, indicating the operation requested, without performing it explicitly. The issue impacts the core functionality of symbolic differentiation within the library, particularly affecting users who perform advanced calculus operations. The severity is moderate as it interrupts workflows involving symbolic calculations but does not affect basic derivative operations. The resolution involves modifying the method responsible for handling multiple differentiation requests to ensure it gracefully returns a symbolic derivative object when explicit differentiation is not possible. The fix was applied to the `Basic._eval_derivative_n_times` function in the `sympy/core/basic.py` file.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Higher order derivatives that cannot be evaluated, like re(x).diff(x, 2), raise an exception\n\nBody:\nThis 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\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/core/basic.py\n  function: Basic._eval_derivative_n_times\n"
    },
    {
      "similar_issue": {
        "issue_title": "Should polygamma(a, b) raise NotImplementedError for noninteger (numeric) a?",
        "issue_body": "mpmath's implementation of polygamma is valid only for integer first arguments. SymPy's implementation does not care, but this leads to many issues if you actually try to do things with such objects:\r\n\r\n```\r\n>>> (I*polygamma(I, pi)).as_real_imag()\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'finite'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'extended_positive'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1308, in evalf\r\n    rf = evalf_table[x.func]\r\nKeyError: polygamma\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/eward/se2/sympy/core/mul.py\", line 798, in as_real_imag\r\n    if i.is_zero:\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 864, in _eval_is_negative\r\n    finite = self.is_finite\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 857, in _eval_is_positive\r\n    extended_positive = self.is_extended_positive\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 882, in _eval_is_extended_positive\r\n    n2 = self._eval_evalf(2)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in _eval_evalf\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in <listcomp>\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1489, in _to_mpmath\r\n    re, im, _, _ = evalf(self, prec, {})\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1314, in evalf\r\n    xe = x._eval_evalf(prec)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 590, in _eval_evalf\r\n    v = func(*args)\r\n  File \"/usr/local/lib/python3.6/dist-packages/mpmath/ctx_mp.py\", line 265, in psi\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (tanh(polygamma(I, 1))).rewrite(exp)\r\n...\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (I / polygamma(I, 4)).rewrite(exp)\r\n...\r\n    raise TypeError(\"Invalid comparison of complex %s\" % me)\r\nTypeError: Invalid comparison of complex I\r\n```",
        "issue_id": 17350,
        "pr_number": 17375,
        "pr_title": "polygamma improvements (evaluation, real and positivity determination)",
        "pr_body": "Closes #17350. Fixes #12569.\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\n- Add `_eval_evalf` to prevent evaluation when the first argument is not a nonnegative integer.\r\n- Remove `_eval_is_real` since the logic was wrong.\r\n- Update `_eval_is_positive` and `_eval_is_negative` to avoid doing comparisons with `>`.\r\n\r\n#### Release Notes\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\nNO ENTRY\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-08-23T06:49:24Z",
        "base_commit": "fc6f766ab588fecbb69ad85eb01ca28b44715e5c"
      },
      "summary": "### Summary: \n\nThis issue is related to the behavior of the `polygamma` function within the SymPy library when it is used with non-integer numeric arguments. The problem stems from the fact that while the mpmath library's implementation of `polygamma` is designed to work only with integer first arguments, the SymPy implementation does not enforce this constraint. This discrepancy leads to various execution errors when attempting to perform operations with such `polygamma` objects, as demonstrated by the traceback logs.\n\n1. **Problem Description in General Terms**: The `polygamma` function in SymPy does not check for integer constraints on its first argument, leading to unexpected behaviors and errors when non-integer arguments are used.\n\n2. **Key Symptoms and Behaviors Observed**: The primary symptoms include multiple tracebacks and errors such as `KeyError` and `TypeError` during operations involving complex expressions with `polygamma`. These errors occur when attempting to evaluate or manipulate expressions containing `polygamma` with non-integer first arguments.\n\n3. **Affected Components or Systems**: The issue primarily affects the `polygamma` function within the SymPy library, particularly in scenarios where complex or non-integer inputs are used. Specific components mentioned in the tracebacks include various functions and methods from `sympy.core.assumptions`, `sympy.core.evalf`, `sympy.core.mul`, and `mpmath`.\n\n4. **Potential Impact or Severity**: The impact of this issue can be significant for users relying on symbolic computation with non-integer arguments in `polygamma`. It can lead to application crashes or incorrect symbolic evaluations, potentially affecting any dependent computations or analyses.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding**: The error logs indicate that functions like `as_real_imag`, `_eval_is_negative`, and `_eval_evalf` are involved in the error propagation. There is a need for the SymPy implementation to include validation of input arguments to ensure compatibility with the underlying mpmath expectations, thereby preventing such runtime errors.\n\nOverall, the issue highlights the importance of input validation and compatibility checks in symbolic computation libraries to prevent unexpected behaviors.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Should polygamma(a, b) raise NotImplementedError for noninteger (numeric) a?\n\nBody:\nmpmath's implementation of polygamma is valid only for integer first arguments. SymPy's implementation does not care, but this leads to many issues if you actually try to do things with such objects:\r\n\r\n```\r\n>>> (I*polygamma(I, pi)).as_real_imag()\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'finite'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'extended_positive'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1308, in evalf\r\n    rf = evalf_table[x.func]\r\nKeyError: polygamma\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/eward/se2/sympy/core/mul.py\", line 798, in as_real_imag\r\n    if i.is_zero:\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 864, in _eval_is_negative\r\n    finite = self.is_finite\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 857, in _eval_is_positive\r\n    extended_positive = self.is_extended_positive\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 882, in _eval_is_extended_positive\r\n    n2 = self._eval_evalf(2)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in _eval_evalf\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in <listcomp>\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1489, in _to_mpmath\r\n    re, im, _, _ = evalf(self, prec, {})\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1314, in evalf\r\n    xe = x._eval_evalf(prec)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 590, in _eval_evalf\r\n    v = func(*args)\r\n  File \"/usr/local/lib/python3.6/dist-packages/mpmath/ctx_mp.py\", line 265, in psi\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (tanh(polygamma(I, 1))).rewrite(exp)\r\n...\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (I / polygamma(I, 4)).rewrite(exp)\r\n...\r\n    raise TypeError(\"Invalid comparison of complex %s\" % me)\r\nTypeError: Invalid comparison of complex I\r\n```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/functions/special/gamma_functions.py\n  class: polygamma\n  function: multigamma.fdiff\n  function: loggamma._eval_expand_func\n"
    },
    {
      "similar_issue": {
        "issue_title": "exp.as_leading_term returns wrong results",
        "issue_body": "```\nas_leading_term is implicitly understood (at least by me) to obey the\nfollowing mathematical contract: expr.as_leading_term(x) ~ expr as x -> 0.\nHowever, it fails on the common pitfall that f(x) ~ g(x) doesn't imply\nexp(f(x)) ~ exp(g(x)). Concretely, we have:\n\n>>>exp((x+1)/x**2).as_leading_term(x)\nexp(x**(-2))\n\nbut, of course,\n\n>>>limit(exp((x+1)/x**2)/exp(x**(-2)), x, 0)\noo\n\nObtaining a correct answer requires performing a full asympotic expansion\nto order o(1) which might be outside the scope of this method, so maybe it\nshould return the expression unchanged unless it can easily get a correct\nanswer.\n```\n\nOriginal issue for #4615: http://code.google.com/p/sympy/issues/detail?id=1516\nOriginal author: https://code.google.com/u/101272611947379421629/\n",
        "issue_id": 4615,
        "pr_number": 17447,
        "pr_title": "exp.as_leading_term() returns wrong results",
        "pr_body": "<!-- 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://github.com/blog/1506-closing-issues-via-pull-requests . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\n\r\nFixes #4615 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\n`as_leading_term` does not work properly on exponential functions.\r\nAs noted in the issue #4615 , `exp((x+1)/x**2).as_leading_term(x)`\r\nreturns `exp(x**(-2))`, which is not the correct result.\r\nIndeed when the argument of `exp` tends to `oo`, then it is not\r\ncorrect doing the leading term of the `arg` and then applying the exponential.\r\n\r\nAlso SymPy in the case\r\n`exp((2*x + 3) / (x+1)).as_leading_term(x)`\r\nreturns `S(1)`, which is not correct here, since the argument is closed to `3`.\r\n\r\nIn `test_exponential.py` the following tests are added\r\n```\r\n    assert exp((x + 1) / x**2).as_leading_term(x) == exp((x + 1) / x**2)\r\n    assert exp((2*x + 3) / (x+1)).as_leading_term(x) == exp(3)\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. 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\r\n- functions\r\n   - remove a bug for `as_leading_term()` for exponential functions.\r\n\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-08-20T14:27:02Z",
        "base_commit": "fc6f766ab588fecbb69ad85eb01ca28b44715e5c"
      },
      "summary": "### Summary:\nThis issue is concerned with the mathematical function `as_leading_term` in the SymPy library, which is expected to approximate an expression as a variable approaches zero. The problem arises because the method fails to consider the nuances of exponential expressions, leading to incorrect results. Specifically, while the function should maintain equivalence in asymptotic behavior, it does not account for the fact that \\( f(x) \\sim g(x) \\) does not necessarily imply \\( \\exp(f(x)) \\sim \\exp(g(x)) \\).\n\nKey symptoms include incorrect results when using `as_leading_term` on exponential expressions, as demonstrated by the test case where the leading term approximation deviates significantly from the expected behavior when evaluated with a limit. The issue impacts the component responsible for evaluating leading terms in mathematical expressions, particularly within the exponential functions of the SymPy library.\n\nThe potential impact is significant for users relying on accurate asymptotic analysis in mathematical computations, as it could lead to erroneous conclusions or calculations. The severity depends on the extent to which users depend on this function for their work.\n\nRelevant technical details include the necessity for a full asymptotic expansion to achieve accurate results, which may extend beyond the intended scope of the `as_leading_term` method. The patch addresses this issue by modifying the `log._eval_as_leading_term` function in `sympy/functions/elementary/exponential.py` to ensure more reliable behavior in such cases.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: exp.as_leading_term returns wrong results\n\nBody:\n```\nas_leading_term is implicitly understood (at least by me) to obey the\nfollowing mathematical contract: expr.as_leading_term(x) ~ expr as x -> 0.\nHowever, it fails on the common pitfall that f(x) ~ g(x) doesn't imply\nexp(f(x)) ~ exp(g(x)). Concretely, we have:\n\n>>>exp((x+1)/x**2).as_leading_term(x)\nexp(x**(-2))\n\nbut, of course,\n\n>>>limit(exp((x+1)/x**2)/exp(x**(-2)), x, 0)\noo\n\nObtaining a correct answer requires performing a full asympotic expansion\nto order o(1) which might be outside the scope of this method, so maybe it\nshould return the expression unchanged unless it can easily get a correct\nanswer.\n```\n\nOriginal issue for #4615: http://code.google.com/p/sympy/issues/detail?id=1516\nOriginal author: https://code.google.com/u/101272611947379421629/\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/functions/elementary/exponential.py\n  function: log._eval_as_leading_term\n"
    },
    {
      "similar_issue": {
        "issue_title": "is_zero is incorrect on complex integer",
        "issue_body": "`is_zero` should return `None` if it cannot decide, but should never give the wrong answer. However:\r\n\r\n```\r\n>>> e = -2*I + (1 + I)**2\r\n>>> e.is_zero\r\nFalse\r\n>>> simplify(e).is_zero\r\nTrue\r\n```\r\n\r\nThis is causing errors in determining the rank of a matrix. See issue #15872 ",
        "issue_id": 15873,
        "pr_number": 15875,
        "pr_title": "[WIP] Fixing is_zero for complex numbers in Add",
        "pr_body": "<!-- 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://github.com/blog/1506-closing-issues-via-pull-requests . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\nfixes #15873\r\n\r\ncloses #15880\r\n#### Brief description of what is fixed or changed\r\n\r\nThe example `-2*I + (1 + I)**2` gets past the breakpoint\r\n```\r\n            if im and not im_or_z:\r\n                return False\r\n```\r\ngiving the wrong determination.\r\n\r\nFrom my understanding, the original logic seems identical to separating the expression into real and imaginary parts and testing it against zero, ~~so I may experiment here with more simple logic.~~\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. 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\r\n- core\r\n  - Fix `is_zero` becoming `False` on some expressions with `Add`.\r\n\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-01-30T04:42:31Z",
        "base_commit": "b506169ad727ee39cb3d60c8b3ff5e315d443d8e"
      },
      "summary": "### Summary:\nThis issue pertains to the incorrect behavior of the `is_zero` method when applied to complex expressions within a symbolic mathematics library. The method is designed to evaluate whether a given expression equates to zero and should return `None` if it cannot conclusively determine the result, avoiding incorrect evaluations. However, the method incorrectly returns `False` for a specific complex integer expression, which, upon simplification, evaluates correctly to `True`. This discrepancy leads to errors in higher-level computations, such as determining the rank of a matrix, which relies on accurate zero evaluations. The affected component is the `Add._eval_is_zero` function within the library, indicating that the issue lies within the logic used to evaluate zero equivalence in additive expressions. The problem has a notable impact on any computations or algorithms dependent on accurate zero evaluations, potentially leading to incorrect mathematical conclusions or computational errors.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: is_zero is incorrect on complex integer\n\nBody:\n`is_zero` should return `None` if it cannot decide, but should never give the wrong answer. However:\r\n\r\n```\r\n>>> e = -2*I + (1 + I)**2\r\n>>> e.is_zero\r\nFalse\r\n>>> simplify(e).is_zero\r\nTrue\r\n```\r\n\r\nThis is causing errors in determining the rank of a matrix. See issue #15872 \n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/core/add.py\n  function: Add._eval_is_zero\n"
    }
  ]
}