{
  "Selected_candidate": {
    "pr_number": 10750,
    "pr_title": "fixed #10719: eigenvals of empty matrix raises IndexError",
    "pr_body": "Now,\n\n```\n>>> Matrix([]).eigenvals()\n{}\n```\n\nfixed #10719\n",
    "issue_id": 10719,
    "issue_title": "eigenvals of empty matrix raises IndexError",
    "issue_body": "``` python\n>>> Matrix([[]]).eigenvals()\nTraceback (most recent call last):\n[...]\nIndexError: Index out of range: a[0]\n```\n\nThis appears to be a bug, spotted by @aravindkanna in https://github.com/sympy/sympy/issues/10701#issuecomment-191355482. I'd expect `eigenvals()` of an empty matrix to return an empty collection instead of raising an indexing exception.\n",
    "issue_closed_at": "2016-03-10T16:31:44Z",
    "base_commit": "2e3f7fb8782f5d4539c8eed547308bbd8d879e2f",
    "changes": [
      {
        "file": "sympy/matrices/matrices.py",
        "type": "function",
        "name": "eigenvals",
        "class_name": "MatrixBase",
        "code": "def eigenvals(self, **flags):\n        \"\"\"Return eigen values using the berkowitz_eigenvals routine.\n\n        Since the roots routine doesn't always work well with Floats,\n        they will be replaced with Rationals before calling that\n        routine. If this is not desired, set flag ``rational`` to False.\n        \"\"\"\n        # roots doesn't like Floats, so replace them with Rationals\n        # unless the nsimplify flag indicates that this has already\n        # been done, e.g. in eigenvects\n        mat = self\n        if flags.pop('rational', True):\n            if any(v.has(Float) for v in mat):\n                mat = mat._new(mat.rows, mat.cols,\n                    [nsimplify(v, rational=True) for v in mat])\n\n        flags.pop('simplify', None)  # pop unsupported flag\n        return mat.berkowitz_eigenvals(**flags)"
      }
    ]
  },
  "Justification": "Candidate E focuses on an IndexError occurring in a matrix context, which aligns closely with the CURRENT bug report involving an IndexError in the Matrix.is_upper function. Both bugs are related to indexing issues in matrix operations, and understanding the fix for the handling of empty matrices could provide valuable insights into proper index management for the case of tall matrices. The shared context of matrix handling makes this candidate particularly relevant for debugging the CURRENT bug.",
  "instance_id": "sympy__sympy-12454",
  "repo": "sympy/sympy",
  "created_at": "2017-03-29T20:40:49Z",
  "problem_statement": "is_upper() raises IndexError for tall matrices\nThe function Matrix.is_upper raises an IndexError for a 4x2 matrix of zeros.\r\n```\r\n>>> sympy.zeros(4,2).is_upper\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"sympy/matrices/matrices.py\", line 1112, in is_upper\r\n    for i in range(1, self.rows)\r\n  File \"sympy/matrices/matrices.py\", line 1113, in <genexpr>\r\n    for j in range(i))\r\n  File \"sympy/matrices/dense.py\", line 119, in __getitem__\r\n    return self.extract(i, j)\r\n  File \"sympy/matrices/matrices.py\", line 352, in extract\r\n    colsList = [a2idx(k, self.cols) for k in colsList]\r\n  File \"sympy/matrices/matrices.py\", line 5261, in a2idx\r\n    raise IndexError(\"Index out of range: a[%s]\" % (j,))\r\nIndexError: Index out of range: a[2]\r\n```\r\nThe code for is_upper() is\r\n```\r\n        return all(self[i, j].is_zero\r\n                   for i in range(1, self.rows)\r\n                   for j in range(i))\r\n```\r\nFor a 4x2 matrix, is_upper iterates over the indices:\r\n```\r\n>>> A = sympy.zeros(4, 2)\r\n>>> print tuple([i, j] for i in range(1, A.rows) for j in range(i))\r\n([1, 0], [2, 0], [2, 1], [3, 0], [3, 1], [3, 2])\r\n```\r\nThe attempt to index the (3,2) entry appears to be the source of the error. \n",
  "patch": "diff --git a/sympy/matrices/matrices.py b/sympy/matrices/matrices.py\n--- a/sympy/matrices/matrices.py\n+++ b/sympy/matrices/matrices.py\n@@ -641,7 +641,7 @@ def _eval_is_zero(self):\n     def _eval_is_upper_hessenberg(self):\n         return all(self[i, j].is_zero\n                    for i in range(2, self.rows)\n-                   for j in range(i - 1))\n+                   for j in range(min(self.cols, (i - 1))))\n \n     def _eval_values(self):\n         return [i for i in self if not i.is_zero]\n@@ -1112,7 +1112,7 @@ def is_upper(self):\n         \"\"\"\n         return all(self[i, j].is_zero\n                    for i in range(1, self.rows)\n-                   for j in range(i))\n+                   for j in range(min(i, self.cols)))\n \n     @property\n     def is_zero(self):\n"
}