{
  "Selected_candidate": {
    "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_id": 12571,
    "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_closed_at": "2019-08-19T00:30:44Z",
    "base_commit": "b28eadab3661a28bfeb2aadffd5c273035057fd1",
    "changes": [
      {
        "file": "sympy/functions/elementary/exponential.py",
        "type": "function",
        "name": "eval",
        "class_name": "LambertW",
        "code": "def eval(cls, x, k=None):\n        if k is S.Zero:\n            return cls(x)\n        elif k is None:\n            k = S.Zero\n\n        if k is S.Zero:\n            if x is S.Zero:\n                return S.Zero\n            if x is S.Exp1:\n                return S.One\n            if x == -1/S.Exp1:\n                return S.NegativeOne\n            if x == -log(2)/2:\n                return -log(2)\n            if x is S.Infinity:\n                return S.Infinity\n\n        if fuzzy_not(k.is_zero):\n            if x is S.Zero:\n                return S.NegativeInfinity\n        if k is S.NegativeOne:\n            if x == -S.Pi/2:\n                return -S.ImaginaryUnit*S.Pi/2\n            elif x == -1/S.Exp1:\n                return S.NegativeOne\n            elif x == -2*exp(-2):\n                return -Integer(2)"
      },
      {
        "file": "sympy/functions/elementary/exponential.py",
        "type": "function",
        "name": "_eval_is_algebraic",
        "class_name": "LambertW",
        "code": "def _eval_is_algebraic(self):\n        s = self.func(*self.args)\n        if s.func == self.func:\n            if fuzzy_not(self.args[0].is_zero) and self.args[0].is_algebraic:\n                return False\n        else:\n            return s.is_algebraic"
      },
      {
        "file": "sympy/functions/special/gamma_functions.py",
        "type": "line",
        "name": "line 7",
        "code": "from sympy.core.power import Pow\nfrom sympy.core.logic import fuzzy_and, fuzzy_not\nfrom sympy.functions.special.zeta_functions import zeta\nfrom sympy.functions.special.error_functions import erf, erfc\nfrom sympy.functions.elementary.exponential import exp, log\nfrom sympy.functions.elementary.integers import ceiling, floor\nfrom sympy.functions.elementary.miscellaneous import sqrt"
      },
      {
        "file": "sympy/functions/special/gamma_functions.py",
        "type": "function",
        "name": "eval",
        "class_name": "multigamma",
        "code": "def eval(cls, x, p):\n        from sympy import Product\n        x, p = map(sympify, (x, p))\n        if p.is_positive is False or p.is_integer is False:\n            raise ValueError('Order parameter p must be positive integer.')\n        k = Dummy(\"k\")\n        return (pi**(p*(p - 1)/4)*Product(gamma(x + (1 - k)/2),\n                                          (k, 1, p))).doit()"
      },
      {
        "file": "sympy/functions/special/gamma_functions.py",
        "type": "function",
        "name": "eval",
        "class_name": "multigamma",
        "code": "def eval(cls, x, p):\n        from sympy import Product\n        x, p = map(sympify, (x, p))\n        if p.is_positive is False or p.is_integer is False:\n            raise ValueError('Order parameter p must be positive integer.')\n        k = Dummy(\"k\")\n        return (pi**(p*(p - 1)/4)*Product(gamma(x + (1 - k)/2),\n                                          (k, 1, p))).doit()"
      }
    ]
  },
  "Justification": "Candidate E is the most relevant due to similarities in the error context concerning the handling of infinity and complex expressions. Both the CURRENT bug and Candidate E's bug revolve around special cases in limits and exponential functions, which suggest a deep integration with how these expressions are evaluated in SymPy. This context may lead to an understanding of the failure when evaluating `0**-oo` as it relates to limit handling in mathematical expressions. Insights from Candidate E's resolution strategy on series expansion for functions including LambertW might also shed light on enhancing correct evaluations of complex expressions, ultimately aiding in debugging the CURRENT bug.",
  "instance_id": "sympy__sympy-20212",
  "repo": "sympy/sympy",
  "created_at": "2020-10-06T11:34:13Z",
  "problem_statement": "0**-oo produces 0, the documentation says it should produce zoo\nUsing SymPy 1.5.1, evaluate `0**-oo` produces `0`.\r\n\r\nThe documentation for the Pow class states that it should return `ComplexInfinity`, aka `zoo`\r\n\r\n| expr | value | reason |\r\n| :-- | :-- | :--|\r\n| `0**-oo` | `zoo` | This is not strictly true, as 0**oo may be oscillating between positive and negative values or rotating in the complex plane. It is convenient, however, when the base is positive.|\r\n\n",
  "patch": "diff --git a/sympy/core/power.py b/sympy/core/power.py\n--- a/sympy/core/power.py\n+++ b/sympy/core/power.py\n@@ -291,6 +291,8 @@ def __new__(cls, b, e, evaluate=None):\n             ).warn()\n \n         if evaluate:\n+            if b is S.Zero and e is S.NegativeInfinity:\n+                return S.ComplexInfinity\n             if e is S.ComplexInfinity:\n                 return S.NaN\n             if e is S.Zero:\n"
}