{
  "instance_id": "sympy__sympy-13647",
  "repo": "sympy/sympy",
  "created_at": "2017-11-28T21:22:51Z",
  "problem_statement": "Matrix.col_insert() no longer seems to work correctly.\nExample:\r\n\r\n```\r\nIn [28]: import sympy as sm\r\n\r\nIn [29]: M = sm.eye(6)\r\n\r\nIn [30]: M\r\nOut[30]: \r\n\u23a11  0  0  0  0  0\u23a4\r\n\u23a2                \u23a5\r\n\u23a20  1  0  0  0  0\u23a5\r\n\u23a2                \u23a5\r\n\u23a20  0  1  0  0  0\u23a5\r\n\u23a2                \u23a5\r\n\u23a20  0  0  1  0  0\u23a5\r\n\u23a2                \u23a5\r\n\u23a20  0  0  0  1  0\u23a5\r\n\u23a2                \u23a5\r\n\u23a30  0  0  0  0  1\u23a6\r\n\r\nIn [31]: V = 2 * sm.ones(6, 2)\r\n\r\nIn [32]: V\r\nOut[32]: \r\n\u23a12  2\u23a4\r\n\u23a2    \u23a5\r\n\u23a22  2\u23a5\r\n\u23a2    \u23a5\r\n\u23a22  2\u23a5\r\n\u23a2    \u23a5\r\n\u23a22  2\u23a5\r\n\u23a2    \u23a5\r\n\u23a22  2\u23a5\r\n\u23a2    \u23a5\r\n\u23a32  2\u23a6\r\n\r\nIn [33]: M.col_insert(3, V)\r\nOut[33]: \r\n\u23a11  0  0  2  2  1  0  0\u23a4\r\n\u23a2                      \u23a5\r\n\u23a20  1  0  2  2  0  1  0\u23a5\r\n\u23a2                      \u23a5\r\n\u23a20  0  1  2  2  0  0  1\u23a5\r\n\u23a2                      \u23a5\r\n\u23a20  0  0  2  2  0  0  0\u23a5\r\n\u23a2                      \u23a5\r\n\u23a20  0  0  2  2  0  0  0\u23a5\r\n\u23a2                      \u23a5\r\n\u23a30  0  0  2  2  0  0  0\u23a6\r\nIn [34]: sm.__version__\r\nOut[34]: '1.1.1'\r\n```\r\n\r\nThe 3 x 3 identify matrix to the right of the columns of twos is shifted from the bottom three rows to the top three rows.\r\n\r\n@siefkenj Do you think this has to do with your matrix refactor?\n",
  "patch": "diff --git a/sympy/matrices/common.py b/sympy/matrices/common.py\n--- a/sympy/matrices/common.py\n+++ b/sympy/matrices/common.py\n@@ -86,7 +86,7 @@ def entry(i, j):\n                 return self[i, j]\n             elif pos <= j < pos + other.cols:\n                 return other[i, j - pos]\n-            return self[i, j - pos - other.cols]\n+            return self[i, j - other.cols]\n \n         return self._new(self.rows, self.cols + other.cols,\n                          lambda i, j: entry(i, j))\n",
  "similar_bug_items": [
    {
      "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": 10269,
      "pr_title": "Beware of non-orthogonal Jordan blocks",
      "pr_body": "The matrix\n\n```\nM = Matrix([[1, 0, 0, 1],\n         [0, 1, 1, 0],\n         [0, 0, 1, 1],\n         [0, 0, 0, 1]])\n```\n\nhas a single fourfold eigenvalue 1 and only two eigenvectors\n`[1, 0. 0, 0]` and `[0, 1, 0, 0]` considered as column vectors.\n(The first two columns of `M`.) The latter belongs to a Jordan block\nof dimension three generated by (the columns of)\n\n```\n[0, 1, 0]\n[1, 0, 0]\n[0, 1, 0]\n[0, 0, 1]\n```\n\nThese vectors form a Jordan chain with the last column as the chain leader.\nThe others are obtained by repeatedly applying `M - I` (where `I` is\nthe identity matrix) so that they are on different \"levels\". The first one\nis in the kernel of `M - I` (together with `[1, 0, 0, 0]`). The middle\ncolumn is in the kernel of `(M - I)**2` while the last column is annulled\nonly by `(M - I)**3`. The first eigenvector is also a chain leader and\nspans a block of dimension one.\n\nThe Jordan chains belonging to the eigenvalue 1 are found by first\nconstructing the increasing sequence `Ns[s]` of kernels of\n`(M - I)**s` for `s = 1, 2, 3`. The chain leaders belonging to\n`Ns[3]` are among those that do not belong to `Ns[2]`. They can be\nfound by searching vectors that are orthogonal to the subspace `Ns[2]`.\nIn this case the orthogonal subspace is one-dimensional, generated by\n`[0, 0, 0, 1]`. The corresponding chain is 3-dimensional.\n\nThere remains only a single one-dimensional block generated by a vector\nof `Ns[1]` not belonging to the first-found chain. Such a vector\n`[1, 0, 0, 0]` is again found by orthogonality, but one must be\ncareful to not demand orthogonality with respect to all chain vectors\nfound previously. Only the one on the same level, namely `[0, 1, 0, 0]`,\nis to be used. If also the second chain vector `[1, 0, 1, 0]` on the\nnext level is taken into account, no vectors remain to be found.\n\nFixes #10220\n",
      "issue_id": 10220,
      "issue_title": "Matrix.jordan_cells() fails",
      "issue_body": "I have SymPy 0.7.7.dev (Python 2.7.6-64-bit) and the following **matrix**:\n\n``` python\nM = Matrix([\n   ...: [1, 0, 0, 1],\n   ...: [0, 1, 1, 0],\n   ...: [0, 0, 1, 1],\n   ...: [0, 0, 0, 1]])\n```\n\nA 4x4 matrix, not very spectacular. However, the following computation **fails**:\n\n``` python\nM.jordan_cells()\n```\n\nHere is what my interpreter says:\n\n> /usr/local/lib/python2.7/dist-packages/sympy-0.7.7.dev-py2.7.egg/sympy/matrices/matrices.pyc in jordan_cells(self, calc_transformation)\n>   3827         P = MutableMatrix.zeros(n)\n>   3828         for j in range(0, n):\n> -> 3829             P[:, j] = Pcols_new[j]\n>   3830 \n>   3831         return type(self)(P), Jcells\n> \n> IndexError: list index out of range\n\nI believe that the Jordan normal form **can be** computed for this matrix. So I guess I fell in a corner case.\nThe online engine [WolframAlpha](http://www.wolframalpha.com/input/?i=jordan+normal+form+calculator&f1={{1%2C+0%2C+0%2C+1}%2C+{0%2C+1%2C+1%2C+0}%2C+{0%2C+0%2C+1%2C+1}%2C+{0%2C+0%2C+0%2C+1}}&f=JordanDecompositionCalculator.theMatrix_{{1%2C+0%2C+0%2C+1}%2C+{0%2C+1%2C+1%2C+0}%2C+{0%2C+0%2C+1%2C+1}%2C+{0%2C+0%2C+0%2C+1}}) finds a solution.\nCan anyone help or fix?\n\n[jordan_cells_failure.txt](https://github.com/sympy/sympy/files/57273/jordan_cells_failure.txt)\n",
      "issue_closed_at": "2015-12-16T20:30:36Z",
      "base_commit": "4bc92d1fd8cec503d66f8aed30f9348e7c8b08d1",
      "changes": [
        {
          "file": "sympy/matrices/matrices.py",
          "type": "function",
          "name": "_jordan_block_structure",
          "class_name": "MatrixBase",
          "code": "def _jordan_block_structure(self):\n        # To every eigenvalue may belong `i` blocks with size s(i)\n        # and a chain of generalized eigenvectors\n        # which will be determined by the following computations:\n        # for every eigenvalue we will add a dictionary\n        # containing, for all blocks, the blocksizes and the attached chain vectors\n        # that will eventually be used to form the transformation P\n        jordan_block_structures = {}\n        _eigenvects = self.eigenvects()\n        ev = self.eigenvals()\n        if len(ev) == 0:\n            raise AttributeError(\"could not compute the eigenvalues\")\n        for eigenval, multiplicity, vects in _eigenvects:\n            l_jordan_chains={}\n            geometrical = len(vects)\n            if geometrical == multiplicity:\n                # The Jordan chains have all length 1 and consist of only one vector\n                # which is the eigenvector of course\n                chains = []\n                for v in vects:\n                    chain=[v]\n                    chains.append(chain)\n                l_jordan_chains[1] = chains\n                jordan_block_structures[eigenval] = l_jordan_chains\n            elif geometrical == 0:\n                raise MatrixError(\"Matrix has the eigen vector with geometrical multiplicity equal zero.\")\n            else:\n                # Up to now we know nothing about the sizes of the blocks of our Jordan matrix.\n                # Note that knowledge of algebraic and geometrical multiplicity\n                # will *NOT* be sufficient to determine this structure.\n                # The blocksize `s` could be defined as the minimal `k` where\n                # `kernel(self-lI)^k = kernel(self-lI)^(k+1)`\n                # The extreme case would be that k = (multiplicity-geometrical+1)\n                # but the blocks could be smaller.\n\n                # Consider for instance the following matrix\n\n                # [2 1 0 0]\n                # [0 2 1 0]\n                # [0 0 2 0]\n                # [0 0 0 2]\n\n                # which coincides with it own Jordan canonical form.\n                # It has only one eigenvalue l=2 of (algebraic) multiplicity=4.\n                # It has two eigenvectors, one belonging to the last row (blocksize 1)\n                # and one being the last part of a jordan chain of length 3 (blocksize of the first block).\n\n                # Note again that it is not not possible to obtain this from the algebraic and geometrical\n                # multiplicity alone. This only gives us an upper limit for the dimension of one of\n                # the subspaces (blocksize of according jordan block) given by\n                # max=(multiplicity-geometrical+1) which is reached for our matrix\n                # but not for\n\n                # [2 1 0 0]\n                # [0 2 0 0]\n                # [0 0 2 1]\n                # [0 0 0 2]\n\n                # although multiplicity=4 and geometrical=2 are the same for this matrix.\n\n                from sympy.matrices import MutableMatrix\n                I = MutableMatrix.eye(self.rows)\n                l = eigenval\n                M = (self-l*I)\n\n                # We will store the matrices `(self-l*I)^k` for further computations\n                # for convenience only we store `Ms[0]=(sefl-lI)^0=I`\n                # so the index is the same as the power for all further Ms entries\n                # We also store the vectors that span these kernels (Ns[0] = [])\n                # and also their dimensions `a_s`\n                # this is mainly done for debugging since the number of blocks of a given size\n                # can be computed from the a_s, in order to check our result which is obtained simpler\n                # by counting the number of Jordan chains for `a` given `s`\n                # `a_0` is `dim(Kernel(Ms[0]) = dim (Kernel(I)) = 0` since `I` is regular\n\n                l_jordan_chains={}\n                chain_vectors=[]\n                Ms = [I]\n                Ns = [[]]\n                a = [0]\n                smax = 0\n                M_new = Ms[-1]*M\n                Ns_new = M_new.nullspace()\n                a_new = len(Ns_new)\n                Ms.append(M_new)\n                Ns.append(Ns_new)\n                while a_new > a[-1]:  # as long as the nullspaces increase compute further powers\n                    a.append(a_new)\n                    M_new = Ms[-1]*M\n                    Ns_new = M_new.nullspace()\n                    a_new=len(Ns_new)\n                    Ms.append(M_new)\n                    Ns.append(Ns_new)\n                    smax += 1\n\n                # We now have `Ms[-1]=((self-l*I)**s)=Z=0`.\n                # We also know the size of the biggest Jordan block\n                # associated with `l` to be `s`.\n                # Now let us proceed with the computation of the associate part of the transformation matrix `P`.\n                # We already know the kernel (=nullspace)  `K_l` of (self-lI) which consists of the\n                # eigenvectors belonging to eigenvalue `l`.\n                # The dimension of this space is the geometric multiplicity of eigenvalue `l`.\n                # For every eigenvector ev out of `K_l`, there exists a subspace that is\n                # spanned by the Jordan chain of ev. The dimension of this subspace is\n                # represented by the length `s` of the Jordan block.\n                # The chain itself is given by `{e_0,..,e_s-1}` where:\n                # `e_k+1 =(self-lI)e_k (*)`\n                # and\n                # `e_s-1=ev`\n                # So it would be possible to start with the already known `ev` and work backwards until one\n                # reaches `e_0`. Unfortunately this can not be done by simply solving system (*) since its matrix\n                # is singular (by definition of the eigenspaces).\n                # This approach would force us a choose in every step the degree of freedom undetermined\n                # by (*). This is difficult to implement with computer algebra systems and also quite inefficient.\n                # We therefore reformulate the problem in terms of nullspaces.\n                # To do so we start from the other end and choose `e0`'s out of\n                # `E=Kernel(self-lI)^s / Kernel(self-lI)^(s-1)`\n                # Note that `Kernel(self-lI)^s = Kernel(Z) = V` (the whole vector space).\n                # So in the first step `s=smax` this restriction turns out to actually restrict nothing at all\n                # and the only remaining condition is to choose vectors in `Kernel(self-lI)^(s-1)`.\n                # Subsequently we compute `e_1=(self-lI)e_0`, `e_2=(self-lI)*e_1` and so on.\n                # The subspace `E` can have a dimension larger than one.\n                # That means that we have more than one Jordan block of size `s` for the eigenvalue `l`\n                # and as many Jordan chains (this is the case in the second example).\n                # In this case we start as many Jordan chains and have as many blocks of size `s` in the jcf.\n                # We now have all the Jordan blocks of size `s` but there might be others attached to the same\n                # eigenvalue that are smaller.\n                # So we will do the same procedure also for `s-1` and so on until 1 (the lowest possible order\n                # where the Jordan chain is of length 1 and just represented by the eigenvector).\n\n                for s in reversed(range(1, smax+1)):\n                    S = Ms[s]\n                    # We want the vectors in `Kernel((self-lI)^s)` (**),\n                    # but without those in `Kernel(self-lI)^s-1` so we will add these as additional equations\n                    # to the system formed by `S` (`S` will no longer be quadratic but this does no harm\n                    # since `S` is rank deficient).\n                    exclude_vectors = Ns[s-1]\n                    for k in range(0, a[s-1]):\n                        S = S.col_join((exclude_vectors[k]).adjoint())\n                    # We also want to exclude the vectors in the chains for the bigger blocks\n                    # that we have already computed (if there are any).\n                    # (That is why we start with the biggest s).\n\n                    ########   Implementation remark:   ########\n\n                    # Doing so for *ALL* already computed chain vectors\n                    # we actually exclude some vectors twice because they are already excluded\n                    # by the condition (**).\n                    # This happens if there are more than one blocks attached to the same eigenvalue *AND*\n                    # the current blocksize is smaller than the block whose chain vectors we exclude.\n                    # If the current block has size `s_i` and the next bigger block has size `s_i-1` then\n                    # the first `s_i-s_i-1` chainvectors of the bigger block are already excluded by (**).\n                    # The unnecassary adding of these equations could be avoided if the algorithm would\n                    # take into account the lengths of the already computed chains which are already stored\n                    # and add only the last `s` items.\n                    # However the following loop would be a good deal more nested to do so.\n                    # Since adding a linear dependent equation does not change the result,\n                    # it can harm only in terms of efficiency.\n                    # So to be sure I left it there for the moment.\n\n                    l = len(chain_vectors)\n                    if l > 0:\n                        for k in range(0, l):\n                            old = chain_vectors[k].adjoint()\n                            S = S.col_join(old)\n                    e0s = S.nullspace()\n                    # Determine the number of chain leaders which equals the number of blocks with that size.\n                    n_e0 = len(e0s)\n                    s_chains = []\n                    # s_cells=[]\n                    for i in range(0, n_e0):\n                        chain=[e0s[i]]\n                        for k in range(1, s):\n                            v = M*chain[k-1]\n                            chain.append(v)\n\n                        # We want the chain leader appear as the last of the block.\n                        chain.reverse()\n                        chain_vectors += chain\n                        s_chains.append(chain)\n                    l_jordan_chains[s] = s_chains\n            jordan_block_structures[eigenval] = l_jordan_chains\n        return jordan_block_structures"
        },
        {
          "file": "sympy/matrices/matrices.py",
          "type": "function",
          "name": "_jordan_block_structure",
          "class_name": "MatrixBase",
          "code": "def _jordan_block_structure(self):\n        # To every eigenvalue may belong `i` blocks with size s(i)\n        # and a chain of generalized eigenvectors\n        # which will be determined by the following computations:\n        # for every eigenvalue we will add a dictionary\n        # containing, for all blocks, the blocksizes and the attached chain vectors\n        # that will eventually be used to form the transformation P\n        jordan_block_structures = {}\n        _eigenvects = self.eigenvects()\n        ev = self.eigenvals()\n        if len(ev) == 0:\n            raise AttributeError(\"could not compute the eigenvalues\")\n        for eigenval, multiplicity, vects in _eigenvects:\n            l_jordan_chains={}\n            geometrical = len(vects)\n            if geometrical == multiplicity:\n                # The Jordan chains have all length 1 and consist of only one vector\n                # which is the eigenvector of course\n                chains = []\n                for v in vects:\n                    chain=[v]\n                    chains.append(chain)\n                l_jordan_chains[1] = chains\n                jordan_block_structures[eigenval] = l_jordan_chains\n            elif geometrical == 0:\n                raise MatrixError(\"Matrix has the eigen vector with geometrical multiplicity equal zero.\")\n            else:\n                # Up to now we know nothing about the sizes of the blocks of our Jordan matrix.\n                # Note that knowledge of algebraic and geometrical multiplicity\n                # will *NOT* be sufficient to determine this structure.\n                # The blocksize `s` could be defined as the minimal `k` where\n                # `kernel(self-lI)^k = kernel(self-lI)^(k+1)`\n                # The extreme case would be that k = (multiplicity-geometrical+1)\n                # but the blocks could be smaller.\n\n                # Consider for instance the following matrix\n\n                # [2 1 0 0]\n                # [0 2 1 0]\n                # [0 0 2 0]\n                # [0 0 0 2]\n\n                # which coincides with it own Jordan canonical form.\n                # It has only one eigenvalue l=2 of (algebraic) multiplicity=4.\n                # It has two eigenvectors, one belonging to the last row (blocksize 1)\n                # and one being the last part of a jordan chain of length 3 (blocksize of the first block).\n\n                # Note again that it is not not possible to obtain this from the algebraic and geometrical\n                # multiplicity alone. This only gives us an upper limit for the dimension of one of\n                # the subspaces (blocksize of according jordan block) given by\n                # max=(multiplicity-geometrical+1) which is reached for our matrix\n                # but not for\n\n                # [2 1 0 0]\n                # [0 2 0 0]\n                # [0 0 2 1]\n                # [0 0 0 2]\n\n                # although multiplicity=4 and geometrical=2 are the same for this matrix.\n\n                from sympy.matrices import MutableMatrix\n                I = MutableMatrix.eye(self.rows)\n                l = eigenval\n                M = (self-l*I)\n\n                # We will store the matrices `(self-l*I)^k` for further computations\n                # for convenience only we store `Ms[0]=(sefl-lI)^0=I`\n                # so the index is the same as the power for all further Ms entries\n                # We also store the vectors that span these kernels (Ns[0] = [])\n                # and also their dimensions `a_s`\n                # this is mainly done for debugging since the number of blocks of a given size\n                # can be computed from the a_s, in order to check our result which is obtained simpler\n                # by counting the number of Jordan chains for `a` given `s`\n                # `a_0` is `dim(Kernel(Ms[0]) = dim (Kernel(I)) = 0` since `I` is regular\n\n                l_jordan_chains={}\n                chain_vectors=[]\n                Ms = [I]\n                Ns = [[]]\n                a = [0]\n                smax = 0\n                M_new = Ms[-1]*M\n                Ns_new = M_new.nullspace()\n                a_new = len(Ns_new)\n                Ms.append(M_new)\n                Ns.append(Ns_new)\n                while a_new > a[-1]:  # as long as the nullspaces increase compute further powers\n                    a.append(a_new)\n                    M_new = Ms[-1]*M\n                    Ns_new = M_new.nullspace()\n                    a_new=len(Ns_new)\n                    Ms.append(M_new)\n                    Ns.append(Ns_new)\n                    smax += 1\n\n                # We now have `Ms[-1]=((self-l*I)**s)=Z=0`.\n                # We also know the size of the biggest Jordan block\n                # associated with `l` to be `s`.\n                # Now let us proceed with the computation of the associate part of the transformation matrix `P`.\n                # We already know the kernel (=nullspace)  `K_l` of (self-lI) which consists of the\n                # eigenvectors belonging to eigenvalue `l`.\n                # The dimension of this space is the geometric multiplicity of eigenvalue `l`.\n                # For every eigenvector ev out of `K_l`, there exists a subspace that is\n                # spanned by the Jordan chain of ev. The dimension of this subspace is\n                # represented by the length `s` of the Jordan block.\n                # The chain itself is given by `{e_0,..,e_s-1}` where:\n                # `e_k+1 =(self-lI)e_k (*)`\n                # and\n                # `e_s-1=ev`\n                # So it would be possible to start with the already known `ev` and work backwards until one\n                # reaches `e_0`. Unfortunately this can not be done by simply solving system (*) since its matrix\n                # is singular (by definition of the eigenspaces).\n                # This approach would force us a choose in every step the degree of freedom undetermined\n                # by (*). This is difficult to implement with computer algebra systems and also quite inefficient.\n                # We therefore reformulate the problem in terms of nullspaces.\n                # To do so we start from the other end and choose `e0`'s out of\n                # `E=Kernel(self-lI)^s / Kernel(self-lI)^(s-1)`\n                # Note that `Kernel(self-lI)^s = Kernel(Z) = V` (the whole vector space).\n                # So in the first step `s=smax` this restriction turns out to actually restrict nothing at all\n                # and the only remaining condition is to choose vectors in `Kernel(self-lI)^(s-1)`.\n                # Subsequently we compute `e_1=(self-lI)e_0`, `e_2=(self-lI)*e_1` and so on.\n                # The subspace `E` can have a dimension larger than one.\n                # That means that we have more than one Jordan block of size `s` for the eigenvalue `l`\n                # and as many Jordan chains (this is the case in the second example).\n                # In this case we start as many Jordan chains and have as many blocks of size `s` in the jcf.\n                # We now have all the Jordan blocks of size `s` but there might be others attached to the same\n                # eigenvalue that are smaller.\n                # So we will do the same procedure also for `s-1` and so on until 1 (the lowest possible order\n                # where the Jordan chain is of length 1 and just represented by the eigenvector).\n\n                for s in reversed(range(1, smax+1)):\n                    S = Ms[s]\n                    # We want the vectors in `Kernel((self-lI)^s)` (**),\n                    # but without those in `Kernel(self-lI)^s-1` so we will add these as additional equations\n                    # to the system formed by `S` (`S` will no longer be quadratic but this does no harm\n                    # since `S` is rank deficient).\n                    exclude_vectors = Ns[s-1]\n                    for k in range(0, a[s-1]):\n                        S = S.col_join((exclude_vectors[k]).adjoint())\n                    # We also want to exclude the vectors in the chains for the bigger blocks\n                    # that we have already computed (if there are any).\n                    # (That is why we start with the biggest s).\n\n                    ########   Implementation remark:   ########\n\n                    # Doing so for *ALL* already computed chain vectors\n                    # we actually exclude some vectors twice because they are already excluded\n                    # by the condition (**).\n                    # This happens if there are more than one blocks attached to the same eigenvalue *AND*\n                    # the current blocksize is smaller than the block whose chain vectors we exclude.\n                    # If the current block has size `s_i` and the next bigger block has size `s_i-1` then\n                    # the first `s_i-s_i-1` chainvectors of the bigger block are already excluded by (**).\n                    # The unnecassary adding of these equations could be avoided if the algorithm would\n                    # take into account the lengths of the already computed chains which are already stored\n                    # and add only the last `s` items.\n                    # However the following loop would be a good deal more nested to do so.\n                    # Since adding a linear dependent equation does not change the result,\n                    # it can harm only in terms of efficiency.\n                    # So to be sure I left it there for the moment.\n\n                    l = len(chain_vectors)\n                    if l > 0:\n                        for k in range(0, l):\n                            old = chain_vectors[k].adjoint()\n                            S = S.col_join(old)\n                    e0s = S.nullspace()\n                    # Determine the number of chain leaders which equals the number of blocks with that size.\n                    n_e0 = len(e0s)\n                    s_chains = []\n                    # s_cells=[]\n                    for i in range(0, n_e0):\n                        chain=[e0s[i]]\n                        for k in range(1, s):\n                            v = M*chain[k-1]\n                            chain.append(v)\n\n                        # We want the chain leader appear as the last of the block.\n                        chain.reverse()\n                        chain_vectors += chain\n                        s_chains.append(chain)\n                    l_jordan_chains[s] = s_chains\n            jordan_block_structures[eigenval] = l_jordan_chains\n        return jordan_block_structures"
        },
        {
          "file": "sympy/matrices/matrices.py",
          "type": "function",
          "name": "_jordan_block_structure",
          "class_name": "MatrixBase",
          "code": "def _jordan_block_structure(self):\n        # To every eigenvalue may belong `i` blocks with size s(i)\n        # and a chain of generalized eigenvectors\n        # which will be determined by the following computations:\n        # for every eigenvalue we will add a dictionary\n        # containing, for all blocks, the blocksizes and the attached chain vectors\n        # that will eventually be used to form the transformation P\n        jordan_block_structures = {}\n        _eigenvects = self.eigenvects()\n        ev = self.eigenvals()\n        if len(ev) == 0:\n            raise AttributeError(\"could not compute the eigenvalues\")\n        for eigenval, multiplicity, vects in _eigenvects:\n            l_jordan_chains={}\n            geometrical = len(vects)\n            if geometrical == multiplicity:\n                # The Jordan chains have all length 1 and consist of only one vector\n                # which is the eigenvector of course\n                chains = []\n                for v in vects:\n                    chain=[v]\n                    chains.append(chain)\n                l_jordan_chains[1] = chains\n                jordan_block_structures[eigenval] = l_jordan_chains\n            elif geometrical == 0:\n                raise MatrixError(\"Matrix has the eigen vector with geometrical multiplicity equal zero.\")\n            else:\n                # Up to now we know nothing about the sizes of the blocks of our Jordan matrix.\n                # Note that knowledge of algebraic and geometrical multiplicity\n                # will *NOT* be sufficient to determine this structure.\n                # The blocksize `s` could be defined as the minimal `k` where\n                # `kernel(self-lI)^k = kernel(self-lI)^(k+1)`\n                # The extreme case would be that k = (multiplicity-geometrical+1)\n                # but the blocks could be smaller.\n\n                # Consider for instance the following matrix\n\n                # [2 1 0 0]\n                # [0 2 1 0]\n                # [0 0 2 0]\n                # [0 0 0 2]\n\n                # which coincides with it own Jordan canonical form.\n                # It has only one eigenvalue l=2 of (algebraic) multiplicity=4.\n                # It has two eigenvectors, one belonging to the last row (blocksize 1)\n                # and one being the last part of a jordan chain of length 3 (blocksize of the first block).\n\n                # Note again that it is not not possible to obtain this from the algebraic and geometrical\n                # multiplicity alone. This only gives us an upper limit for the dimension of one of\n                # the subspaces (blocksize of according jordan block) given by\n                # max=(multiplicity-geometrical+1) which is reached for our matrix\n                # but not for\n\n                # [2 1 0 0]\n                # [0 2 0 0]\n                # [0 0 2 1]\n                # [0 0 0 2]\n\n                # although multiplicity=4 and geometrical=2 are the same for this matrix.\n\n                from sympy.matrices import MutableMatrix\n                I = MutableMatrix.eye(self.rows)\n                l = eigenval\n                M = (self-l*I)\n\n                # We will store the matrices `(self-l*I)^k` for further computations\n                # for convenience only we store `Ms[0]=(sefl-lI)^0=I`\n                # so the index is the same as the power for all further Ms entries\n                # We also store the vectors that span these kernels (Ns[0] = [])\n                # and also their dimensions `a_s`\n                # this is mainly done for debugging since the number of blocks of a given size\n                # can be computed from the a_s, in order to check our result which is obtained simpler\n                # by counting the number of Jordan chains for `a` given `s`\n                # `a_0` is `dim(Kernel(Ms[0]) = dim (Kernel(I)) = 0` since `I` is regular\n\n                l_jordan_chains={}\n                chain_vectors=[]\n                Ms = [I]\n                Ns = [[]]\n                a = [0]\n                smax = 0\n                M_new = Ms[-1]*M\n                Ns_new = M_new.nullspace()\n                a_new = len(Ns_new)\n                Ms.append(M_new)\n                Ns.append(Ns_new)\n                while a_new > a[-1]:  # as long as the nullspaces increase compute further powers\n                    a.append(a_new)\n                    M_new = Ms[-1]*M\n                    Ns_new = M_new.nullspace()\n                    a_new=len(Ns_new)\n                    Ms.append(M_new)\n                    Ns.append(Ns_new)\n                    smax += 1\n\n                # We now have `Ms[-1]=((self-l*I)**s)=Z=0`.\n                # We also know the size of the biggest Jordan block\n                # associated with `l` to be `s`.\n                # Now let us proceed with the computation of the associate part of the transformation matrix `P`.\n                # We already know the kernel (=nullspace)  `K_l` of (self-lI) which consists of the\n                # eigenvectors belonging to eigenvalue `l`.\n                # The dimension of this space is the geometric multiplicity of eigenvalue `l`.\n                # For every eigenvector ev out of `K_l`, there exists a subspace that is\n                # spanned by the Jordan chain of ev. The dimension of this subspace is\n                # represented by the length `s` of the Jordan block.\n                # The chain itself is given by `{e_0,..,e_s-1}` where:\n                # `e_k+1 =(self-lI)e_k (*)`\n                # and\n                # `e_s-1=ev`\n                # So it would be possible to start with the already known `ev` and work backwards until one\n                # reaches `e_0`. Unfortunately this can not be done by simply solving system (*) since its matrix\n                # is singular (by definition of the eigenspaces).\n                # This approach would force us a choose in every step the degree of freedom undetermined\n                # by (*). This is difficult to implement with computer algebra systems and also quite inefficient.\n                # We therefore reformulate the problem in terms of nullspaces.\n                # To do so we start from the other end and choose `e0`'s out of\n                # `E=Kernel(self-lI)^s / Kernel(self-lI)^(s-1)`\n                # Note that `Kernel(self-lI)^s = Kernel(Z) = V` (the whole vector space).\n                # So in the first step `s=smax` this restriction turns out to actually restrict nothing at all\n                # and the only remaining condition is to choose vectors in `Kernel(self-lI)^(s-1)`.\n                # Subsequently we compute `e_1=(self-lI)e_0`, `e_2=(self-lI)*e_1` and so on.\n                # The subspace `E` can have a dimension larger than one.\n                # That means that we have more than one Jordan block of size `s` for the eigenvalue `l`\n                # and as many Jordan chains (this is the case in the second example).\n                # In this case we start as many Jordan chains and have as many blocks of size `s` in the jcf.\n                # We now have all the Jordan blocks of size `s` but there might be others attached to the same\n                # eigenvalue that are smaller.\n                # So we will do the same procedure also for `s-1` and so on until 1 (the lowest possible order\n                # where the Jordan chain is of length 1 and just represented by the eigenvector).\n\n                for s in reversed(range(1, smax+1)):\n                    S = Ms[s]\n                    # We want the vectors in `Kernel((self-lI)^s)` (**),\n                    # but without those in `Kernel(self-lI)^s-1` so we will add these as additional equations\n                    # to the system formed by `S` (`S` will no longer be quadratic but this does no harm\n                    # since `S` is rank deficient).\n                    exclude_vectors = Ns[s-1]\n                    for k in range(0, a[s-1]):\n                        S = S.col_join((exclude_vectors[k]).adjoint())\n                    # We also want to exclude the vectors in the chains for the bigger blocks\n                    # that we have already computed (if there are any).\n                    # (That is why we start with the biggest s).\n\n                    ########   Implementation remark:   ########\n\n                    # Doing so for *ALL* already computed chain vectors\n                    # we actually exclude some vectors twice because they are already excluded\n                    # by the condition (**).\n                    # This happens if there are more than one blocks attached to the same eigenvalue *AND*\n                    # the current blocksize is smaller than the block whose chain vectors we exclude.\n                    # If the current block has size `s_i` and the next bigger block has size `s_i-1` then\n                    # the first `s_i-s_i-1` chainvectors of the bigger block are already excluded by (**).\n                    # The unnecassary adding of these equations could be avoided if the algorithm would\n                    # take into account the lengths of the already computed chains which are already stored\n                    # and add only the last `s` items.\n                    # However the following loop would be a good deal more nested to do so.\n                    # Since adding a linear dependent equation does not change the result,\n                    # it can harm only in terms of efficiency.\n                    # So to be sure I left it there for the moment.\n\n                    l = len(chain_vectors)\n                    if l > 0:\n                        for k in range(0, l):\n                            old = chain_vectors[k].adjoint()\n                            S = S.col_join(old)\n                    e0s = S.nullspace()\n                    # Determine the number of chain leaders which equals the number of blocks with that size.\n                    n_e0 = len(e0s)\n                    s_chains = []\n                    # s_cells=[]\n                    for i in range(0, n_e0):\n                        chain=[e0s[i]]\n                        for k in range(1, s):\n                            v = M*chain[k-1]\n                            chain.append(v)\n\n                        # We want the chain leader appear as the last of the block.\n                        chain.reverse()\n                        chain_vectors += chain\n                        s_chains.append(chain)\n                    l_jordan_chains[s] = s_chains\n            jordan_block_structures[eigenval] = l_jordan_chains\n        return jordan_block_structures"
        }
      ]
    },
    {
      "pr_number": 8548,
      "pr_title": "Issue #6988: expand_log(exp(x), force=True) = x",
      "pr_body": "This is a try to fix issue #6988. If I made some mistake just let me know, as I'm still new to sympy development.\n\n```\nIn [9]: expand_log(log(exp(x)), force=True)\nOut[9]: x\n\nIn [10]: expand_log(log(y**(x)), force=True)\nOut[10]: x\u22c5log(y)\n```\n",
      "issue_id": 6988,
      "issue_title": "expand_log(exp(x), force=True) should give x",
      "issue_body": "```\nIn [5]: expand_log(log(exp(x)), force=True)\nOut[5]:\n   \u239b x\u239e\nlog\u239d\u212f \u23a0\n\nIn [6]: expand_log(log(y**(x)), force=True)\nOut[6]: x\u22c5log(y) Issue 1799 is probably to blame.\n```\n\nOriginal issue for #6988: http://code.google.com/p/sympy/issues/detail?id=3889\nOriginal author: https://code.google.com/u/asmeurer@gmail.com/\n",
      "issue_closed_at": "2014-12-03T13:34:14Z",
      "base_commit": "e6fc53f27ee872b27bc79b96529fc4bf34d4f023",
      "changes": [
        {
          "file": "sympy/functions/elementary/exponential.py",
          "type": "function",
          "name": "_eval_expand_log",
          "class_name": "log",
          "code": "def _eval_expand_log(self, deep=True, **hints):\n        from sympy import unpolarify\n        from sympy.concrete import Sum, Product\n        force = hints.get('force', False)\n        arg = self.args[0]\n        if arg.is_Integer:\n            # remove perfect powers\n            p = perfect_power(int(arg))\n            if p is not False:\n                return p[1]*self.func(p[0])\n        elif arg.is_Mul:\n            expr = []\n            nonpos = []\n            for x in arg.args:\n                if force or x.is_positive or x.is_polar:\n                    a = self.func(x)\n                    if isinstance(a, log):\n                        expr.append(self.func(x)._eval_expand_log(**hints))\n                    else:\n                        expr.append(a)\n                elif x.is_negative:\n                    a = self.func(-x)\n                    expr.append(a)\n                    nonpos.append(S.NegativeOne)\n                else:\n                    nonpos.append(x)\n            return Add(*expr) + log(Mul(*nonpos))\n        elif arg.is_Pow:\n            if force or (arg.exp.is_real and arg.base.is_positive) or \\\n                    arg.base.is_polar:\n                b = arg.base\n                e = arg.exp\n                a = self.func(b)\n                if isinstance(a, log):\n                    return unpolarify(e) * a._eval_expand_log(**hints)\n                else:\n                    return unpolarify(e) * a\n        elif isinstance(arg, Product):\n            if arg.function.is_positive:\n                return Sum(log(arg.function), *arg.limits)\n\n        return self.func(arg)"
        }
      ]
    },
    {
      "pr_number": 12882,
      "pr_title": "Checker functions for orthogonality of coordinate system",
      "pr_body": "This PR introduce additional condition for transformation equation which must be fulfill. \r\nIn `vector` module we are dealing with orthogonal curvilinear coordinate system only, so we need to check if transformation equations are correctly defined.\r\n\r\nCloses #12852",
      "issue_id": 12852,
      "issue_title": "Vector module: make sure that the base vectors remain orthogonal",
      "issue_body": "Given a generic transformation equation, make sure that the base vectors remain orthogonal, if not, raise an exception.",
      "issue_closed_at": "2017-07-05T15:10:49Z",
      "base_commit": "c87c0fbf1223c28db8590f2591f64db75d5bdd66",
      "changes": [
        {
          "file": "sympy/vector/coordsysrect.py",
          "type": "line",
          "name": "line 4",
          "code": "from sympy.core.cache import cacheit\nfrom sympy.core import S\nfrom sympy.vector.scalar import BaseScalar\nfrom sympy import eye, trigsimp, ImmutableMatrix as Matrix, Symbol, sin, cos, sqrt, diff, Tuple\nimport sympy.vector\nfrom sympy import simplify\nfrom sympy.vector.orienters import (Orienter, AxisOrienter, BodyOrienter,"
        },
        {
          "file": "sympy/vector/coordsysrect.py",
          "type": "function",
          "name": "_connect_to_standard_cartesian",
          "class_name": "CoordSys3D",
          "code": "def _connect_to_standard_cartesian(self, curv_coord_type):\n        \"\"\"\n        Change the type of orthogonal curvilinear system. It could be done\n        by tuple of transformation equations or by choosing one of pre-defined\n        coordinate system.\n\n        Parameters\n        ==========\n\n        :param curv_coord_type: str, tuple\n\n        \"\"\"\n        if isinstance(curv_coord_type, string_types):\n            self._set_transformation_equations_mapping(curv_coord_type)\n            self._set_lame_coefficient_mapping(curv_coord_type)\n\n        elif isinstance(curv_coord_type, (tuple, list, Tuple)) and len(curv_coord_type) == 3:\n            self._transformation_eqs = curv_coord_type\n            self._h1, self._h2, self._h3 = self._calculate_lame_coefficients(curv_coord_type)\n\n        elif isinstance(curv_coord_type, (tuple, list, Tuple)) and len(curv_coord_type) == 2:\n            self._transformation_eqs = \\\n            tuple([eq.subs({curv_coord_type[0][0]: self.x,\n                            curv_coord_type[0][1]: self.y,\n                            curv_coord_type[0][2]: self.z}) for eq in curv_coord_type[1]])\n            self._h1, self._h2, self._h3 = self._calculate_lame_coefficients(self._transformation_equations())\n\n        else:\n            raise ValueError(\"Wrong set of parameter.\")"
        }
      ]
    },
    {
      "pr_number": 13437,
      "pr_title": "Fix bell(n) for n=oo, and negative/non-integer 'n'",
      "pr_body": "This PR uses commits of #9198 (maintaining ownership to original author). And tries to address the requested changes on PR #9198 .\r\nFixes #9184",
      "issue_id": 9184,
      "issue_title": "bell(n).limit(n, oo) should be oo rather than bell(oo)",
      "issue_body": "`bell(n).limit(n,oo)` should take the value infinity, but the current output is `bell(oo)`. As the Bell numbers represent the number of partitions of a set, it seems natural that `bell(oo)` should be able to be evaluated rather than be returned unevaluated. This issue is also in line with the recent fixes to the corresponding limit for the Fibonacci numbers and Lucas numbers.\n\n```\nfrom sympy import *\nn = symbols('n')\nbell(n).limit(n,oo)\n\nOutput:\nbell(oo)\n```\n\nI'm new to Sympy, so I'd appreciate the opportunity to fix this bug myself if that's alright.\n",
      "issue_closed_at": "2017-10-13T04:35:13Z",
      "base_commit": "674afc619d7f5c519b6a5393a8b0532a131e57e0",
      "changes": [
        {
          "file": "sympy/functions/combinatorial/numbers.py",
          "type": "function",
          "name": "_bell_incomplete_poly",
          "class_name": "bell",
          "code": "def _bell_incomplete_poly(n, k, symbols):\n        r\"\"\"\n        The second kind of Bell polynomials (incomplete Bell polynomials).\n\n        Calculated by recurrence formula:\n\n        .. math:: B_{n,k}(x_1, x_2, \\dotsc, x_{n-k+1}) =\n                \\sum_{m=1}^{n-k+1}\n                \\x_m \\binom{n-1}{m-1} B_{n-m,k-1}(x_1, x_2, \\dotsc, x_{n-m-k})\n\n        where\n            B_{0,0} = 1;\n            B_{n,0} = 0; for n>=1\n            B_{0,k} = 0; for k>=1\n\n        \"\"\"\n        if (n == 0) and (k == 0):\n            return S.One\n        elif (n == 0) or (k == 0):\n            return S.Zero\n        s = S.Zero\n        a = S.One\n        for m in range(1, n - k + 2):\n            s += a * bell._bell_incomplete_poly(\n                n - m, k - 1, symbols) * symbols[m - 1]\n            a = a * (n - m) / m\n        return expand_mul(s)"
        }
      ]
    }
  ]
}