{
  "instance_id": "sympy__sympy-18698",
  "repo": "sympy/sympy",
  "created_at": "2020-02-21T05:46:56Z",
  "problem_statement": "sqf and sqf_list output is not consistant\nThe example below is wrong in the sense that we should have (x*_2 - 5_x + 6, 3) and not 2 factors of multiplicity 3.\n\n```\n>  sqf_list(  (x**2 + 1)  * (x - 1)**2 * (x - 2)**3 * (x - 3)**3  )\n\n>  (1, [(x**2 + 1, 1), (x - 1, 2), (x - 3, 3), (x - 2, 3)])\n```\n\nwhereas below is correct --- one factor of multiplicity 2\n\n```\n>  sqf_list( x**5 - 2*x**4 - 2*x**3 + 4*x**2 + x - 2 )\n\n>  (1, [(x - 2, 1), (x**2 - 1, 2)])\n```\n\n",
  "patch": "diff --git a/sympy/polys/polytools.py b/sympy/polys/polytools.py\n--- a/sympy/polys/polytools.py\n+++ b/sympy/polys/polytools.py\n@@ -2,7 +2,8 @@\n \n from __future__ import print_function, division\n \n-from functools import wraps\n+from functools import wraps, reduce\n+from operator import mul\n \n from sympy.core import (\n     S, Basic, Expr, I, Integer, Add, Mul, Dummy, Tuple\n@@ -5905,10 +5906,7 @@ def _symbolic_factor_list(expr, opt, method):\n         if arg.is_Number:\n             coeff *= arg\n             continue\n-        if arg.is_Mul:\n-            args.extend(arg.args)\n-            continue\n-        if arg.is_Pow:\n+        elif arg.is_Pow:\n             base, exp = arg.args\n             if base.is_Number and exp.is_Number:\n                 coeff *= arg\n@@ -5949,6 +5947,9 @@ def _symbolic_factor_list(expr, opt, method):\n                         other.append((f, k))\n \n                 factors.append((_factors_product(other), exp))\n+    if method == 'sqf':\n+        factors = [(reduce(mul, (f for f, _ in factors if _ == k)), k)\n+                   for k in set(i for _, i in factors)]\n \n     return coeff, factors\n \n",
  "similar_bug_items": [
    {
      "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()"
        }
      ]
    },
    {
      "pr_number": 15286,
      "pr_title": "Implemented finding equation of Ellipse using slope as parameter and another method for calculation of circumference of ellipse - continued",
      "pr_body": "Implemented finding equation of Ellipse using slope as parameter.\r\n\r\nWhen the rotated ellipse is supported, this calculation can still be used but the `_slope` keyword will not be needed: the slope will be an attribute of the rotated ellipse.\r\n\r\nFixes #2815\r\nFixes #6952\r\nCloses #15053 \r\n\r\nThis PR uses the approach to finding equation of ellipse using slope, length of semi minor axis and length of semi major axis as inputs given [here](https://math.stackexchange.com/questions/108270/what-is-the-equation-of-an-ellipse-that-is-not-aligned-with-the-axis/646971#646971)\r\nThis could be an added functionality to the equation finding method in class `Ellipse`.\r\nThanks to @smichr  for providing the approach.\r\n\r\nNote : This is a continuation of #15053 \r\nPlease take a look at this PR and suggest changes. I will be glad to implement them.\r\nThanks.\r\n\r\n#### Release Notes\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n* geometry\r\n   * Implemented private method for finding equation of Ellipse using `_slope` as parameter\r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 6952,
      "issue_title": "recognize elliptical integrals",
      "issue_body": "```\nThis requires about 2 minutes\n\n>>> Ellipse((0,0),3,1).circumference.n()\n13.3648932205553\n\n\nThis is nearly instantaneous\n\n>>> def EllipseCircumference(a, b):\n...    \"\"\"\n...    Compute the circumference of an ellipse with semi-axes a and b.\n...    Require a >= 0 and b >= 0.  Relative accuracy is about 0.5^53.\n...    \"\"\"\n...    import math\n...    x, y = max(a, b), min(a, b)\n...    digits = 53; tol = math.sqrt(math.pow(0.5, digits))\n...    if digits * y < tol * x: return 4 * x\n...    s = 0; m = 1\n...    while x - y > tol * y:\n...       x, y = 0.5 * (x + y), math.sqrt(x * y)\n...       m *= 2; s += m * math.pow(x - y, 2)\n...    return math.pi * (math.pow(a + b, 2) - s) / (x + y)\n...\n>>> EllipseCircumference(3,1)\n13.364893220555258\n>>>\n\nPerhaps recognition of such integrals by integrate/Integral.evalf would be a good idea.\n```\n\nOriginal issue for #6952: http://code.google.com/p/sympy/issues/detail?id=3853\nOriginal author: https://code.google.com/u/117933771799683895267/\n",
      "issue_closed_at": "2018-10-01T21:27:53Z",
      "base_commit": "5997e30a33f92e6b4b4d351e835feb7379a0e31d",
      "changes": [
        {
          "file": "sympy/geometry/ellipse.py",
          "type": "function",
          "name": "encloses_point",
          "class_name": "Ellipse",
          "code": "def encloses_point(self, p):\n        \"\"\"\n        Return True if p is enclosed by (is inside of) self.\n\n        Notes\n        -----\n        Being on the border of self is considered False.\n\n        Parameters\n        ==========\n\n        p : Point\n\n        Returns\n        =======\n\n        encloses_point : True, False or None\n\n        See Also\n        ========\n\n        sympy.geometry.point.Point\n\n        Examples\n        ========\n\n        >>> from sympy import Ellipse, S\n        >>> from sympy.abc import t\n        >>> e = Ellipse((0, 0), 3, 2)\n        >>> e.encloses_point((0, 0))\n        True\n        >>> e.encloses_point(e.arbitrary_point(t).subs(t, S.Half))\n        False\n        >>> e.encloses_point((4, 0))\n        False\n\n        \"\"\"\n        p = Point(p, dim=2)\n        if p in self:\n            return False\n\n        if len(self.foci) == 2:\n            # if the combined distance from the foci to p (h1 + h2) is less\n            # than the combined distance from the foci to the minor axis\n            # (which is the same as the major axis length) then p is inside\n            # the ellipse\n            h1, h2 = [f.distance(p) for f in self.foci]\n            test = 2*self.major - (h1 + h2)\n        else:\n            test = self.radius - self.center.distance(p)\n\n        return fuzzy_bool(test.is_positive)"
        },
        {
          "file": "sympy/geometry/ellipse.py",
          "type": "function",
          "name": "equation",
          "class_name": "Circle",
          "code": "def equation(self, x='x', y='y'):\n        \"\"\"The equation of the circle.\n\n        Parameters\n        ==========\n\n        x : str or Symbol, optional\n            Default value is 'x'.\n        y : str or Symbol, optional\n            Default value is 'y'.\n\n        Returns\n        =======\n\n        equation : SymPy expression\n\n        Examples\n        ========\n\n        >>> from sympy import Point, Circle\n        >>> c1 = Circle(Point(0, 0), 5)\n        >>> c1.equation()\n        x**2 + y**2 - 25\n\n        \"\"\"\n        x = _symbol(x, real=True)\n        y = _symbol(y, real=True)\n        t1 = (x - self.center.x)**2\n        t2 = (y - self.center.y)**2\n        return t1 + t2 - self.major**2"
        },
        {
          "file": "sympy/geometry/ellipse.py",
          "type": "function",
          "name": "equation",
          "class_name": "Circle",
          "code": "def equation(self, x='x', y='y'):\n        \"\"\"The equation of the circle.\n\n        Parameters\n        ==========\n\n        x : str or Symbol, optional\n            Default value is 'x'.\n        y : str or Symbol, optional\n            Default value is 'y'.\n\n        Returns\n        =======\n\n        equation : SymPy expression\n\n        Examples\n        ========\n\n        >>> from sympy import Point, Circle\n        >>> c1 = Circle(Point(0, 0), 5)\n        >>> c1.equation()\n        x**2 + y**2 - 25\n\n        \"\"\"\n        x = _symbol(x, real=True)\n        y = _symbol(y, real=True)\n        t1 = (x - self.center.x)**2\n        t2 = (y - self.center.y)**2\n        return t1 + t2 - self.major**2"
        }
      ]
    },
    {
      "pr_number": 8627,
      "pr_title": "Bug Fix #8626",
      "pr_body": "Let me know if a test case is needed\n",
      "issue_id": 8626,
      "issue_title": "bug in physics/mechanics/lagrange.py",
      "issue_body": "When providing a `forcelist` with more than one force, not all terms are computed,\nthis comes from the fact that the iterator `flist = zip(*_f_list_parser(self.forcelist, N))` is consumed in the first iteration of the loop.\n\nI propose a following PR that fixes the bug, let me know if I need to also provide a test case.\n\nBest,\nGuillaume\n",
      "issue_closed_at": "2015-01-06T16:57:16Z",
      "base_commit": "65f7c8c2c9c1927eaa8520c4ce06864f93a20ad1",
      "changes": [
        {
          "file": "sympy/physics/mechanics/lagrange.py",
          "type": "function",
          "name": "form_lagranges_equations",
          "class_name": "LagrangesMethod",
          "code": "def form_lagranges_equations(self):\n        \"\"\"Method to form Lagrange's equations of motion.\n\n        Returns a vector of equations of motion using Lagrange's equations of\n        the second kind.\n        \"\"\"\n\n        qds = self._qdots\n        qdd_zero = dict((i, 0) for i in self._qdoubledots)\n        n = len(self.q)\n\n        # Internally we represent the EOM as four terms:\n        # EOM = term1 - term2 - term3 - term4 = 0\n\n        # First term\n        self._term1 = self._L.jacobian(qds)\n        self._term1 = self._term1.diff(dynamicsymbols._t).T\n\n        # Second term\n        self._term2 = self._L.jacobian(self.q).T\n\n        # Third term\n        if self.coneqs:\n            coneqs = self.coneqs\n            m = len(coneqs)\n            # Creating the multipliers\n            self.lam_vec = Matrix(dynamicsymbols('lam1:' + str(m + 1)))\n            self.lam_coeffs = -coneqs.jacobian(qds)\n            self._term3 = self.lam_coeffs.T * self.lam_vec\n            # Extracting the coeffecients of the qdds from the diff coneqs\n            diffconeqs = coneqs.diff(dynamicsymbols._t)\n            self._m_cd = diffconeqs.jacobian(self._qdoubledots)\n            # The remaining terms i.e. the 'forcing' terms in diff coneqs\n            self._f_cd = -diffconeqs.subs(qdd_zero)\n        else:\n            self._term3 = zeros(n, 1)\n\n        # Fourth term\n        if self.forcelist:\n            N = self.inertial\n            self._term4 = zeros(n, 1)\n            flist = zip(*_f_list_parser(self.forcelist, N))\n            for i, qd in enumerate(qds):\n                for obj, force in self.forcelist:\n                    self._term4[i] = sum(v.diff(qd, N) & f for (v, f) in flist)\n        else:\n            self._term4 = zeros(n, 1)\n\n        # Form the dynamic mass and forcing matrices\n        without_lam = self._term1 - self._term2 - self._term4\n        self._m_d = without_lam.jacobian(self._qdoubledots)\n        self._f_d = -without_lam.subs(qdd_zero)\n\n        # Form the EOM\n        self.eom = without_lam - self._term3\n        return self.eom"
        }
      ]
    },
    {
      "pr_number": 8548,
      "pr_title": "Issue #6988: expand_log(exp(x), force=True) = x",
      "pr_body": "This is a try to fix issue #6988. If I made some mistake just let me know, as I'm still new to sympy development.\n\n```\nIn [9]: expand_log(log(exp(x)), force=True)\nOut[9]: x\n\nIn [10]: expand_log(log(y**(x)), force=True)\nOut[10]: x\u22c5log(y)\n```\n",
      "issue_id": 6988,
      "issue_title": "expand_log(exp(x), force=True) should give x",
      "issue_body": "```\nIn [5]: expand_log(log(exp(x)), force=True)\nOut[5]:\n   \u239b x\u239e\nlog\u239d\u212f \u23a0\n\nIn [6]: expand_log(log(y**(x)), force=True)\nOut[6]: x\u22c5log(y) Issue 1799 is probably to blame.\n```\n\nOriginal issue for #6988: http://code.google.com/p/sympy/issues/detail?id=3889\nOriginal author: https://code.google.com/u/asmeurer@gmail.com/\n",
      "issue_closed_at": "2014-12-03T13:34:14Z",
      "base_commit": "e6fc53f27ee872b27bc79b96529fc4bf34d4f023",
      "changes": [
        {
          "file": "sympy/functions/elementary/exponential.py",
          "type": "function",
          "name": "_eval_expand_log",
          "class_name": "log",
          "code": "def _eval_expand_log(self, deep=True, **hints):\n        from sympy import unpolarify\n        from sympy.concrete import Sum, Product\n        force = hints.get('force', False)\n        arg = self.args[0]\n        if arg.is_Integer:\n            # remove perfect powers\n            p = perfect_power(int(arg))\n            if p is not False:\n                return p[1]*self.func(p[0])\n        elif arg.is_Mul:\n            expr = []\n            nonpos = []\n            for x in arg.args:\n                if force or x.is_positive or x.is_polar:\n                    a = self.func(x)\n                    if isinstance(a, log):\n                        expr.append(self.func(x)._eval_expand_log(**hints))\n                    else:\n                        expr.append(a)\n                elif x.is_negative:\n                    a = self.func(-x)\n                    expr.append(a)\n                    nonpos.append(S.NegativeOne)\n                else:\n                    nonpos.append(x)\n            return Add(*expr) + log(Mul(*nonpos))\n        elif arg.is_Pow:\n            if force or (arg.exp.is_real and arg.base.is_positive) or \\\n                    arg.base.is_polar:\n                b = arg.base\n                e = arg.exp\n                a = self.func(b)\n                if isinstance(a, log):\n                    return unpolarify(e) * a._eval_expand_log(**hints)\n                else:\n                    return unpolarify(e) * a\n        elif isinstance(arg, Product):\n            if arg.function.is_positive:\n                return Sum(log(arg.function), *arg.limits)\n\n        return self.func(arg)"
        }
      ]
    },
    {
      "pr_number": 12270,
      "pr_title": "fix bug in extract_multiplicatively()",
      "pr_body": "Fixes #12254 .\r\nCan you review this and suggest improvements @smichr, @cbm755 ?\r\n\r\nAnd consider this test case : \r\n```\r\n>>> (4*y**2*(-x*y-2*y)).extract_multiplicatively(-2*y)\r\n```\r\nI am not sure whether we should return ```None``` or ```2*x*y**2 + 4*y**2``` ,  currently it returns ```None```",
      "issue_id": 12254,
      "issue_title": "cannot extract_multiplicatively(-2) from (-2*x - 2*y)",
      "issue_body": "I think this might be a bug.\r\n````\r\n>>> (2+4*I).extract_multiplicatively(2)    # yes\r\n1 + 2*I\r\n>>> (-2-4*I).extract_multiplicatively(-1)   # yes\r\n2 + 4*I\r\n>>> (-2-4*I).extract_multiplicatively(-2)   # bug?\r\n````\r\nsimilarly:\r\n````\r\n>>> (2*x + 4*y + 8).extract_multiplicatively(2)   # yes\r\nx + 2*y + 4\r\n>>> (-2*x - 4*y - 8).extract_multiplicatively(2)    # yes\r\n-x - 2*y - 4\r\n>>> (-2*x - 4*y - 8).extract_multiplicatively(-1)    # yes\r\n2*x + 4*y + 8\r\n>>> (-2*x - 4*y - 8).extract_multiplicatively(-2)    # bug?\r\n````\r\n\r\nAssuming it is indeed a bug, here is why it happens:\r\n\r\nLook in `core/expr.py` where:\r\n````\r\n>>> (-2*x - 4*y - 8).primitive()\r\n(2, -x - 2*y - 4)\r\n````\r\nwhich is then made into a *non-evaluated* `Mul`, from which `-2` cannot be multiplicatively extracted; for example:\r\n````\r\n>>> Mul(2, -x).extract_multiplicatively(-2)\r\nx\r\n>>> Mul(2, -x, evaluate=False).extract_multiplicatively(-2)\r\n````\r\n@smichr do you think this is bug? (see your commit 8968b85310506c0a2b34f3d7aeb8e0d88f87885b: not clear whether we still need this special case anyway)",
      "issue_closed_at": "2017-03-11T15:24:28Z",
      "base_commit": "a79801c044c2b0ed74176e4abc18f4ca2b38ac58",
      "changes": [
        {
          "file": "sympy/core/expr.py",
          "type": "line",
          "name": "line 11",
          "code": "\nfrom collections import defaultdict\n\n\nclass Expr(Basic, EvalfMixin):\n    \"\"\"\n    Base class for algebraic expressions."
        },
        {
          "file": "sympy/core/expr.py",
          "type": "function",
          "name": "extract_multiplicatively",
          "class_name": "Expr",
          "code": "def extract_multiplicatively(self, c):\n        \"\"\"Return None if it's not possible to make self in the form\n           c * something in a nice way, i.e. preserving the properties\n           of arguments of self.\n\n           >>> from sympy import symbols, Rational\n\n           >>> x, y = symbols('x,y', real=True)\n\n           >>> ((x*y)**3).extract_multiplicatively(x**2 * y)\n           x*y**2\n\n           >>> ((x*y)**3).extract_multiplicatively(x**4 * y)\n\n           >>> (2*x).extract_multiplicatively(2)\n           x\n\n           >>> (2*x).extract_multiplicatively(3)\n\n           >>> (Rational(1, 2)*x).extract_multiplicatively(3)\n           x/6\n\n        \"\"\"\n        c = sympify(c)\n        if self is S.NaN:\n            return None\n        if c is S.One:\n            return self\n        elif c == self:\n            return S.One\n        if c.is_Add:\n            cc, pc = c.primitive()\n            if cc is not S.One:\n                c = Mul(cc, pc, evaluate=False)\n        if c.is_Mul:\n            a, b = c.as_two_terms()\n            x = self.extract_multiplicatively(a)\n            if x is not None:\n                return x.extract_multiplicatively(b)\n        quotient = self / c\n        if self.is_Number:\n            if self is S.Infinity:\n                if c.is_positive:\n                    return S.Infinity\n            elif self is S.NegativeInfinity:\n                if c.is_negative:\n                    return S.Infinity\n                elif c.is_positive:\n                    return S.NegativeInfinity\n            elif self is S.ComplexInfinity:\n                if not c.is_zero:\n                    return S.ComplexInfinity\n            elif self.is_Integer:\n                if not quotient.is_Integer:\n                    return None\n                elif self.is_positive and quotient.is_negative:\n                    return None\n                else:\n                    return quotient\n            elif self.is_Rational:\n                if not quotient.is_Rational:\n                    return None\n                elif self.is_positive and quotient.is_negative:\n                    return None\n                else:\n                    return quotient\n            elif self.is_Float:\n                if not quotient.is_Float:\n                    return None\n                elif self.is_positive and quotient.is_negative:\n                    return None\n                else:\n                    return quotient\n        elif self.is_NumberSymbol or self.is_Symbol or self is S.ImaginaryUnit:\n            if quotient.is_Mul and len(quotient.args) == 2:\n                if quotient.args[0].is_Integer and quotient.args[0].is_positive and quotient.args[1] == self:\n                    return quotient\n            elif quotient.is_Integer and c.is_Number:\n                return quotient\n        elif self.is_Add:\n            cs, ps = self.primitive()\n            if cs is not S.One:\n                return Mul(cs, ps, evaluate=False).extract_multiplicatively(c)\n            newargs = []\n            for arg in self.args:\n                newarg = arg.extract_multiplicatively(c)\n                if newarg is not None:\n                    newargs.append(newarg)\n                else:\n                    return None\n            return Add(*newargs)\n        elif self.is_Mul:\n            args = list(self.args)\n            for i, arg in enumerate(args):\n                newarg = arg.extract_multiplicatively(c)\n                if newarg is not None:\n                    args[i] = newarg\n                    return Mul(*args)\n        elif self.is_Pow:\n            if c.is_Pow and c.base == self.base:\n                new_exp = self.exp.extract_additively(c.exp)\n                if new_exp is not None:\n                    return self.base ** (new_exp)\n            elif c == self.base:\n                new_exp = self.exp.extract_additively(1)\n                if new_exp is not None:\n                    return self.base ** (new_exp)"
        },
        {
          "file": "sympy/core/expr.py",
          "type": "function",
          "name": "extract_multiplicatively",
          "class_name": "Expr",
          "code": "def extract_multiplicatively(self, c):\n        \"\"\"Return None if it's not possible to make self in the form\n           c * something in a nice way, i.e. preserving the properties\n           of arguments of self.\n\n           >>> from sympy import symbols, Rational\n\n           >>> x, y = symbols('x,y', real=True)\n\n           >>> ((x*y)**3).extract_multiplicatively(x**2 * y)\n           x*y**2\n\n           >>> ((x*y)**3).extract_multiplicatively(x**4 * y)\n\n           >>> (2*x).extract_multiplicatively(2)\n           x\n\n           >>> (2*x).extract_multiplicatively(3)\n\n           >>> (Rational(1, 2)*x).extract_multiplicatively(3)\n           x/6\n\n        \"\"\"\n        c = sympify(c)\n        if self is S.NaN:\n            return None\n        if c is S.One:\n            return self\n        elif c == self:\n            return S.One\n        if c.is_Add:\n            cc, pc = c.primitive()\n            if cc is not S.One:\n                c = Mul(cc, pc, evaluate=False)\n        if c.is_Mul:\n            a, b = c.as_two_terms()\n            x = self.extract_multiplicatively(a)\n            if x is not None:\n                return x.extract_multiplicatively(b)\n        quotient = self / c\n        if self.is_Number:\n            if self is S.Infinity:\n                if c.is_positive:\n                    return S.Infinity\n            elif self is S.NegativeInfinity:\n                if c.is_negative:\n                    return S.Infinity\n                elif c.is_positive:\n                    return S.NegativeInfinity\n            elif self is S.ComplexInfinity:\n                if not c.is_zero:\n                    return S.ComplexInfinity\n            elif self.is_Integer:\n                if not quotient.is_Integer:\n                    return None\n                elif self.is_positive and quotient.is_negative:\n                    return None\n                else:\n                    return quotient\n            elif self.is_Rational:\n                if not quotient.is_Rational:\n                    return None\n                elif self.is_positive and quotient.is_negative:\n                    return None\n                else:\n                    return quotient\n            elif self.is_Float:\n                if not quotient.is_Float:\n                    return None\n                elif self.is_positive and quotient.is_negative:\n                    return None\n                else:\n                    return quotient\n        elif self.is_NumberSymbol or self.is_Symbol or self is S.ImaginaryUnit:\n            if quotient.is_Mul and len(quotient.args) == 2:\n                if quotient.args[0].is_Integer and quotient.args[0].is_positive and quotient.args[1] == self:\n                    return quotient\n            elif quotient.is_Integer and c.is_Number:\n                return quotient\n        elif self.is_Add:\n            cs, ps = self.primitive()\n            if cs is not S.One:\n                return Mul(cs, ps, evaluate=False).extract_multiplicatively(c)\n            newargs = []\n            for arg in self.args:\n                newarg = arg.extract_multiplicatively(c)\n                if newarg is not None:\n                    newargs.append(newarg)\n                else:\n                    return None\n            return Add(*newargs)\n        elif self.is_Mul:\n            args = list(self.args)\n            for i, arg in enumerate(args):\n                newarg = arg.extract_multiplicatively(c)\n                if newarg is not None:\n                    args[i] = newarg\n                    return Mul(*args)\n        elif self.is_Pow:\n            if c.is_Pow and c.base == self.base:\n                new_exp = self.exp.extract_additively(c.exp)\n                if new_exp is not None:\n                    return self.base ** (new_exp)\n            elif c == self.base:\n                new_exp = self.exp.extract_additively(1)\n                if new_exp is not None:\n                    return self.base ** (new_exp)"
        },
        {
          "file": "sympy/core/expr.py",
          "type": "function",
          "name": "extract_multiplicatively",
          "class_name": "Expr",
          "code": "def extract_multiplicatively(self, c):\n        \"\"\"Return None if it's not possible to make self in the form\n           c * something in a nice way, i.e. preserving the properties\n           of arguments of self.\n\n           >>> from sympy import symbols, Rational\n\n           >>> x, y = symbols('x,y', real=True)\n\n           >>> ((x*y)**3).extract_multiplicatively(x**2 * y)\n           x*y**2\n\n           >>> ((x*y)**3).extract_multiplicatively(x**4 * y)\n\n           >>> (2*x).extract_multiplicatively(2)\n           x\n\n           >>> (2*x).extract_multiplicatively(3)\n\n           >>> (Rational(1, 2)*x).extract_multiplicatively(3)\n           x/6\n\n        \"\"\"\n        c = sympify(c)\n        if self is S.NaN:\n            return None\n        if c is S.One:\n            return self\n        elif c == self:\n            return S.One\n        if c.is_Add:\n            cc, pc = c.primitive()\n            if cc is not S.One:\n                c = Mul(cc, pc, evaluate=False)\n        if c.is_Mul:\n            a, b = c.as_two_terms()\n            x = self.extract_multiplicatively(a)\n            if x is not None:\n                return x.extract_multiplicatively(b)\n        quotient = self / c\n        if self.is_Number:\n            if self is S.Infinity:\n                if c.is_positive:\n                    return S.Infinity\n            elif self is S.NegativeInfinity:\n                if c.is_negative:\n                    return S.Infinity\n                elif c.is_positive:\n                    return S.NegativeInfinity\n            elif self is S.ComplexInfinity:\n                if not c.is_zero:\n                    return S.ComplexInfinity\n            elif self.is_Integer:\n                if not quotient.is_Integer:\n                    return None\n                elif self.is_positive and quotient.is_negative:\n                    return None\n                else:\n                    return quotient\n            elif self.is_Rational:\n                if not quotient.is_Rational:\n                    return None\n                elif self.is_positive and quotient.is_negative:\n                    return None\n                else:\n                    return quotient\n            elif self.is_Float:\n                if not quotient.is_Float:\n                    return None\n                elif self.is_positive and quotient.is_negative:\n                    return None\n                else:\n                    return quotient\n        elif self.is_NumberSymbol or self.is_Symbol or self is S.ImaginaryUnit:\n            if quotient.is_Mul and len(quotient.args) == 2:\n                if quotient.args[0].is_Integer and quotient.args[0].is_positive and quotient.args[1] == self:\n                    return quotient\n            elif quotient.is_Integer and c.is_Number:\n                return quotient\n        elif self.is_Add:\n            cs, ps = self.primitive()\n            if cs is not S.One:\n                return Mul(cs, ps, evaluate=False).extract_multiplicatively(c)\n            newargs = []\n            for arg in self.args:\n                newarg = arg.extract_multiplicatively(c)\n                if newarg is not None:\n                    newargs.append(newarg)\n                else:\n                    return None\n            return Add(*newargs)\n        elif self.is_Mul:\n            args = list(self.args)\n            for i, arg in enumerate(args):\n                newarg = arg.extract_multiplicatively(c)\n                if newarg is not None:\n                    args[i] = newarg\n                    return Mul(*args)\n        elif self.is_Pow:\n            if c.is_Pow and c.base == self.base:\n                new_exp = self.exp.extract_additively(c.exp)\n                if new_exp is not None:\n                    return self.base ** (new_exp)\n            elif c == self.base:\n                new_exp = self.exp.extract_additively(1)\n                if new_exp is not None:\n                    return self.base ** (new_exp)"
        }
      ]
    }
  ]
}