{
  "original_problem": {
    "instance_id": "sympy__sympy-18698",
    "repo": "sympy/sympy",
    "created_at": "2020-02-21T05:46:56Z",
    "problem_statement": "sqf and sqf_list output is not consistant\nThe example below is wrong in the sense that we should have (x*_2 - 5_x + 6, 3) and not 2 factors of multiplicity 3.\n\n```\n>  sqf_list(  (x**2 + 1)  * (x - 1)**2 * (x - 2)**3 * (x - 3)**3  )\n\n>  (1, [(x**2 + 1, 1), (x - 1, 2), (x - 3, 3), (x - 2, 3)])\n```\n\nwhereas below is correct --- one factor of multiplicity 2\n\n```\n>  sqf_list( x**5 - 2*x**4 - 2*x**3 + 4*x**2 + x - 2 )\n\n>  (1, [(x - 2, 1), (x**2 - 1, 2)])\n```\n\n",
    "patch": "diff --git a/sympy/polys/polytools.py b/sympy/polys/polytools.py\n--- a/sympy/polys/polytools.py\n+++ b/sympy/polys/polytools.py\n@@ -2,7 +2,8 @@\n \n from __future__ import print_function, division\n \n-from functools import wraps\n+from functools import wraps, reduce\n+from operator import mul\n \n from sympy.core import (\n     S, Basic, Expr, I, Integer, Add, Mul, Dummy, Tuple\n@@ -5905,10 +5906,7 @@ def _symbolic_factor_list(expr, opt, method):\n         if arg.is_Number:\n             coeff *= arg\n             continue\n-        if arg.is_Mul:\n-            args.extend(arg.args)\n-            continue\n-        if arg.is_Pow:\n+        elif arg.is_Pow:\n             base, exp = arg.args\n             if base.is_Number and exp.is_Number:\n                 coeff *= arg\n@@ -5949,6 +5947,9 @@ def _symbolic_factor_list(expr, opt, method):\n                         other.append((f, k))\n \n                 factors.append((_factors_product(other), exp))\n+    if method == 'sqf':\n+        factors = [(reduce(mul, (f for f, _ in factors if _ == k)), k)\n+                   for k in set(i for _, i in factors)]\n \n     return coeff, factors\n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_12571",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves recursion errors in assumption handling, which is unrelated to the factorization logic in the current issue."
      },
      {
        "idx": 2,
        "id": "similar_6952",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about performance in symbolic integration, not about factorization or multiplicity handling."
      },
      {
        "idx": 3,
        "id": "similar_8626",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves iterator management in force computation, which does not relate to factorization or multiplicity logic."
      },
      {
        "idx": 4,
        "id": "similar_6988",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about simplification of logarithmic expressions, not about factorization or handling multiplicities."
      },
      {
        "idx": 5,
        "id": "similar_12254",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve handling multiplicative factors in symbolic expressions, suggesting transferable reasoning in factor extraction."
      }
    ]
  },
  "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 a software bug within the SymPy library, specifically affecting the computation of limits involving the LambertW function. The core problem manifests as a RecursionError when attempting to evaluate the limit of the expression `-LambertW(-log(t))/log(t)` as `t` approaches 1. The error occurs due to infinite recursion within the assumption handling mechanism in SymPy's core, leading to a crash. The symptoms include a long traceback of errors related to KeyError exceptions for assumptions like 'zero' and 'irrational', eventually culminating in a RecursionError. This problem affects the components responsible for symbolic limit computation and series expansion within the SymPy library. The potential impact is significant for users relying on symbolic computation of limits, as it prevents the correct evaluation of certain mathematical expressions, leading to incorrect results or application crashes. The issue highlights a need for improved handling of assumptions and recursion depth in symbolic calculations, particularly when dealing with complex functions like LambertW. The fix involved modifications in the evaluation and algebraic checking functions for LambertW and the multigamma function, ensuring a more robust computation process.",
      "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": "recognize elliptical integrals",
        "issue_body": "```\nThis requires about 2 minutes\n\n>>> Ellipse((0,0),3,1).circumference.n()\n13.3648932205553\n\n\nThis is nearly instantaneous\n\n>>> def EllipseCircumference(a, b):\n...    \"\"\"\n...    Compute the circumference of an ellipse with semi-axes a and b.\n...    Require a >= 0 and b >= 0.  Relative accuracy is about 0.5^53.\n...    \"\"\"\n...    import math\n...    x, y = max(a, b), min(a, b)\n...    digits = 53; tol = math.sqrt(math.pow(0.5, digits))\n...    if digits * y < tol * x: return 4 * x\n...    s = 0; m = 1\n...    while x - y > tol * y:\n...       x, y = 0.5 * (x + y), math.sqrt(x * y)\n...       m *= 2; s += m * math.pow(x - y, 2)\n...    return math.pi * (math.pow(a + b, 2) - s) / (x + y)\n...\n>>> EllipseCircumference(3,1)\n13.364893220555258\n>>>\n\nPerhaps recognition of such integrals by integrate/Integral.evalf would be a good idea.\n```\n\nOriginal issue for #6952: http://code.google.com/p/sympy/issues/detail?id=3853\nOriginal author: https://code.google.com/u/117933771799683895267/\n",
        "issue_id": 6952,
        "pr_number": 15286,
        "pr_title": "Implemented finding equation of Ellipse using slope as parameter and another method for calculation of circumference of ellipse - continued",
        "pr_body": "Implemented finding equation of Ellipse using slope as parameter.\r\n\r\nWhen the rotated ellipse is supported, this calculation can still be used but the `_slope` keyword will not be needed: the slope will be an attribute of the rotated ellipse.\r\n\r\nFixes #2815\r\nFixes #6952\r\nCloses #15053 \r\n\r\nThis PR uses the approach to finding equation of ellipse using slope, length of semi minor axis and length of semi major axis as inputs given [here](https://math.stackexchange.com/questions/108270/what-is-the-equation-of-an-ellipse-that-is-not-aligned-with-the-axis/646971#646971)\r\nThis could be an added functionality to the equation finding method in class `Ellipse`.\r\nThanks to @smichr  for providing the approach.\r\n\r\nNote : This is a continuation of #15053 \r\nPlease take a look at this PR and suggest changes. I will be glad to implement them.\r\nThanks.\r\n\r\n#### Release Notes\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n* geometry\r\n   * Implemented private method for finding equation of Ellipse using `_slope` as parameter\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2018-10-01T21:27:53Z",
        "base_commit": "5997e30a33f92e6b4b4d351e835feb7379a0e31d"
      },
      "summary": "### Summary:\nThis issue pertains to the computational performance of determining the circumference of an ellipse using symbolic mathematics software, specifically SymPy. The primary symptom reported is the significant discrepancy in computation time when calculating ellipse circumferences through symbolic versus numerical methods. The symbolic approach, via the `Ellipse` class's `circumference.n()` method, takes approximately two minutes to complete, whereas an equivalent numerical method, `EllipseCircumference(a, b)`, executes almost instantaneously. The problem highlights a potential gap in the symbolic engine's capability to efficiently compute integrals related to ellipses. The affected components include the symbolic integration functions, primarily those responsible for evaluating elliptical integrals. The potential impact of this issue is a reduced efficiency in performing symbolic calculations involving ellipses, which could affect users relying on SymPy for rapid computations in mathematical and engineering applications. The report suggests that enhancing the symbolic integration capabilities to recognize and handle elliptical integrals more efficiently could address the observed performance bottleneck.",
      "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: recognize elliptical integrals\n\nBody:\n```\nThis requires about 2 minutes\n\n>>> Ellipse((0,0),3,1).circumference.n()\n13.3648932205553\n\n\nThis is nearly instantaneous\n\n>>> def EllipseCircumference(a, b):\n...    \"\"\"\n...    Compute the circumference of an ellipse with semi-axes a and b.\n...    Require a >= 0 and b >= 0.  Relative accuracy is about 0.5^53.\n...    \"\"\"\n...    import math\n...    x, y = max(a, b), min(a, b)\n...    digits = 53; tol = math.sqrt(math.pow(0.5, digits))\n...    if digits * y < tol * x: return 4 * x\n...    s = 0; m = 1\n...    while x - y > tol * y:\n...       x, y = 0.5 * (x + y), math.sqrt(x * y)\n...       m *= 2; s += m * math.pow(x - y, 2)\n...    return math.pi * (math.pow(a + b, 2) - s) / (x + y)\n...\n>>> EllipseCircumference(3,1)\n13.364893220555258\n>>>\n\nPerhaps recognition of such integrals by integrate/Integral.evalf would be a good idea.\n```\n\nOriginal issue for #6952: http://code.google.com/p/sympy/issues/detail?id=3853\nOriginal author: https://code.google.com/u/117933771799683895267/\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/geometry/ellipse.py\n  function: Ellipse.encloses_point\n  function: Circle.equation\n  function: Circle.equation\n"
    },
    {
      "similar_issue": {
        "issue_title": "bug in physics/mechanics/lagrange.py",
        "issue_body": "When providing a `forcelist` with more than one force, not all terms are computed,\nthis comes from the fact that the iterator `flist = zip(*_f_list_parser(self.forcelist, N))` is consumed in the first iteration of the loop.\n\nI propose a following PR that fixes the bug, let me know if I need to also provide a test case.\n\nBest,\nGuillaume\n",
        "issue_id": 8626,
        "pr_number": 8627,
        "pr_title": "Bug Fix #8626",
        "pr_body": "Let me know if a test case is needed\n",
        "issue_closed_at": "2015-01-06T16:57:16Z",
        "base_commit": "65f7c8c2c9c1927eaa8520c4ce06864f93a20ad1"
      },
      "summary": "### Summary:\nThis issue pertains to a bug within the `LagrangesMethod.form_lagranges_equations` function of the `sympy/physics/mechanics/lagrange.py` module. The problem arises when a list of forces (`forcelist`) containing more than one force is provided as input. The core issue is that not all terms are computed due to the iterator `flist` being exhausted during the first iteration of the loop. This indicates a flaw in how the iterator is managed, leading to incomplete processing of force terms. The key symptom is the partial computation of forces, which could result in inaccurate or incomplete physics simulations. The severity of this issue is potentially significant for users relying on precise force computations in their mechanical simulations or analyses. The proposed solution involves modifying the code to ensure that the iterator is properly handled to avoid premature consumption, thereby ensuring all forces in the list are processed as intended.",
      "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: bug in physics/mechanics/lagrange.py\n\nBody:\nWhen providing a `forcelist` with more than one force, not all terms are computed,\nthis comes from the fact that the iterator `flist = zip(*_f_list_parser(self.forcelist, N))` is consumed in the first iteration of the loop.\n\nI propose a following PR that fixes the bug, let me know if I need to also provide a test case.\n\nBest,\nGuillaume\n\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/physics/mechanics/lagrange.py\n  function: LagrangesMethod.form_lagranges_equations\n"
    },
    {
      "similar_issue": {
        "issue_title": "expand_log(exp(x), force=True) should give x",
        "issue_body": "```\nIn [5]: expand_log(log(exp(x)), force=True)\nOut[5]:\n   ⎛ x⎞\nlog⎝ℯ ⎠\n\nIn [6]: expand_log(log(y**(x)), force=True)\nOut[6]: x⋅log(y) Issue 1799 is probably to blame.\n```\n\nOriginal issue for #6988: http://code.google.com/p/sympy/issues/detail?id=3889\nOriginal author: https://code.google.com/u/asmeurer@gmail.com/\n",
        "issue_id": 6988,
        "pr_number": 8548,
        "pr_title": "Issue #6988: expand_log(exp(x), force=True) = x",
        "pr_body": "This is a try to fix issue #6988. If I made some mistake just let me know, as I'm still new to sympy development.\n\n```\nIn [9]: expand_log(log(exp(x)), force=True)\nOut[9]: x\n\nIn [10]: expand_log(log(y**(x)), force=True)\nOut[10]: x⋅log(y)\n```\n",
        "issue_closed_at": "2014-12-03T13:34:14Z",
        "base_commit": "e6fc53f27ee872b27bc79b96529fc4bf34d4f023"
      },
      "summary": "### Summary:\nThis issue pertains to the behavior of the `expand_log` function in the SymPy library, a Python library for symbolic mathematics. Specifically, the function does not simplify the logarithm of an exponential expression as expected when the `force=True` parameter is used. \n\n1. **Problem Description**: The `expand_log` function should properly simplify expressions involving logarithms and exponentials. In general terms, the function is expected to simplify `log(exp(x))` directly to `x` when the `force` parameter is set to `True`.\n\n2. **Key Symptoms and Behaviors Observed**: When users input `expand_log(log(exp(x)), force=True)`, the output is not simplified to `x` as anticipated but rather remains in the form `log(e^x)`. In contrast, similar expressions like `expand_log(log(y**(x)), force=True)` correctly simplify to `x * log(y)`.\n\n3. **Affected Components or Systems**: The issue affects the `log._eval_expand_log` function within the `sympy/functions/elementary/exponential.py` file. This is a core component responsible for the mathematical expansion and simplification of logarithmic expressions involving exponentials.\n\n4. **Potential Impact or Severity**: This issue can cause incorrect or unexpected results when users rely on the `expand_log` function for simplifying expressions, potentially affecting any downstream calculations or symbolic computations that depend on these simplifications. It is particularly relevant for users performing complex symbolic mathematics or developing algorithms that require precise logarithmic transformations.\n\n5. **Relevant Technical Details**: The issue highlights a discrepancy in the simplification process of logarithmic expressions when forced simplification is requested. The technical fix involves ensuring that the `expand_log` function correctly applies simplification rules to logarithmic expressions involving exponentials, aligning the function's behavior with mathematical expectations and user intentions. The solution requires updating the logic within the `log._eval_expand_log` method to handle these cases appropriately.",
      "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: expand_log(exp(x), force=True) should give x\n\nBody:\n```\nIn [5]: expand_log(log(exp(x)), force=True)\nOut[5]:\n   ⎛ x⎞\nlog⎝ℯ ⎠\n\nIn [6]: expand_log(log(y**(x)), force=True)\nOut[6]: x⋅log(y) Issue 1799 is probably to blame.\n```\n\nOriginal issue for #6988: http://code.google.com/p/sympy/issues/detail?id=3889\nOriginal author: https://code.google.com/u/asmeurer@gmail.com/\n\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_expand_log\n"
    },
    {
      "similar_issue": {
        "issue_title": "cannot extract_multiplicatively(-2) from (-2*x - 2*y)",
        "issue_body": "I think this might be a bug.\r\n````\r\n>>> (2+4*I).extract_multiplicatively(2)    # yes\r\n1 + 2*I\r\n>>> (-2-4*I).extract_multiplicatively(-1)   # yes\r\n2 + 4*I\r\n>>> (-2-4*I).extract_multiplicatively(-2)   # bug?\r\n````\r\nsimilarly:\r\n````\r\n>>> (2*x + 4*y + 8).extract_multiplicatively(2)   # yes\r\nx + 2*y + 4\r\n>>> (-2*x - 4*y - 8).extract_multiplicatively(2)    # yes\r\n-x - 2*y - 4\r\n>>> (-2*x - 4*y - 8).extract_multiplicatively(-1)    # yes\r\n2*x + 4*y + 8\r\n>>> (-2*x - 4*y - 8).extract_multiplicatively(-2)    # bug?\r\n````\r\n\r\nAssuming it is indeed a bug, here is why it happens:\r\n\r\nLook in `core/expr.py` where:\r\n````\r\n>>> (-2*x - 4*y - 8).primitive()\r\n(2, -x - 2*y - 4)\r\n````\r\nwhich is then made into a *non-evaluated* `Mul`, from which `-2` cannot be multiplicatively extracted; for example:\r\n````\r\n>>> Mul(2, -x).extract_multiplicatively(-2)\r\nx\r\n>>> Mul(2, -x, evaluate=False).extract_multiplicatively(-2)\r\n````\r\n@smichr do you think this is bug? (see your commit 8968b85310506c0a2b34f3d7aeb8e0d88f87885b: not clear whether we still need this special case anyway)",
        "issue_id": 12254,
        "pr_number": 12270,
        "pr_title": "fix bug in extract_multiplicatively()",
        "pr_body": "Fixes #12254 .\r\nCan you review this and suggest improvements @smichr, @cbm755 ?\r\n\r\nAnd consider this test case : \r\n```\r\n>>> (4*y**2*(-x*y-2*y)).extract_multiplicatively(-2*y)\r\n```\r\nI am not sure whether we should return ```None``` or ```2*x*y**2 + 4*y**2``` ,  currently it returns ```None```",
        "issue_closed_at": "2017-03-11T15:24:28Z",
        "base_commit": "a79801c044c2b0ed74176e4abc18f4ca2b38ac58"
      },
      "summary": "### Summary: This issue is related to the inability of a mathematical expression handling function, `extract_multiplicatively`, within the symbolic mathematics library to correctly factor out a negative multiplicative factor under specific circumstances. The problem manifests when attempting to extract a negative factor from a symbolic expression, particularly when the expression is represented in a non-evaluated multiplication form. The key symptoms include the function failing to return an expected simplified expression when a negative factor is involved, potentially leading to incorrect mathematical analysis or computation. The affected component is the `extract_multiplicatively` function in the `sympy/core/expr.py` module, which is responsible for manipulating symbolic expressions. The severity of this issue could vary depending on the context, as it might lead to incorrect results or misinterpretations in mathematical computations or symbolic reasoning tasks utilizing this function. Technically, the issue arises from the non-evaluated `Mul` object, which prevents the proper extraction of the negative factor, highlighting a limitation or oversight in the handling of such expressions within the library.",
      "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: cannot extract_multiplicatively(-2) from (-2*x - 2*y)\n\nBody:\nI think this might be a bug.\r\n````\r\n>>> (2+4*I).extract_multiplicatively(2)    # yes\r\n1 + 2*I\r\n>>> (-2-4*I).extract_multiplicatively(-1)   # yes\r\n2 + 4*I\r\n>>> (-2-4*I).extract_multiplicatively(-2)   # bug?\r\n````\r\nsimilarly:\r\n````\r\n>>> (2*x + 4*y + 8).extract_multiplicatively(2)   # yes\r\nx + 2*y + 4\r\n>>> (-2*x - 4*y - 8).extract_multiplicatively(2)    # yes\r\n-x - 2*y - 4\r\n>>> (-2*x - 4*y - 8).extract_multiplicatively(-1)    # yes\r\n2*x + 4*y + 8\r\n>>> (-2*x - 4*y - 8).extract_multiplicatively(-2)    # bug?\r\n````\r\n\r\nAssuming it is indeed a bug, here is why it happens:\r\n\r\nLook in `core/expr.py` where:\r\n````\r\n>>> (-2*x - 4*y - 8).primitive()\r\n(2, -x - 2*y - 4)\r\n````\r\nwhich is then made into a *non-evaluated* `Mul`, from which `-2` cannot be multiplicatively extracted; for example:\r\n````\r\n>>> Mul(2, -x).extract_multiplicatively(-2)\r\nx\r\n>>> Mul(2, -x, evaluate=False).extract_multiplicatively(-2)\r\n````\r\n@smichr do you think this is bug? (see your commit 8968b85310506c0a2b34f3d7aeb8e0d88f87885b: not clear whether we still need this special case anyway)\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/expr.py\n  line: line 11\n  function: Expr.extract_multiplicatively\n  function: Expr.extract_multiplicatively\n  function: Expr.extract_multiplicatively\n"
    }
  ]
}