{
    "Selected_candidate": {
        "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"
            }
        ]
    },
    "Justification": "Candidate B is the most relevant to the CURRENT bug report due to its focus on matrix functionalities, specifically the `Matrix.jordan_cells()` method. The CURRENT bug involves an issue with the `Matrix.col_insert()` method as well, indicating a structural similarity in how matrix manipulations are performed in both cases. While the specifics differ, both bugs likely share logical underpinnings in matrix operations affecting how matrices are constructed or manipulated, particularly concerning dimensions and index management. This shared context makes Candidate B's insights and resolution strategy particularly applicable for debugging the CURRENT bug."
}