{
  "instance_id": "sympy__sympy-19007",
  "repo": "sympy/sympy",
  "created_at": "2020-03-29T13:47:11Z",
  "problem_statement": "Wrong matrix element fetched from BlockMatrix\nGiven this code:\r\n```\r\nfrom sympy import *\r\nn, i = symbols('n, i', integer=True)\r\nA = MatrixSymbol('A', 1, 1)\r\nB = MatrixSymbol('B', n, 1)\r\nC = BlockMatrix([[A], [B]])\r\nprint('C is')\r\npprint(C)\r\nprint('C[i, 0] is')\r\npprint(C[i, 0])\r\n```\r\nI get this output:\r\n```\r\nC is\r\n\u23a1A\u23a4\r\n\u23a2 \u23a5\r\n\u23a3B\u23a6\r\nC[i, 0] is\r\n(A)[i, 0]\r\n```\r\n`(A)[i, 0]` is the wrong here. `C[i, 0]` should not be simplified as that element may come from either `A` or `B`.\n",
  "patch": "diff --git a/sympy/matrices/expressions/blockmatrix.py b/sympy/matrices/expressions/blockmatrix.py\n--- a/sympy/matrices/expressions/blockmatrix.py\n+++ b/sympy/matrices/expressions/blockmatrix.py\n@@ -7,7 +7,7 @@\n from sympy.utilities import sift\n from sympy.utilities.misc import filldedent\n \n-from sympy.matrices.expressions.matexpr import MatrixExpr, ZeroMatrix, Identity\n+from sympy.matrices.expressions.matexpr import MatrixExpr, ZeroMatrix, Identity, MatrixElement\n from sympy.matrices.expressions.matmul import MatMul\n from sympy.matrices.expressions.matadd import MatAdd\n from sympy.matrices.expressions.matpow import MatPow\n@@ -234,16 +234,24 @@ def transpose(self):\n \n     def _entry(self, i, j, **kwargs):\n         # Find row entry\n+        orig_i, orig_j = i, j\n         for row_block, numrows in enumerate(self.rowblocksizes):\n-            if (i < numrows) != False:\n+            cmp = i < numrows\n+            if cmp == True:\n                 break\n-            else:\n+            elif cmp == False:\n                 i -= numrows\n+            elif row_block < self.blockshape[0] - 1:\n+                # Can't tell which block and it's not the last one, return unevaluated\n+                return MatrixElement(self, orig_i, orig_j)\n         for col_block, numcols in enumerate(self.colblocksizes):\n-            if (j < numcols) != False:\n+            cmp = j < numcols\n+            if cmp == True:\n                 break\n-            else:\n+            elif cmp == False:\n                 j -= numcols\n+            elif col_block < self.blockshape[1] - 1:\n+                return MatrixElement(self, orig_i, orig_j)\n         return self.blocks[row_block, col_block][i, j]\n \n     @property\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": 11947,
      "pr_title": "aligned middle of matrix with baseline",
      "pr_body": "**Previous Output**: \r\n\r\n```\r\n>>> Z = Matrix(5,5, lambda i,j: i+j)\r\n>>> pprint(MatMul(2,Z))\r\n2\u22c5\u23a10  1  2  3  4\u23a4\r\n  \u23a2             \u23a5\r\n  \u23a21  2  3  4  5\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a22  3  4  5  6\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a23  4  5  6  7\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a34  5  6  7  8\u23a6\r\n```\r\n\r\n**Output after this PR**:\r\n```\r\n>>> Z = Matrix(5,5, lambda i,j: i+j)\r\n>>> pprint(MatMul(2,Z))\r\n  \u23a10  1  2  3  4\u23a4\r\n  \u23a2             \u23a5\r\n  \u23a21  2  3  4  5\u23a5\r\n  \u23a2             \u23a5\r\n2.\u23a22  3  4  5  6\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a23  4  5  6  7\u23a5\r\n  \u23a2             \u23a5\r\n  \u23a34  5  6  7  8\u23a6\r\n```\r\nFixes #10472 . ",
      "issue_id": 10472,
      "issue_title": "pprint should align the middle of the matrix to the baseline?",
      "issue_body": "Consider the current behaviour, where operators align with the top of the matrix:\n\n```\n>>> Z = Matrix(5,5, lambda i,j: i+j)\n>>> pprint(MatMul(2,Z))\n2\u22c5\u23a10  1  2  3  4\u23a4\n  \u23a2             \u23a5\n  \u23a21  2  3  4  5\u23a5\n  \u23a2             \u23a5\n  \u23a22  3  4  5  6\u23a5\n  \u23a2             \u23a5\n  \u23a23  4  5  6  7\u23a5\n  \u23a2             \u23a5\n  \u23a34  5  6  7  8\u23a6\n>>> pprint(MatAdd(Z,Z))\n\u23a10  1  2  3  4\u23a4 + \u23a10  1  2  3  4\u23a4\n\u23a2             \u23a5   \u23a2             \u23a5\n\u23a21  2  3  4  5\u23a5   \u23a21  2  3  4  5\u23a5\n\u23a2             \u23a5   \u23a2             \u23a5\n\u23a22  3  4  5  6\u23a5   \u23a22  3  4  5  6\u23a5\n\u23a2             \u23a5   \u23a2             \u23a5\n\u23a23  4  5  6  7\u23a5   \u23a23  4  5  6  7\u23a5\n\u23a2             \u23a5   \u23a2             \u23a5\n\u23a34  5  6  7  8\u23a6   \u23a34  5  6  7  8\u23a6\n```\n\nThis looks poor, but I figured it might be the desired behaviour...\n\nHere's the example that makes me think its wrong:\n\n```\n>>> pprint(sin((1+1/x)/(1+1/y)) + det(MatMul(2,Z)))\n   \u239b    1\u239e                       \n   \u239c1 + \u2500\u239f                       \n   \u239c    x\u239f                       \nsin\u239c\u2500\u2500\u2500\u2500\u2500\u239f + 32\u22c5\u2502\u23a10  1  2  3  4\u23a4\u2502\n   \u239c    1\u239f      \u2502\u23a2             \u23a5\u2502\n   \u239c1 + \u2500\u239f      \u2502\u23a21  2  3  4  5\u23a5\u2502\n   \u239d    y\u23a0      \u2502\u23a2             \u23a5\u2502\n                \u2502\u23a22  3  4  5  6\u23a5\u2502\n                \u2502\u23a2             \u23a5\u2502\n                \u2502\u23a23  4  5  6  7\u23a5\u2502\n                \u2502\u23a2             \u23a5\u2502\n                \u2502\u23a34  5  6  7  8\u23a6\u2502\n```\n\nHere's how I think it should work, using the proposed #10423:\n\n```\npprint(sin((1+1/x)/y) + Trace(Z))\n               \u239b\u23a10  1  2  3  4\u23a4\u239e\n   \u239b    1\u239e     \u239c\u23a2             \u23a5\u239f\n   \u239c1 + \u2500\u239f     \u239c\u23a21  2  3  4  5\u23a5\u239f\n   \u239c    x\u239f     \u239c\u23a2             \u23a5\u239f\nsin\u239c\u2500\u2500\u2500\u2500\u2500\u239f + tr\u239c\u23a22  3  4  5  6\u23a5\u239f\n   \u239d  y  \u23a0     \u239c\u23a2             \u23a5\u239f\n               \u239c\u23a23  4  5  6  7\u23a5\u239f\n               \u239c\u23a2             \u23a5\u239f\n               \u239d\u23a34  5  6  7  8\u23a6\u23a0\n```\n\nwhere note the `sin` alignment is by-design, and (relevant to this bug) the `+` and `tr` operator line up with `sin`.\n\nAt least, det, MatAdd, MatMul, MatPow would need fixed, maybe others I haven't thought of.\n",
      "issue_closed_at": "2016-12-22T06:52:11Z",
      "base_commit": "9a724a42c033c1aae97064947a0f44ec3b922d73",
      "changes": [
        {
          "file": "sympy/matrices/expressions/matadd.py",
          "type": "function",
          "name": "merge_explicit",
          "class_name": null,
          "code": "def merge_explicit(matadd):\n    \"\"\" Merge explicit MatrixBase arguments\n\n    >>> from sympy import MatrixSymbol, eye, Matrix, MatAdd, pprint\n    >>> from sympy.matrices.expressions.matadd import merge_explicit\n    >>> A = MatrixSymbol('A', 2, 2)\n    >>> B = eye(2)\n    >>> C = Matrix([[1, 2], [3, 4]])\n    >>> X = MatAdd(A, B, C)\n    >>> pprint(X)\n    A + [1  0] + [1  2]\n        [    ]   [    ]\n        [0  1]   [3  4]\n    >>> pprint(merge_explicit(X))\n    A + [2  2]\n        [    ]\n        [3  5]\n    \"\"\"\n    groups = sift(matadd.args, lambda arg: isinstance(arg, MatrixBase))\n    if len(groups[True]) > 1:\n        return MatAdd(*(groups[False] + [reduce(add, groups[True])]))\n    else:\n        return matadd"
        },
        {
          "file": "sympy/matrices/expressions/matmul.py",
          "type": "function",
          "name": "merge_explicit",
          "class_name": null,
          "code": "def merge_explicit(matmul):\n    \"\"\" Merge explicit MatrixBase arguments\n\n    >>> from sympy import MatrixSymbol, eye, Matrix, MatMul, pprint\n    >>> from sympy.matrices.expressions.matmul import merge_explicit\n    >>> A = MatrixSymbol('A', 2, 2)\n    >>> B = Matrix([[1, 1], [1, 1]])\n    >>> C = Matrix([[1, 2], [3, 4]])\n    >>> X = MatMul(A, B, C)\n    >>> pprint(X)\n    A*[1  1]*[1  2]\n      [    ] [    ]\n      [1  1] [3  4]\n    >>> pprint(merge_explicit(X))\n    A*[4  6]\n      [    ]\n      [4  6]\n\n    >>> X = MatMul(B, A, C)\n    >>> pprint(X)\n    [1  1]*A*[1  2]\n    [    ]   [    ]\n    [1  1]   [3  4]\n    >>> pprint(merge_explicit(X))\n    [1  1]*A*[1  2]\n    [    ]   [    ]\n    [1  1]   [3  4]\n    \"\"\"\n    if not any(isinstance(arg, MatrixBase) for arg in matmul.args):\n        return matmul\n    newargs = []\n    last = matmul.args[0]\n    for arg in matmul.args[1:]:\n        if isinstance(arg, (MatrixBase, Number)) and isinstance(last, (MatrixBase, Number)):\n            last = last * arg\n        else:\n            newargs.append(last)\n            last = arg\n    newargs.append(last)\n\n    return MatMul(*newargs)"
        },
        {
          "file": "sympy/printing/pretty/pretty.py",
          "type": "function",
          "name": "_print_matrix_contents",
          "class_name": "PrettyPrinter",
          "code": "def _print_matrix_contents(self, e):\n        \"\"\"\n        This method factors out what is essentially grid printing.\n        \"\"\"\n        M = e   # matrix\n        Ms = {}  # i,j -> pretty(M[i,j])\n        for i in range(M.rows):\n            for j in range(M.cols):\n                Ms[i, j] = self._print(M[i, j])\n\n        # h- and v- spacers\n        hsep = 2\n        vsep = 1\n\n        # max width for columns\n        maxw = [-1] * M.cols\n\n        for j in range(M.cols):\n            maxw[j] = max([Ms[i, j].width() for i in range(M.rows)] or [0])\n\n        # drawing result\n        D = None\n\n        for i in range(M.rows):\n\n            D_row = None\n            for j in range(M.cols):\n                s = Ms[i, j]\n\n                # reshape s to maxw\n                # XXX this should be generalized, and go to stringPict.reshape ?\n                assert s.width() <= maxw[j]\n\n                # hcenter it, +0.5 to the right                        2\n                # ( it's better to align formula starts for say 0 and r )\n                # XXX this is not good in all cases -- maybe introduce vbaseline?\n                wdelta = maxw[j] - s.width()\n                wleft = wdelta // 2\n                wright = wdelta - wleft\n\n                s = prettyForm(*s.right(' '*wright))\n                s = prettyForm(*s.left(' '*wleft))\n\n                # we don't need vcenter cells -- this is automatically done in\n                # a pretty way because when their baselines are taking into\n                # account in .right()\n\n                if D_row is None:\n                    D_row = s   # first box in a row\n                    continue\n\n                D_row = prettyForm(*D_row.right(' '*hsep))  # h-spacer\n                D_row = prettyForm(*D_row.right(s))\n\n            if D is None:\n                D = D_row       # first row in a picture\n                continue\n\n            # v-spacer\n            for _ in range(vsep):\n                D = prettyForm(*D.below(' '))\n\n            D = prettyForm(*D.below(D_row))\n\n        if D is None:\n            D = prettyForm('')  # Empty Matrix\n\n        return D"
        },
        {
          "file": "sympy/printing/pretty/pretty.py",
          "type": "function",
          "name": "_print_MatrixElement",
          "class_name": "PrettyPrinter",
          "code": "def _print_MatrixElement(self, expr):\n        from sympy.matrices import MatrixSymbol\n        from sympy import Symbol\n        if (isinstance(expr.parent, MatrixSymbol)\n                and expr.i.is_number and expr.j.is_number):\n            return self._print(\n                    Symbol(expr.parent.name + '_%d%d'%(expr.i, expr.j)))\n        else:\n            prettyFunc = self._print(expr.parent)\n            prettyIndices = self._print_seq((expr.i, expr.j), delimiter=', '\n                    ).parens(left='[', right=']')[0]\n            pform = prettyForm(binding=prettyForm.FUNC,\n                    *stringPict.next(prettyFunc, prettyIndices))\n\n            # store pform parts so it can be reassembled e.g. when powered\n            pform.prettyFunc = prettyFunc\n            pform.prettyArgs = prettyIndices\n\n            return pform"
        }
      ]
    },
    {
      "pr_number": 2707,
      "pr_title": "remove practice of evaluating factorial as 0 for negative numbers",
      "pr_body": "it is infinity for negative integers and remains unevaluated for non-integers. fix gosper test, which had a missing term.\nfix string representations\n",
      "issue_id": 2703,
      "issue_title": "uncommon convention for factorials of negative numbers",
      "issue_body": "from the docstring of the factorial function:\n\n\"For the sake of convenience and simplicity of procedures using\nthis function it is defined for negative integers and returns\nzero in this case.\"\n\nBy convention (and by some definitions), n! is usually infinity for n < 0. This is consistent with the Gamma function identity n! = Gamma(n+1) and with the convention that binomial coefficients are 0 outside of Pascal's triangle. In fact, in the same module, we have, in the doc string for binomial coefficients:\n\n\"For the sake of convenience for negative 'k' this function\nwill return zero no matter what valued is the other argument.\"\n\nThis is incompatible with sympy's convention on factorials, given the definition of the binomial coefficients: C(n,k) = n!/(k!(n-k)!)\n\nFor example take \"2 choose -1\", C(2,-1) = 0. However, going to sympy's definition of the factorial, we would have 2!/((-1)! \\* 3!) == 1/0 == oo, which is obviously wrong. Switching over to the Gamma function gives us the correct answer.\n\nDoes anyone know what \"procedures using\" the factorial function rely on the \"convenience and simplicity\" of the incorrect convention n! = 0  for n < 0? It would nice to bring the factorial function to consistency with other parts of sympy (like the binomial coefficients) and the more common convention in the math and cs communities.\n",
      "issue_closed_at": "2014-01-05T13:28:55Z",
      "base_commit": "5879fa2318e853807a6cf63981f2bca441cceb9f",
      "changes": [
        {
          "file": "sympy/functions/combinatorial/factorials.py",
          "type": "function",
          "name": "_eval_simplify",
          "class_name": "CombinatorialFunction",
          "code": "def _eval_simplify(self, ratio, measure):\n        from sympy.simplify.simplify import combsimp\n        expr = combsimp(self)\n        if measure(expr) <= ratio*measure(self):\n            return expr\n        return self"
        },
        {
          "file": "sympy/functions/combinatorial/factorials.py",
          "type": "class",
          "name": "factorial",
          "code": "class factorial(CombinatorialFunction):\n    \"\"\"Implementation of factorial function over nonnegative integers.\n       For the sake of convenience and simplicity of procedures using\n       this function it is defined for negative integers and returns\n       zero in this case.\n\n       The factorial is very important in combinatorics where it gives\n       the number of ways in which 'n' objects can be permuted. It also\n       arises in calculus, probability, number theory etc.\n\n       There is strict relation of factorial with gamma function. In\n       fact n! = gamma(n+1) for nonnegative integers. Rewrite of this\n       kind is very useful in case of combinatorial simplification.\n\n       Computation of the factorial is done using two algorithms. For\n       small arguments naive product is evaluated. However for bigger\n       input algorithm Prime-Swing is used. It is the fastest algorithm\n       known and computes n! via prime factorization of special class\n       of numbers, called here the 'Swing Numbers'.\n\n       Examples\n       ========\n\n       >>> from sympy import Symbol, factorial\n       >>> n = Symbol('n', integer=True)\n\n       >>> factorial(-2)\n       0\n\n       >>> factorial(0)\n       1\n\n       >>> factorial(7)\n       5040\n\n       >>> factorial(n)\n       factorial(n)\n\n       >>> factorial(2*n)\n       factorial(2*n)\n\n       See Also\n       ========\n\n       factorial2, RisingFactorial, FallingFactorial\n    \"\"\"\n\n    nargs = 1\n\n    def fdiff(self, argindex=1):\n        if argindex == 1:\n            return C.gamma(self.args[0] + 1)*C.polygamma(0, self.args[0] + 1)\n        else:\n            raise ArgumentIndexError(self, argindex)\n\n    _small_swing = [\n        1, 1, 1, 3, 3, 15, 5, 35, 35, 315, 63, 693, 231, 3003, 429, 6435, 6435, 109395,\n        12155, 230945, 46189, 969969, 88179, 2028117, 676039, 16900975, 1300075,\n        35102025, 5014575, 145422675, 9694845, 300540195, 300540195\n    ]\n\n    @classmethod\n    def _swing(cls, n):\n        if n < 33:\n            return cls._small_swing[n]\n        else:\n            N, primes = int(_sqrt(n)), []\n\n            for prime in sieve.primerange(3, N + 1):\n                p, q = 1, n\n\n                while True:\n                    q //= prime\n\n                    if q > 0:\n                        if q & 1 == 1:\n                            p *= prime\n                    else:\n                        break\n\n                if p > 1:\n                    primes.append(p)\n\n            for prime in sieve.primerange(N + 1, n//3 + 1):\n                if (n // prime) & 1 == 1:\n                    primes.append(prime)\n\n            L_product = R_product = 1\n\n            for prime in sieve.primerange(n//2 + 1, n + 1):\n                L_product *= prime\n\n            for prime in primes:\n                R_product *= prime\n\n            return L_product*R_product\n\n    @classmethod\n    def _recursive(cls, n):\n        if n < 2:\n            return 1\n        else:\n            return (cls._recursive(n//2)**2)*cls._swing(n)\n\n    @classmethod\n    def eval(cls, n):\n        n = sympify(n)\n\n        if n.is_Number:\n            if n is S.Zero:\n                return S.One\n            elif n is S.Infinity:\n                return S.Infinity\n            elif n.is_Integer:\n                if n.is_negative:\n                    return S.Zero\n                else:\n                    n, result = n.p, 1\n\n                    if n < 20:\n                        for i in range(2, n + 1):\n                            result *= i\n                    else:\n                        N, bits = n, 0\n\n                        while N != 0:\n                            if N & 1 == 1:\n                                bits += 1\n\n                            N = N >> 1\n\n                        result = cls._recursive(n)*2**(n - bits)\n\n                    return C.Integer(result)\n\n        if n.is_negative:\n            return S.Zero\n\n    def _eval_rewrite_as_gamma(self, n):\n        return C.gamma(n + 1)\n\n    def _eval_is_integer(self):\n        return self.args[0].is_integer\n\n    def _eval_is_positive(self):\n        if self.args[0].is_integer and self.args[0].is_positive:\n            return True"
        },
        {
          "file": "sympy/functions/combinatorial/factorials.py",
          "type": "function",
          "name": "eval",
          "class_name": "binomial",
          "code": "def eval(cls, n, k):\n        n, k = map(sympify, (n, k))\n\n        if k.is_Number:\n            if k.is_Integer:\n                if k < 0:\n                    return S.Zero\n                elif k == 0 or n == k:\n                    return S.One\n                elif n.is_Integer and n >= 0:\n                    n, k = int(n), int(k)\n\n                    if k > n:\n                        return S.Zero\n                    elif k > n // 2:\n                        k = n - k\n\n                    M, result = int(_sqrt(n)), 1\n\n                    for prime in sieve.primerange(2, n + 1):\n                        if prime > n - k:\n                            result *= prime\n                        elif prime > n // 2:\n                            continue\n                        elif prime > M:\n                            if n % prime < k % prime:\n                                result *= prime\n                        else:\n                            N, K = n, k\n                            exp = a = 0\n\n                            while N > 0:\n                                a = int((N % prime) < (K % prime + a))\n                                N, K = N // prime, K // prime\n                                exp = a + exp\n\n                            if exp > 0:\n                                result *= prime**exp\n\n                    return C.Integer(result)\n                elif n.is_Number:\n                    result = n - k + 1\n                    for i in xrange(2, k + 1):\n                        result *= n - k + i\n                        result /= i\n                    return result\n\n        elif k.is_negative:\n            return S.Zero\n        elif (n - k).simplify().is_negative:\n            return S.Zero\n        else:\n            d = n - k\n\n            if d.is_Integer:\n                return cls.eval(n, d)"
        },
        {
          "file": "sympy/functions/combinatorial/factorials.py",
          "type": "function",
          "name": "eval",
          "class_name": "binomial",
          "code": "def eval(cls, n, k):\n        n, k = map(sympify, (n, k))\n\n        if k.is_Number:\n            if k.is_Integer:\n                if k < 0:\n                    return S.Zero\n                elif k == 0 or n == k:\n                    return S.One\n                elif n.is_Integer and n >= 0:\n                    n, k = int(n), int(k)\n\n                    if k > n:\n                        return S.Zero\n                    elif k > n // 2:\n                        k = n - k\n\n                    M, result = int(_sqrt(n)), 1\n\n                    for prime in sieve.primerange(2, n + 1):\n                        if prime > n - k:\n                            result *= prime\n                        elif prime > n // 2:\n                            continue\n                        elif prime > M:\n                            if n % prime < k % prime:\n                                result *= prime\n                        else:\n                            N, K = n, k\n                            exp = a = 0\n\n                            while N > 0:\n                                a = int((N % prime) < (K % prime + a))\n                                N, K = N // prime, K // prime\n                                exp = a + exp\n\n                            if exp > 0:\n                                result *= prime**exp\n\n                    return C.Integer(result)\n                elif n.is_Number:\n                    result = n - k + 1\n                    for i in xrange(2, k + 1):\n                        result *= n - k + i\n                        result /= i\n                    return result\n\n        elif k.is_negative:\n            return S.Zero\n        elif (n - k).simplify().is_negative:\n            return S.Zero\n        else:\n            d = n - k\n\n            if d.is_Integer:\n                return cls.eval(n, d)"
        }
      ]
    },
    {
      "pr_number": 15519,
      "pr_title": "Exit _eval_derivative_n_times when None is obtained",
      "pr_body": "#### References to other Issues or PRs\r\n\r\nFixes #15518 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nThe method `_eval_derivative_n_times` contains a loop that involves calling `_eval_derivative`. The latter may return None when evaluation is not implemented. In such a case the loop should be aborted (returning None) instead of trying to differentiate None.\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below. See\r\nhttps://github.com/sympy/sympy/wiki/Writing-Release-Notes for more information\r\non how to write release notes. The bot will check your release notes\r\nautomatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n* core\r\n  * Fixed a bug in the creation of higher order derivatives that cannot be evaluated.  \r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 15518,
      "issue_title": "Higher order derivatives that cannot be evaluated, like re(x).diff(x, 2), raise an exception",
      "issue_body": "This issue arose in a [comment on another issue]( https://github.com/sympy/sympy/issues/15457#issuecomment-436453327) but since it's actually unrelated, is posted here separately. \r\n```\r\n>>> re(x).diff(x, 2)\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/ubuntu/sympy/sympy/core/expr.py\", line 3047, in diff\r\n    return Derivative(self, *symbols, **assumptions)\r\n  File \"/home/ubuntu/sympy/sympy/core/function.py\", line 1370, in __new__\r\n    obj = expr._eval_derivative_n_times(v, count)\r\n  File \"/home/ubuntu/sympy/sympy/core/basic.py\", line 1688, in _eval_derivative_n_times\r\n    obj2 = obj._accept_eval_derivative(s)\r\nAttributeError: 'NoneType' object has no attribute '_accept_eval_derivative'\r\n```\r\nThis happens whenever a higher-order derivative is requested for a function that does not have an explicit derivative. The expected output is \r\n```\r\nDerivative(re(x), (x, 2))\r\n```\r\nA PR is forthcoming. \r\n",
      "issue_closed_at": "2018-11-24T11:36:42Z",
      "base_commit": "61e5c20c02328815270ddda385f0108a2b40d24d",
      "changes": [
        {
          "file": "sympy/core/basic.py",
          "type": "function",
          "name": "_eval_derivative_n_times",
          "class_name": "Basic",
          "code": "def _eval_derivative_n_times(self, s, n):\n        # This is the default evaluator for derivatives (as called by `diff`\n        # and `Derivative`), it will attempt a loop to derive the expression\n        # `n` times by calling the corresponding `_eval_derivative` method,\n        # while leaving the derivative unevaluated if `n` is symbolic.  This\n        # method should be overridden if the object has a closed form for its\n        # symbolic n-th derivative.\n        from sympy import Integer\n        if isinstance(n, (int, Integer)):\n            obj = self\n            for i in range(n):\n                obj2 = obj._accept_eval_derivative(s)\n                if obj == obj2:\n                    break\n                obj = obj2\n            return obj\n        else:\n            return None"
        }
      ]
    },
    {
      "pr_number": 17769,
      "pr_title": "Fix linsolve  for immutable matrix",
      "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 #17762 \r\nFixes #17722 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nI've fixed the type checking for `linearsolve`, and also fixed some usage of the mutability of a matrix in `gauss_jordan_solve`.\r\n\r\n#### Other comments\r\n\r\nI'd also try to check `linsolve` whether it works with matrix expressions.\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- matrices\r\n  - Fixed `Matrix.gauss_jordan_solve` raising `ShapeError` for immutable matrices.\r\n- solvers\r\n  - Fixed `linsolve` raising errors for `ImmutableMatrix`.\r\n<!-- END RELEASE NOTES -->\r\n",
      "issue_id": 17722,
      "issue_title": "linsolve error; ValueError: Got rows of variable lengths: [1, 3]",
      "issue_body": "Can anyone tell me if this is a bug and if there is a method to get around this please, cause it seems like the linsolve() function is broken?\r\nA similar question was asked in issue #17430 but this doesn't solve my problem when used in jupyter or qtconsole or spyder. This function would be really useful if it worked for my uni study.\r\n\r\nParameters given are: *system* in form of Ax=b and variables *c* in a tuple of Sympy Symbols\r\n![image](https://user-images.githubusercontent.com/42601907/66694509-028ba580-ed00-11e9-85db-f8e1567a5306.png)\r\n![image](https://user-images.githubusercontent.com/42601907/66694519-1505df00-ed00-11e9-9861-02ea8f1dd249.png)\r\n",
      "issue_closed_at": "2019-10-21T21:12:36Z",
      "base_commit": "4c87ea3ec5a36b0d3364b9bc52f88653282bf9aa",
      "changes": [
        {
          "file": "sympy/matrices/matrices.py",
          "type": "function",
          "name": "gauss_jordan_solve",
          "class_name": "MatrixBase",
          "code": "def gauss_jordan_solve(self, B, freevar=False):\n        \"\"\"\n        Solves ``Ax = B`` using Gauss Jordan elimination.\n\n        There may be zero, one, or infinite solutions.  If one solution\n        exists, it will be returned. If infinite solutions exist, it will\n        be returned parametrically. If no solutions exist, It will throw\n        ValueError.\n\n        Parameters\n        ==========\n\n        B : Matrix\n            The right hand side of the equation to be solved for.  Must have\n            the same number of rows as matrix A.\n\n        freevar : List\n            If the system is underdetermined (e.g. A has more columns than\n            rows), infinite solutions are possible, in terms of arbitrary\n            values of free variables. Then the index of the free variables\n            in the solutions (column Matrix) will be returned by freevar, if\n            the flag `freevar` is set to `True`.\n\n        Returns\n        =======\n\n        x : Matrix\n            The matrix that will satisfy ``Ax = B``.  Will have as many rows as\n            matrix A has columns, and as many columns as matrix B.\n\n        params : Matrix\n            If the system is underdetermined (e.g. A has more columns than\n            rows), infinite solutions are possible, in terms of arbitrary\n            parameters. These arbitrary parameters are returned as params\n            Matrix.\n\n        Examples\n        ========\n\n        >>> from sympy import Matrix\n        >>> A = Matrix([[1, 2, 1, 1], [1, 2, 2, -1], [2, 4, 0, 6]])\n        >>> B = Matrix([7, 12, 4])\n        >>> sol, params = A.gauss_jordan_solve(B)\n        >>> sol\n        Matrix([\n        [-2*tau0 - 3*tau1 + 2],\n        [                 tau0],\n        [           2*tau1 + 5],\n        [                 tau1]])\n        >>> params\n        Matrix([\n        [tau0],\n        [tau1]])\n        >>> taus_zeroes = { tau:0 for tau in params }\n        >>> sol_unique = sol.xreplace(taus_zeroes)\n        >>> sol_unique\n         Matrix([\n        [2],\n        [0],\n        [5],\n        [0]])\n\n\n        >>> A = Matrix([[1, 2, 3], [4, 5, 6], [7, 8, 10]])\n        >>> B = Matrix([3, 6, 9])\n        >>> sol, params = A.gauss_jordan_solve(B)\n        >>> sol\n        Matrix([\n        [-1],\n        [ 2],\n        [ 0]])\n        >>> params\n        Matrix(0, 1, [])\n\n        >>> A = Matrix([[2, -7], [-1, 4]])\n        >>> B = Matrix([[-21, 3], [12, -2]])\n        >>> sol, params = A.gauss_jordan_solve(B)\n        >>> sol\n        Matrix([\n        [0, -2],\n        [3, -1]])\n        >>> params\n        Matrix(0, 2, [])\n\n        See Also\n        ========\n\n        lower_triangular_solve\n        upper_triangular_solve\n        cholesky_solve\n        diagonal_solve\n        LDLsolve\n        LUsolve\n        QRsolve\n        pinv\n\n        References\n        ==========\n\n        .. [1] https://en.wikipedia.org/wiki/Gaussian_elimination\n\n        \"\"\"\n        from sympy.matrices import Matrix, zeros\n\n        aug = self.hstack(self.copy(), B.copy())\n        B_cols = B.cols\n        row, col = aug[:, :-B_cols].shape\n\n        # solve by reduced row echelon form\n        A, pivots = aug.rref(simplify=True)\n        A, v = A[:, :-B_cols], A[:, -B_cols:]\n        pivots = list(filter(lambda p: p < col, pivots))\n        rank = len(pivots)\n\n        # Bring to block form\n        permutation = Matrix(range(col)).T\n\n        for i, c in enumerate(pivots):\n            permutation.col_swap(i, c)\n\n\n        # check for existence of solutions\n        # rank of aug Matrix should be equal to rank of coefficient matrix\n        if not v[rank:, :].is_zero:\n            raise ValueError(\"Linear system has no solution\")\n\n        # Get index of free symbols (free parameters)\n        free_var_index = permutation[\n                         len(pivots):]  # non-pivots columns are free variables\n\n        # Free parameters\n        # what are current unnumbered free symbol names?\n        name = _uniquely_named_symbol('tau', aug,\n            compare=lambda i: str(i).rstrip('1234567890')).name\n        gen = numbered_symbols(name)\n        tau = Matrix([next(gen) for k in range((col - rank)*B_cols)]).reshape(\n            col - rank, B_cols)\n\n        # Full parametric solution\n        V = A[:rank,:]\n        for c in reversed(pivots):\n            V.col_del(c)\n        vt = v[:rank, :]\n        free_sol = tau.vstack(vt - V * tau, tau)\n\n        # Undo permutation\n        sol = zeros(col, B_cols)\n        for k in range(col):\n            sol[permutation[k], :] = free_sol[k,:]\n\n        if freevar:\n            return sol, tau, free_var_index\n        else:\n            return sol, tau"
        },
        {
          "file": "sympy/matrices/matrices.py",
          "type": "function",
          "name": "gauss_jordan_solve",
          "class_name": "MatrixBase",
          "code": "def gauss_jordan_solve(self, B, freevar=False):\n        \"\"\"\n        Solves ``Ax = B`` using Gauss Jordan elimination.\n\n        There may be zero, one, or infinite solutions.  If one solution\n        exists, it will be returned. If infinite solutions exist, it will\n        be returned parametrically. If no solutions exist, It will throw\n        ValueError.\n\n        Parameters\n        ==========\n\n        B : Matrix\n            The right hand side of the equation to be solved for.  Must have\n            the same number of rows as matrix A.\n\n        freevar : List\n            If the system is underdetermined (e.g. A has more columns than\n            rows), infinite solutions are possible, in terms of arbitrary\n            values of free variables. Then the index of the free variables\n            in the solutions (column Matrix) will be returned by freevar, if\n            the flag `freevar` is set to `True`.\n\n        Returns\n        =======\n\n        x : Matrix\n            The matrix that will satisfy ``Ax = B``.  Will have as many rows as\n            matrix A has columns, and as many columns as matrix B.\n\n        params : Matrix\n            If the system is underdetermined (e.g. A has more columns than\n            rows), infinite solutions are possible, in terms of arbitrary\n            parameters. These arbitrary parameters are returned as params\n            Matrix.\n\n        Examples\n        ========\n\n        >>> from sympy import Matrix\n        >>> A = Matrix([[1, 2, 1, 1], [1, 2, 2, -1], [2, 4, 0, 6]])\n        >>> B = Matrix([7, 12, 4])\n        >>> sol, params = A.gauss_jordan_solve(B)\n        >>> sol\n        Matrix([\n        [-2*tau0 - 3*tau1 + 2],\n        [                 tau0],\n        [           2*tau1 + 5],\n        [                 tau1]])\n        >>> params\n        Matrix([\n        [tau0],\n        [tau1]])\n        >>> taus_zeroes = { tau:0 for tau in params }\n        >>> sol_unique = sol.xreplace(taus_zeroes)\n        >>> sol_unique\n         Matrix([\n        [2],\n        [0],\n        [5],\n        [0]])\n\n\n        >>> A = Matrix([[1, 2, 3], [4, 5, 6], [7, 8, 10]])\n        >>> B = Matrix([3, 6, 9])\n        >>> sol, params = A.gauss_jordan_solve(B)\n        >>> sol\n        Matrix([\n        [-1],\n        [ 2],\n        [ 0]])\n        >>> params\n        Matrix(0, 1, [])\n\n        >>> A = Matrix([[2, -7], [-1, 4]])\n        >>> B = Matrix([[-21, 3], [12, -2]])\n        >>> sol, params = A.gauss_jordan_solve(B)\n        >>> sol\n        Matrix([\n        [0, -2],\n        [3, -1]])\n        >>> params\n        Matrix(0, 2, [])\n\n        See Also\n        ========\n\n        lower_triangular_solve\n        upper_triangular_solve\n        cholesky_solve\n        diagonal_solve\n        LDLsolve\n        LUsolve\n        QRsolve\n        pinv\n\n        References\n        ==========\n\n        .. [1] https://en.wikipedia.org/wiki/Gaussian_elimination\n\n        \"\"\"\n        from sympy.matrices import Matrix, zeros\n\n        aug = self.hstack(self.copy(), B.copy())\n        B_cols = B.cols\n        row, col = aug[:, :-B_cols].shape\n\n        # solve by reduced row echelon form\n        A, pivots = aug.rref(simplify=True)\n        A, v = A[:, :-B_cols], A[:, -B_cols:]\n        pivots = list(filter(lambda p: p < col, pivots))\n        rank = len(pivots)\n\n        # Bring to block form\n        permutation = Matrix(range(col)).T\n\n        for i, c in enumerate(pivots):\n            permutation.col_swap(i, c)\n\n\n        # check for existence of solutions\n        # rank of aug Matrix should be equal to rank of coefficient matrix\n        if not v[rank:, :].is_zero:\n            raise ValueError(\"Linear system has no solution\")\n\n        # Get index of free symbols (free parameters)\n        free_var_index = permutation[\n                         len(pivots):]  # non-pivots columns are free variables\n\n        # Free parameters\n        # what are current unnumbered free symbol names?\n        name = _uniquely_named_symbol('tau', aug,\n            compare=lambda i: str(i).rstrip('1234567890')).name\n        gen = numbered_symbols(name)\n        tau = Matrix([next(gen) for k in range((col - rank)*B_cols)]).reshape(\n            col - rank, B_cols)\n\n        # Full parametric solution\n        V = A[:rank,:]\n        for c in reversed(pivots):\n            V.col_del(c)\n        vt = v[:rank, :]\n        free_sol = tau.vstack(vt - V * tau, tau)\n\n        # Undo permutation\n        sol = zeros(col, B_cols)\n        for k in range(col):\n            sol[permutation[k], :] = free_sol[k,:]\n\n        if freevar:\n            return sol, tau, free_var_index\n        else:\n            return sol, tau"
        },
        {
          "file": "sympy/matrices/matrices.py",
          "type": "function",
          "name": "gauss_jordan_solve",
          "class_name": "MatrixBase",
          "code": "def gauss_jordan_solve(self, B, freevar=False):\n        \"\"\"\n        Solves ``Ax = B`` using Gauss Jordan elimination.\n\n        There may be zero, one, or infinite solutions.  If one solution\n        exists, it will be returned. If infinite solutions exist, it will\n        be returned parametrically. If no solutions exist, It will throw\n        ValueError.\n\n        Parameters\n        ==========\n\n        B : Matrix\n            The right hand side of the equation to be solved for.  Must have\n            the same number of rows as matrix A.\n\n        freevar : List\n            If the system is underdetermined (e.g. A has more columns than\n            rows), infinite solutions are possible, in terms of arbitrary\n            values of free variables. Then the index of the free variables\n            in the solutions (column Matrix) will be returned by freevar, if\n            the flag `freevar` is set to `True`.\n\n        Returns\n        =======\n\n        x : Matrix\n            The matrix that will satisfy ``Ax = B``.  Will have as many rows as\n            matrix A has columns, and as many columns as matrix B.\n\n        params : Matrix\n            If the system is underdetermined (e.g. A has more columns than\n            rows), infinite solutions are possible, in terms of arbitrary\n            parameters. These arbitrary parameters are returned as params\n            Matrix.\n\n        Examples\n        ========\n\n        >>> from sympy import Matrix\n        >>> A = Matrix([[1, 2, 1, 1], [1, 2, 2, -1], [2, 4, 0, 6]])\n        >>> B = Matrix([7, 12, 4])\n        >>> sol, params = A.gauss_jordan_solve(B)\n        >>> sol\n        Matrix([\n        [-2*tau0 - 3*tau1 + 2],\n        [                 tau0],\n        [           2*tau1 + 5],\n        [                 tau1]])\n        >>> params\n        Matrix([\n        [tau0],\n        [tau1]])\n        >>> taus_zeroes = { tau:0 for tau in params }\n        >>> sol_unique = sol.xreplace(taus_zeroes)\n        >>> sol_unique\n         Matrix([\n        [2],\n        [0],\n        [5],\n        [0]])\n\n\n        >>> A = Matrix([[1, 2, 3], [4, 5, 6], [7, 8, 10]])\n        >>> B = Matrix([3, 6, 9])\n        >>> sol, params = A.gauss_jordan_solve(B)\n        >>> sol\n        Matrix([\n        [-1],\n        [ 2],\n        [ 0]])\n        >>> params\n        Matrix(0, 1, [])\n\n        >>> A = Matrix([[2, -7], [-1, 4]])\n        >>> B = Matrix([[-21, 3], [12, -2]])\n        >>> sol, params = A.gauss_jordan_solve(B)\n        >>> sol\n        Matrix([\n        [0, -2],\n        [3, -1]])\n        >>> params\n        Matrix(0, 2, [])\n\n        See Also\n        ========\n\n        lower_triangular_solve\n        upper_triangular_solve\n        cholesky_solve\n        diagonal_solve\n        LDLsolve\n        LUsolve\n        QRsolve\n        pinv\n\n        References\n        ==========\n\n        .. [1] https://en.wikipedia.org/wiki/Gaussian_elimination\n\n        \"\"\"\n        from sympy.matrices import Matrix, zeros\n\n        aug = self.hstack(self.copy(), B.copy())\n        B_cols = B.cols\n        row, col = aug[:, :-B_cols].shape\n\n        # solve by reduced row echelon form\n        A, pivots = aug.rref(simplify=True)\n        A, v = A[:, :-B_cols], A[:, -B_cols:]\n        pivots = list(filter(lambda p: p < col, pivots))\n        rank = len(pivots)\n\n        # Bring to block form\n        permutation = Matrix(range(col)).T\n\n        for i, c in enumerate(pivots):\n            permutation.col_swap(i, c)\n\n\n        # check for existence of solutions\n        # rank of aug Matrix should be equal to rank of coefficient matrix\n        if not v[rank:, :].is_zero:\n            raise ValueError(\"Linear system has no solution\")\n\n        # Get index of free symbols (free parameters)\n        free_var_index = permutation[\n                         len(pivots):]  # non-pivots columns are free variables\n\n        # Free parameters\n        # what are current unnumbered free symbol names?\n        name = _uniquely_named_symbol('tau', aug,\n            compare=lambda i: str(i).rstrip('1234567890')).name\n        gen = numbered_symbols(name)\n        tau = Matrix([next(gen) for k in range((col - rank)*B_cols)]).reshape(\n            col - rank, B_cols)\n\n        # Full parametric solution\n        V = A[:rank,:]\n        for c in reversed(pivots):\n            V.col_del(c)\n        vt = v[:rank, :]\n        free_sol = tau.vstack(vt - V * tau, tau)\n\n        # Undo permutation\n        sol = zeros(col, B_cols)\n        for k in range(col):\n            sol[permutation[k], :] = free_sol[k,:]\n\n        if freevar:\n            return sol, tau, free_var_index\n        else:\n            return sol, tau"
        },
        {
          "file": "sympy/solvers/solveset.py",
          "type": "function",
          "name": "linsolve",
          "class_name": null,
          "code": "def linsolve(system, *symbols):\n    r\"\"\"\n    Solve system of N linear equations with M variables; both\n    underdetermined and overdetermined systems are supported.\n    The possible number of solutions is zero, one or infinite.\n    Zero solutions throws a ValueError, whereas infinite\n    solutions are represented parametrically in terms of the given\n    symbols. For unique solution a FiniteSet of ordered tuples\n    is returned.\n\n    All Standard input formats are supported:\n    For the given set of Equations, the respective input types\n    are given below:\n\n    .. math:: 3x + 2y -   z = 1\n    .. math:: 2x - 2y + 4z = -2\n    .. math:: 2x -   y + 2z = 0\n\n    * Augmented Matrix Form, `system` given below:\n\n    ::\n\n              [3   2  -1  1]\n     system = [2  -2   4 -2]\n              [2  -1   2  0]\n\n    * List Of Equations Form\n\n    `system  =  [3x + 2y - z - 1, 2x - 2y + 4z + 2, 2x - y + 2z]`\n\n    * Input A & b Matrix Form (from Ax = b) are given as below:\n\n    ::\n\n         [3   2  -1 ]         [  1 ]\n     A = [2  -2   4 ]    b =  [ -2 ]\n         [2  -1   2 ]         [  0 ]\n\n    `system = (A, b)`\n\n    Symbols can always be passed but are actually only needed\n    when 1) a system of equations is being passed and 2) the\n    system is passed as an underdetermined matrix and one wants\n    to control the name of the free variables in the result.\n    An error is raised if no symbols are used for case 1, but if\n    no symbols are provided for case 2, internally generated symbols\n    will be provided. When providing symbols for case 2, there should\n    be at least as many symbols are there are columns in matrix A.\n\n    The algorithm used here is Gauss-Jordan elimination, which\n    results, after elimination, in a row echelon form matrix.\n\n    Returns\n    =======\n\n    A FiniteSet containing an ordered tuple of values for the\n    unknowns for which the `system` has a solution. (Wrapping\n    the tuple in FiniteSet is used to maintain a consistent\n    output format throughout solveset.)\n\n    Returns EmptySet(), if the linear system is inconsistent.\n\n    Raises\n    ======\n\n    ValueError\n        The input is not valid.\n        The symbols are not given.\n\n    Examples\n    ========\n\n    >>> from sympy import Matrix, S, linsolve, symbols\n    >>> x, y, z = symbols(\"x, y, z\")\n    >>> A = Matrix([[1, 2, 3], [4, 5, 6], [7, 8, 10]])\n    >>> b = Matrix([3, 6, 9])\n    >>> A\n    Matrix([\n    [1, 2,  3],\n    [4, 5,  6],\n    [7, 8, 10]])\n    >>> b\n    Matrix([\n    [3],\n    [6],\n    [9]])\n    >>> linsolve((A, b), [x, y, z])\n    {(-1, 2, 0)}\n\n    * Parametric Solution: In case the system is underdetermined, the\n      function will return a parametric solution in terms of the given\n      symbols. Those that are free will be returned unchanged. e.g. in\n      the system below, `z` is returned as the solution for variable z;\n      it can take on any value.\n\n    >>> A = Matrix([[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n    >>> b = Matrix([3, 6, 9])\n    >>> linsolve((A, b), x, y, z)\n    {(z - 1, 2 - 2*z, z)}\n\n    If no symbols are given, internally generated symbols will be used.\n    The `tau0` in the 3rd position indicates (as before) that the 3rd\n    variable -- whatever it's named -- can take on any value:\n\n    >>> linsolve((A, b))\n    {(tau0 - 1, 2 - 2*tau0, tau0)}\n\n    * List of Equations as input\n\n    >>> Eqns = [3*x + 2*y - z - 1, 2*x - 2*y + 4*z + 2, - x + y/2 - z]\n    >>> linsolve(Eqns, x, y, z)\n    {(1, -2, -2)}\n\n    * Augmented Matrix as input\n\n    >>> aug = Matrix([[2, 1, 3, 1], [2, 6, 8, 3], [6, 8, 18, 5]])\n    >>> aug\n    Matrix([\n    [2, 1,  3, 1],\n    [2, 6,  8, 3],\n    [6, 8, 18, 5]])\n    >>> linsolve(aug, x, y, z)\n    {(3/10, 2/5, 0)}\n\n    * Solve for symbolic coefficients\n\n    >>> a, b, c, d, e, f = symbols('a, b, c, d, e, f')\n    >>> eqns = [a*x + b*y - c, d*x + e*y - f]\n    >>> linsolve(eqns, x, y)\n    {((-b*f + c*e)/(a*e - b*d), (a*f - c*d)/(a*e - b*d))}\n\n    * A degenerate system returns solution as set of given\n      symbols.\n\n    >>> system = Matrix(([0, 0, 0], [0, 0, 0], [0, 0, 0]))\n    >>> linsolve(system, x, y)\n    {(x, y)}\n\n    * For an empty system linsolve returns empty set\n\n    >>> linsolve([], x)\n    EmptySet()\n\n    * An error is raised if, after expansion, any nonlinearity\n      is detected:\n\n    >>> linsolve([x*(1/x - 1), (y - 1)**2 - y**2 + 1], x, y)\n    {(1, 1)}\n    >>> linsolve([x**2 - 1], x)\n    Traceback (most recent call last):\n    ...\n    ValueError:\n    The term x**2 is nonlinear in {x}\n    \"\"\"\n    if not system:\n        return S.EmptySet\n\n    # If second argument is an iterable\n    if symbols and hasattr(symbols[0], '__iter__'):\n        symbols = symbols[0]\n    sym_gen = isinstance(symbols, GeneratorType)\n\n    swap = {}\n    b = None  # if we don't get b the input was bad\n    syms_needed_msg = None\n\n    # unpack system\n\n    if hasattr(system, '__iter__'):\n\n        # 1). (A, b)\n        if len(system) == 2 and isinstance(system[0], Matrix):\n            A, b = system\n\n        # 2). (eq1, eq2, ...)\n        if not isinstance(system[0], Matrix):\n            if sym_gen or not symbols:\n                raise ValueError(filldedent('''\n                    When passing a system of equations, the explicit\n                    symbols for which a solution is being sought must\n                    be given as a sequence, too.\n                '''))\n            system = [\n                _mexpand(i.lhs - i.rhs if isinstance(i, Eq) else i,\n                recursive=True) for i in system]\n            system, symbols, swap = recast_to_symbols(system, symbols)\n            A, b = linear_eq_to_matrix(system, symbols)\n            syms_needed_msg = 'free symbols in the equations provided'\n\n    elif isinstance(system, Matrix) and not (\n            symbols and not isinstance(symbols, GeneratorType) and\n            isinstance(symbols[0], Matrix)):\n        # 3). A augmented with b\n        A, b = system[:, :-1], system[:, -1:]\n\n    if b is None:\n        raise ValueError(\"Invalid arguments\")\n\n    syms_needed_msg  = syms_needed_msg or 'columns of A'\n\n    if sym_gen:\n        symbols = [next(symbols) for i in range(A.cols)]\n        if any(set(symbols) & (A.free_symbols | b.free_symbols)):\n            raise ValueError(filldedent('''\n                At least one of the symbols provided\n                already appears in the system to be solved.\n                One way to avoid this is to use Dummy symbols in\n                the generator, e.g. numbered_symbols('%s', cls=Dummy)\n            ''' % symbols[0].name.rstrip('1234567890')))\n\n    try:\n        solution, params, free_syms = A.gauss_jordan_solve(b, freevar=True)\n    except ValueError:\n        # No solution\n        return S.EmptySet\n\n    # Replace free parameters with free symbols\n    if params:\n        if not symbols:\n            symbols = [_ for _ in params]\n            # re-use the parameters but put them in order\n            # params       [x, y, z]\n            # free_symbols [2, 0, 4]\n            # idx          [1, 0, 2]\n            idx = list(zip(*sorted(zip(free_syms, range(len(free_syms))))))[1]\n            # simultaneous replacements {y: x, x: y, z: z}\n            replace_dict = dict(zip(symbols, [symbols[i] for i in idx]))\n        elif len(symbols) >= A.cols:\n            replace_dict = {v: symbols[free_syms[k]] for k, v in enumerate(params)}\n        else:\n            raise IndexError(filldedent('''\n                the number of symbols passed should have a length\n                equal to the number of %s.\n                ''' % syms_needed_msg))\n        solution = [sol.xreplace(replace_dict) for sol in solution]\n\n    solution = [simplify(sol).xreplace(swap) for sol in solution]\n    return FiniteSet(tuple(solution))"
        },
        {
          "file": "sympy/solvers/solveset.py",
          "type": "function",
          "name": "linsolve",
          "class_name": null,
          "code": "def linsolve(system, *symbols):\n    r\"\"\"\n    Solve system of N linear equations with M variables; both\n    underdetermined and overdetermined systems are supported.\n    The possible number of solutions is zero, one or infinite.\n    Zero solutions throws a ValueError, whereas infinite\n    solutions are represented parametrically in terms of the given\n    symbols. For unique solution a FiniteSet of ordered tuples\n    is returned.\n\n    All Standard input formats are supported:\n    For the given set of Equations, the respective input types\n    are given below:\n\n    .. math:: 3x + 2y -   z = 1\n    .. math:: 2x - 2y + 4z = -2\n    .. math:: 2x -   y + 2z = 0\n\n    * Augmented Matrix Form, `system` given below:\n\n    ::\n\n              [3   2  -1  1]\n     system = [2  -2   4 -2]\n              [2  -1   2  0]\n\n    * List Of Equations Form\n\n    `system  =  [3x + 2y - z - 1, 2x - 2y + 4z + 2, 2x - y + 2z]`\n\n    * Input A & b Matrix Form (from Ax = b) are given as below:\n\n    ::\n\n         [3   2  -1 ]         [  1 ]\n     A = [2  -2   4 ]    b =  [ -2 ]\n         [2  -1   2 ]         [  0 ]\n\n    `system = (A, b)`\n\n    Symbols can always be passed but are actually only needed\n    when 1) a system of equations is being passed and 2) the\n    system is passed as an underdetermined matrix and one wants\n    to control the name of the free variables in the result.\n    An error is raised if no symbols are used for case 1, but if\n    no symbols are provided for case 2, internally generated symbols\n    will be provided. When providing symbols for case 2, there should\n    be at least as many symbols are there are columns in matrix A.\n\n    The algorithm used here is Gauss-Jordan elimination, which\n    results, after elimination, in a row echelon form matrix.\n\n    Returns\n    =======\n\n    A FiniteSet containing an ordered tuple of values for the\n    unknowns for which the `system` has a solution. (Wrapping\n    the tuple in FiniteSet is used to maintain a consistent\n    output format throughout solveset.)\n\n    Returns EmptySet(), if the linear system is inconsistent.\n\n    Raises\n    ======\n\n    ValueError\n        The input is not valid.\n        The symbols are not given.\n\n    Examples\n    ========\n\n    >>> from sympy import Matrix, S, linsolve, symbols\n    >>> x, y, z = symbols(\"x, y, z\")\n    >>> A = Matrix([[1, 2, 3], [4, 5, 6], [7, 8, 10]])\n    >>> b = Matrix([3, 6, 9])\n    >>> A\n    Matrix([\n    [1, 2,  3],\n    [4, 5,  6],\n    [7, 8, 10]])\n    >>> b\n    Matrix([\n    [3],\n    [6],\n    [9]])\n    >>> linsolve((A, b), [x, y, z])\n    {(-1, 2, 0)}\n\n    * Parametric Solution: In case the system is underdetermined, the\n      function will return a parametric solution in terms of the given\n      symbols. Those that are free will be returned unchanged. e.g. in\n      the system below, `z` is returned as the solution for variable z;\n      it can take on any value.\n\n    >>> A = Matrix([[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n    >>> b = Matrix([3, 6, 9])\n    >>> linsolve((A, b), x, y, z)\n    {(z - 1, 2 - 2*z, z)}\n\n    If no symbols are given, internally generated symbols will be used.\n    The `tau0` in the 3rd position indicates (as before) that the 3rd\n    variable -- whatever it's named -- can take on any value:\n\n    >>> linsolve((A, b))\n    {(tau0 - 1, 2 - 2*tau0, tau0)}\n\n    * List of Equations as input\n\n    >>> Eqns = [3*x + 2*y - z - 1, 2*x - 2*y + 4*z + 2, - x + y/2 - z]\n    >>> linsolve(Eqns, x, y, z)\n    {(1, -2, -2)}\n\n    * Augmented Matrix as input\n\n    >>> aug = Matrix([[2, 1, 3, 1], [2, 6, 8, 3], [6, 8, 18, 5]])\n    >>> aug\n    Matrix([\n    [2, 1,  3, 1],\n    [2, 6,  8, 3],\n    [6, 8, 18, 5]])\n    >>> linsolve(aug, x, y, z)\n    {(3/10, 2/5, 0)}\n\n    * Solve for symbolic coefficients\n\n    >>> a, b, c, d, e, f = symbols('a, b, c, d, e, f')\n    >>> eqns = [a*x + b*y - c, d*x + e*y - f]\n    >>> linsolve(eqns, x, y)\n    {((-b*f + c*e)/(a*e - b*d), (a*f - c*d)/(a*e - b*d))}\n\n    * A degenerate system returns solution as set of given\n      symbols.\n\n    >>> system = Matrix(([0, 0, 0], [0, 0, 0], [0, 0, 0]))\n    >>> linsolve(system, x, y)\n    {(x, y)}\n\n    * For an empty system linsolve returns empty set\n\n    >>> linsolve([], x)\n    EmptySet()\n\n    * An error is raised if, after expansion, any nonlinearity\n      is detected:\n\n    >>> linsolve([x*(1/x - 1), (y - 1)**2 - y**2 + 1], x, y)\n    {(1, 1)}\n    >>> linsolve([x**2 - 1], x)\n    Traceback (most recent call last):\n    ...\n    ValueError:\n    The term x**2 is nonlinear in {x}\n    \"\"\"\n    if not system:\n        return S.EmptySet\n\n    # If second argument is an iterable\n    if symbols and hasattr(symbols[0], '__iter__'):\n        symbols = symbols[0]\n    sym_gen = isinstance(symbols, GeneratorType)\n\n    swap = {}\n    b = None  # if we don't get b the input was bad\n    syms_needed_msg = None\n\n    # unpack system\n\n    if hasattr(system, '__iter__'):\n\n        # 1). (A, b)\n        if len(system) == 2 and isinstance(system[0], Matrix):\n            A, b = system\n\n        # 2). (eq1, eq2, ...)\n        if not isinstance(system[0], Matrix):\n            if sym_gen or not symbols:\n                raise ValueError(filldedent('''\n                    When passing a system of equations, the explicit\n                    symbols for which a solution is being sought must\n                    be given as a sequence, too.\n                '''))\n            system = [\n                _mexpand(i.lhs - i.rhs if isinstance(i, Eq) else i,\n                recursive=True) for i in system]\n            system, symbols, swap = recast_to_symbols(system, symbols)\n            A, b = linear_eq_to_matrix(system, symbols)\n            syms_needed_msg = 'free symbols in the equations provided'\n\n    elif isinstance(system, Matrix) and not (\n            symbols and not isinstance(symbols, GeneratorType) and\n            isinstance(symbols[0], Matrix)):\n        # 3). A augmented with b\n        A, b = system[:, :-1], system[:, -1:]\n\n    if b is None:\n        raise ValueError(\"Invalid arguments\")\n\n    syms_needed_msg  = syms_needed_msg or 'columns of A'\n\n    if sym_gen:\n        symbols = [next(symbols) for i in range(A.cols)]\n        if any(set(symbols) & (A.free_symbols | b.free_symbols)):\n            raise ValueError(filldedent('''\n                At least one of the symbols provided\n                already appears in the system to be solved.\n                One way to avoid this is to use Dummy symbols in\n                the generator, e.g. numbered_symbols('%s', cls=Dummy)\n            ''' % symbols[0].name.rstrip('1234567890')))\n\n    try:\n        solution, params, free_syms = A.gauss_jordan_solve(b, freevar=True)\n    except ValueError:\n        # No solution\n        return S.EmptySet\n\n    # Replace free parameters with free symbols\n    if params:\n        if not symbols:\n            symbols = [_ for _ in params]\n            # re-use the parameters but put them in order\n            # params       [x, y, z]\n            # free_symbols [2, 0, 4]\n            # idx          [1, 0, 2]\n            idx = list(zip(*sorted(zip(free_syms, range(len(free_syms))))))[1]\n            # simultaneous replacements {y: x, x: y, z: z}\n            replace_dict = dict(zip(symbols, [symbols[i] for i in idx]))\n        elif len(symbols) >= A.cols:\n            replace_dict = {v: symbols[free_syms[k]] for k, v in enumerate(params)}\n        else:\n            raise IndexError(filldedent('''\n                the number of symbols passed should have a length\n                equal to the number of %s.\n                ''' % syms_needed_msg))\n        solution = [sol.xreplace(replace_dict) for sol in solution]\n\n    solution = [simplify(sol).xreplace(swap) for sol in solution]\n    return FiniteSet(tuple(solution))"
        }
      ]
    }
  ]
}