{
  "instance_id": "sympy__sympy-24213",
  "repo": "sympy/sympy",
  "created_at": "2022-11-03T14:00:09Z",
  "problem_statement": "collect_factor_and_dimension does not detect equivalent dimensions in addition\nCode to reproduce:\r\n```python\r\nfrom sympy.physics import units\r\nfrom sympy.physics.units.systems.si import SI\r\n\r\nv1 = units.Quantity('v1')\r\nSI.set_quantity_dimension(v1, units.velocity)\r\nSI.set_quantity_scale_factor(v1, 2 * units.meter / units.second)\r\n\r\na1 = units.Quantity('a1')\r\nSI.set_quantity_dimension(a1, units.acceleration)\r\nSI.set_quantity_scale_factor(a1, -9.8 * units.meter / units.second**2)\r\n\r\nt1 = units.Quantity('t1')\r\nSI.set_quantity_dimension(t1, units.time)\r\nSI.set_quantity_scale_factor(t1, 5 * units.second)\r\n\r\nexpr1 = a1*t1 + v1\r\nSI._collect_factor_and_dimension(expr1)\r\n```\r\nResults in:\r\n```\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"C:\\Python\\Python310\\lib\\site-packages\\sympy\\physics\\units\\unitsystem.py\", line 179, in _collect_factor_and_dimension\r\n    raise ValueError(\r\nValueError: Dimension of \"v1\" is Dimension(velocity), but it should be Dimension(acceleration*time)\r\n```\n",
  "patch": "diff --git a/sympy/physics/units/unitsystem.py b/sympy/physics/units/unitsystem.py\n--- a/sympy/physics/units/unitsystem.py\n+++ b/sympy/physics/units/unitsystem.py\n@@ -175,7 +175,7 @@ def _collect_factor_and_dimension(self, expr):\n             for addend in expr.args[1:]:\n                 addend_factor, addend_dim = \\\n                     self._collect_factor_and_dimension(addend)\n-                if dim != addend_dim:\n+                if not self.get_dimension_system().equivalent_dims(dim, addend_dim):\n                     raise ValueError(\n                         'Dimension of \"{}\" is {}, '\n                         'but it should be {}'.format(\n",
  "similar_bug_items": [
    {
      "pr_number": 16753,
      "pr_title": "Fix Quantity._collect_factor_and_dimension for exp().",
      "pr_body": "Fixes #16751\r\n\r\nReturn `dim` instead of `dim.name` in error message of `Quantity._collect_factor_and_dimension()` to avoid error if `dim` is actually an expression, such as in `Quantity._collect_factor_and_dimension(1 - exp(u / v))`.\r\n<!-- BEGIN RELEASE NOTES -->\r\nNO ENTRY\r\n<!-- END RELEASE NOTES -->",
      "issue_id": 16751,
      "issue_title": "Bug in Quantity._collect_factor_and_dimension",
      "issue_body": "This should give an error, but it fails in the wrong place:\r\n```python\r\nfrom sympy import S, exp\r\nfrom sympy.physics.units import length, mass, Quantity\r\n\r\nu = Quantity(\"u\")\r\nv = Quantity(\"v\")\r\nu.set_dimension(length)\r\nv.set_dimension(mass)\r\nQuantity._collect_factor_and_dimension(1 - exp(u/v))\r\n```\r\nreturns:\r\n\r\n> AttributeError: 'Mul' object has no attribute 'name'\r\nThis is because the code expects a quantity but encounters an expression in the exponent.",
      "issue_closed_at": "2019-05-01T04:55:02Z",
      "base_commit": "9f6e77b6cf0025201d5d783f24236ca07f82ab99",
      "changes": [
        {
          "file": "sympy/physics/units/quantities.py",
          "type": "function",
          "name": "_collect_factor_and_dimension",
          "class_name": "Quantity",
          "code": "def _collect_factor_and_dimension(expr):\n        \"\"\"Return tuple with factor expression and dimension expression.\"\"\"\n        if isinstance(expr, Quantity):\n            return expr.scale_factor, expr.dimension\n        elif isinstance(expr, Mul):\n            factor = 1\n            dimension = Dimension(1)\n            for arg in expr.args:\n                arg_factor, arg_dim = Quantity._collect_factor_and_dimension(arg)\n                factor *= arg_factor\n                dimension *= arg_dim\n            return factor, dimension\n        elif isinstance(expr, Pow):\n            factor, dim = Quantity._collect_factor_and_dimension(expr.base)\n            exp_factor, exp_dim = Quantity._collect_factor_and_dimension(expr.exp)\n            if exp_dim.is_dimensionless:\n               exp_dim = 1\n            return factor ** exp_factor, dim ** (exp_factor * exp_dim)\n        elif isinstance(expr, Add):\n            factor, dim = Quantity._collect_factor_and_dimension(expr.args[0])\n            for addend in expr.args[1:]:\n                addend_factor, addend_dim = \\\n                    Quantity._collect_factor_and_dimension(addend)\n                if dim != addend_dim:\n                    raise ValueError(\n                        'Dimension of \"{0}\" is {1}, '\n                        'but it should be {2}'.format(\n                            addend, addend_dim.name, dim.name))\n                factor += addend_factor\n            return factor, dim\n        elif isinstance(expr, Derivative):\n            factor, dim = Quantity._collect_factor_and_dimension(expr.args[0])\n            for independent, count in expr.variable_count:\n                ifactor, idim = Quantity._collect_factor_and_dimension(independent)\n                factor /= ifactor**count\n                dim /= idim**count\n            return factor, dim\n        elif isinstance(expr, Function):\n            fds = [Quantity._collect_factor_and_dimension(\n                arg) for arg in expr.args]\n            return (expr.func(*(f[0] for f in fds)),\n                    expr.func(*(d[1] for d in fds)))\n        elif isinstance(expr, Dimension):\n            return 1, expr\n        else:\n            return expr, Dimension(1)"
        }
      ]
    },
    {
      "pr_number": 13103,
      "pr_title": "fixed cos.rewrite(sqrt) sometimes not fully rewriting",
      "pr_body": "See #13066\r\n`functions.elementary.trigonometric.cos._eval_rewrite_as_sqrt` would fail to fully rewrite `cos(pi/51)` on python 3.6 only. This turned out to be an issue with the `_fermatCoords` function which is supposed to factor 51 into fermat primes. Trigonometric expressions with these fermat primes as denominators of pi can be rewritten using squareroots.\r\n\r\nThe function uses `divmod` repeatedly to get the factors. `n` was set to the whole number result of the `divmod`. This is where the bug was, since that would mean that if `n` was not divisible by that particular factor, then `n` would still be changed to the whole number result, which usually ended up being 0, in which case the function would miss the other factors and return `False`. Or in rare cases it would have led to a false factorization.\r\n\r\nThe reason this bug only revealed itself in 3.6 is because the ordering of dicts was changed. Previously for n=51 it so happened that python ordered the dict with 17 first, then 3, which are both divisible.\r\n\r\n<!-- Please give this pull request a descriptive title. Pull requests with descriptive titles are more likely to receive reviews. Describe what you changed! A title that only references an issue number is not descriptive. -->\r\n\r\n<!-- If this pull request fixes an issue please indicate which issue by typing \"Fixes #NNNN\" below. -->\r\nFixes #13066",
      "issue_id": 13066,
      "issue_title": "cos(pi/51).rewrite(sqrt) does not fully rewrite the expression on python 3.6 (test failure)",
      "issue_body": "It currently returns `cos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2`, even though both `cos(6*pi/17)` and `sin(6*pi/17)` can be rewritten using `sqrt`s. The slow test `test_sincos_rewrite_sqrt` in test_trigonometric.py currently fails because it tests that `cos(pi/51).rewrite(sqrt)` returns the full expression in terms of `sqrt`s. I tested on python 3.4 64 bit and python 3.6 64 bit, and it only happens on 3.6, which is odd. I tried a fresh installation for 3.6 to be sure it wasn't anything I changed and it still happened.\r\n```\r\n>>> cos(pi/51).rewrite(sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n>>> cos(pi/51).rewrite(cos, sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n>>> cos(pi/51).rewrite([cos, sin], sqrt)\r\ncos(6*pi/17)/2 + sqrt(3)*sin(6*pi/17)/2\r\n```",
      "issue_closed_at": "2017-08-10T09:16:46Z",
      "base_commit": "8ff744d843f9dc78c560e61e3edc01f878d1960b",
      "changes": [
        {
          "file": "sympy/functions/elementary/trigonometric.py",
          "type": "function",
          "name": "_fermatCoords",
          "class_name": "cos",
          "code": "def _fermatCoords(n):\n            # if n can be factored in terms of Fermat primes with\n            # multiplicity of each being 1, return those primes, else\n            # False\n            from sympy import chebyshevt\n            primes = []\n            for p_i in cst_table_some:\n                n, r = divmod(n, p_i)\n                if not r:\n                    primes.append(p_i)\n                    if n == 1:\n                        return tuple(primes)\n            return False"
        }
      ]
    },
    {
      "pr_number": 8223,
      "pr_title": "Add _eval_simplify helper for AlgebraicNumber",
      "pr_body": "fixes #4401\n",
      "issue_id": 4401,
      "issue_title": "Raising complex numbers to fractional powers",
      "issue_body": "bc.. >>> simplify((3+4_I)__(Rational(3,2)))\n(3 + 4_I)**(3/2)\n\n> > > expand(_)\n> > > (3 + 4_I)_*(3/2)\n\nMathematica gives: 2 + 11 \\* I as the answer. Would be good if Sympy could do the same (so far as \nmathematics allows ;)\n\np. Original issue for \"#4401\":https://github.com/sympy/sympy/issues/4401: \"http://code.google.com/p/sympy/issues/detail?id=1302\":http://code.google.com/p/sympy/issues/detail?id=1302\n\np. Original author: \"https://code.google.com/u/111560553046880738986/\":https://code.google.com/u/111560553046880738986/\n\np. Original owner: \"https://code.google.com/u/111560553046880738986/\":https://code.google.com/u/111560553046880738986/\n",
      "issue_closed_at": "2014-11-06T01:06:09Z",
      "base_commit": "0cd829dc3e88d5b1f0fa76a73360f94d58926008",
      "changes": [
        {
          "file": "sympy/core/numbers.py",
          "type": "function",
          "name": "to_algebraic_integer",
          "class_name": "AlgebraicNumber",
          "code": "def to_algebraic_integer(self):\n        \"\"\"Convert ``self`` to an algebraic integer. \"\"\"\n        f = self.minpoly\n\n        if f.LC() == 1:\n            return self\n\n        coeff = f.LC()**(f.degree() - 1)\n        poly = f.compose(C.Poly(f.gen/f.LC()))\n\n        minpoly = poly*coeff\n        root = f.LC()*self.root\n\n        return AlgebraicNumber((minpoly, root), self.coeffs())"
        }
      ]
    },
    {
      "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)"
        }
      ]
    },
    {
      "pr_number": 19229,
      "pr_title": "Fix creation of matrix with list of ndarray",
      "pr_body": "<!-- Your title above should be a short description of what\r\nwas changed. Do not include the issue number in the title. -->\r\n\r\n#### References to other Issues or PRs\r\n<!-- If this pull request fixes an issue, write \"Fixes #NNNN\" in that exact\r\nformat, e.g. \"Fixes #1234\" (see\r\nhttps://tinyurl.com/auto-closing for more information). Also, please\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\nFixes #18268\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\n`not np.array([])` or `not np.array([1, 2])` does not work as intended.\r\nThough they recommend the usage of `ndarray.any` or `ndarray.all`, however, I find that this is not a valid way to test out the empty array because they are used for testing the zero array.\r\n\r\n#### Other comments\r\n\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below. See\r\nhttps://github.com/sympy/sympy/wiki/Writing-Release-Notes for more information\r\non how to write release notes. The bot will check your release notes\r\nautomatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\n- matrices\r\n  - Fixed matrix creation from the list containg numpy ndarray. (e.g. `Matrix([np.array([1, 2]), np.array([1, 2])])`)\r\n<!-- END RELEASE NOTES -->",
      "issue_id": 18268,
      "issue_title": "ValueError when using NumPy arrays as rows in Matrix constructor in SymPy 1.5",
      "issue_body": "Version 1.5 of the package breaks some of my code. When an iterable of NumPy arrays is used as argument to the sympy.Matrix constructor, the following exception is raised:\r\n\r\n```\r\nTraceback (most recent call last):\r\n  File \"<input>\", line 6, in <module>\r\n  File \"/Users/jan/.local/share/virtualenvs/geometer-zell7LBw/lib/python3.7/site-packages/sympy/matrices/dense.py\", line 430, in __new__\r\n    return cls._new(*args, **kwargs)\r\n  File \"/Users/jan/.local/share/virtualenvs/geometer-zell7LBw/lib/python3.7/site-packages/sympy/matrices/dense.py\", line 442, in _new\r\n    rows, cols, flat_list = cls._handle_creation_inputs(*args, **kwargs)\r\n  File \"/Users/jan/.local/share/virtualenvs/geometer-zell7LBw/lib/python3.7/site-packages/sympy/matrices/matrices.py\", line 2623, in _handle_creation_inputs\r\n    if not row:\r\nValueError: The truth value of an array with more than one element is ambiguous. Use a.any() or a.all()\r\n```\r\n\r\nThe following code works in SymPy 1.4 but not in 1.5:\r\n\r\n```python\r\nimport sympy\r\nimport numpy as np\r\n\r\nrow1 = np.array([1, 2])\r\nrow2 = np.array([3, 4])\r\nsympy.Matrix([row1, row2])\r\n```",
      "issue_closed_at": "2020-04-30T09:02:11Z",
      "base_commit": "cc48fad3149e475594b12163a523e132049b7c10",
      "changes": [
        {
          "file": "sympy/matrices/matrices.py",
          "type": "function",
          "name": "irregular",
          "class_name": "MatrixBase",
          "code": "def irregular(cls, ntop, *matrices, **kwargs):\n      \"\"\"Return a matrix filled by the given matrices which\n      are listed in order of appearance from left to right, top to\n      bottom as they first appear in the matrix. They must fill the\n      matrix completely.\n\n      Examples\n      ========\n\n      >>> from sympy import ones, Matrix\n      >>> Matrix.irregular(3, ones(2,1), ones(3,3)*2, ones(2,2)*3,\n      ...   ones(1,1)*4, ones(2,2)*5, ones(1,2)*6, ones(1,2)*7)\n      Matrix([\n        [1, 2, 2, 2, 3, 3],\n        [1, 2, 2, 2, 3, 3],\n        [4, 2, 2, 2, 5, 5],\n        [6, 6, 7, 7, 5, 5]])\n      \"\"\"\n      from sympy.core.compatibility import as_int\n      ntop = as_int(ntop)\n      # make sure we are working with explicit matrices\n      b = [i.as_explicit() if hasattr(i, 'as_explicit') else i\n          for i in matrices]\n      q = list(range(len(b)))\n      dat = [i.rows for i in b]\n      active = [q.pop(0) for _ in range(ntop)]\n      cols = sum([b[i].cols for i in active])\n      rows = []\n      while any(dat):\n          r = []\n          for a, j in enumerate(active):\n              r.extend(b[j][-dat[j], :])\n              dat[j] -= 1\n              if dat[j] == 0 and q:\n                  active[a] = q.pop(0)\n          if len(r) != cols:\n            raise ValueError(filldedent('''\n                Matrices provided do not appear to fill\n                the space completely.'''))\n          rows.append(r)\n      return cls._new(rows)"
        },
        {
          "file": "sympy/matrices/matrices.py",
          "type": "function",
          "name": "_handle_creation_inputs",
          "class_name": "MatrixBase",
          "code": "def _handle_creation_inputs(cls, *args, **kwargs):\n        \"\"\"Return the number of rows, cols and flat matrix elements.\n\n        Examples\n        ========\n\n        >>> from sympy import Matrix, I\n\n        Matrix can be constructed as follows:\n\n        * from a nested list of iterables\n\n        >>> Matrix( ((1, 2+I), (3, 4)) )\n        Matrix([\n        [1, 2 + I],\n        [3,     4]])\n\n        * from un-nested iterable (interpreted as a column)\n\n        >>> Matrix( [1, 2] )\n        Matrix([\n        [1],\n        [2]])\n\n        * from un-nested iterable with dimensions\n\n        >>> Matrix(1, 2, [1, 2] )\n        Matrix([[1, 2]])\n\n        * from no arguments (a 0 x 0 matrix)\n\n        >>> Matrix()\n        Matrix(0, 0, [])\n\n        * from a rule\n\n        >>> Matrix(2, 2, lambda i, j: i/(j + 1) )\n        Matrix([\n        [0,   0],\n        [1, 1/2]])\n\n        See Also\n        ========\n        irregular - filling a matrix with irregular blocks\n        \"\"\"\n        from sympy.matrices.sparse import SparseMatrix\n        from sympy.matrices.expressions.matexpr import MatrixSymbol\n        from sympy.matrices.expressions.blockmatrix import BlockMatrix\n        from sympy.utilities.iterables import reshape\n\n        flat_list = None\n\n        if len(args) == 1:\n            # Matrix(SparseMatrix(...))\n            if isinstance(args[0], SparseMatrix):\n                return args[0].rows, args[0].cols, flatten(args[0].tolist())\n\n            # Matrix(Matrix(...))\n            elif isinstance(args[0], MatrixBase):\n                return args[0].rows, args[0].cols, args[0]._mat\n\n            # Matrix(MatrixSymbol('X', 2, 2))\n            elif isinstance(args[0], Basic) and args[0].is_Matrix:\n                return args[0].rows, args[0].cols, args[0].as_explicit()._mat\n\n            elif isinstance(args[0], mp.matrix):\n                M = args[0]\n                flat_list = [cls._sympify(x) for x in M]\n                return M.rows, M.cols, flat_list\n\n            # Matrix(numpy.ones((2, 2)))\n            elif hasattr(args[0], \"__array__\"):\n                # NumPy array or matrix or some other object that implements\n                # __array__. So let's first use this method to get a\n                # numpy.array() and then make a python list out of it.\n                arr = args[0].__array__()\n                if len(arr.shape) == 2:\n                    rows, cols = arr.shape[0], arr.shape[1]\n                    flat_list = [cls._sympify(i) for i in arr.ravel()]\n                    return rows, cols, flat_list\n                elif len(arr.shape) == 1:\n                    rows, cols = arr.shape[0], 1\n                    flat_list = [cls.zero] * rows\n                    for i in range(len(arr)):\n                        flat_list[i] = cls._sympify(arr[i])\n                    return rows, cols, flat_list\n                else:\n                    raise NotImplementedError(\n                        \"SymPy supports just 1D and 2D matrices\")\n\n            # Matrix([1, 2, 3]) or Matrix([[1, 2], [3, 4]])\n            elif is_sequence(args[0]) \\\n                    and not isinstance(args[0], DeferredVector):\n                dat = list(args[0])\n                ismat = lambda i: isinstance(i, MatrixBase) and (\n                    evaluate or\n                    isinstance(i, BlockMatrix) or\n                    isinstance(i, MatrixSymbol))\n                raw = lambda i: is_sequence(i) and not ismat(i)\n                evaluate = kwargs.get('evaluate', True)\n                if evaluate:\n                    def do(x):\n                        # make Block and Symbol explicit\n                        if isinstance(x, (list, tuple)):\n                            return type(x)([do(i) for i in x])\n                        if isinstance(x, BlockMatrix) or \\\n                                isinstance(x, MatrixSymbol) and \\\n                                all(_.is_Integer for _ in x.shape):\n                            return x.as_explicit()\n                        return x\n                    dat = do(dat)\n\n                if dat == [] or dat == [[]]:\n                    rows = cols = 0\n                    flat_list = []\n                elif not any(raw(i) or ismat(i) for i in dat):\n                    # a column as a list of values\n                    flat_list = [cls._sympify(i) for i in dat]\n                    rows = len(flat_list)\n                    cols = 1 if rows else 0\n                elif evaluate and all(ismat(i) for i in dat):\n                    # a column as a list of matrices\n                    ncol = {i.cols for i in dat if any(i.shape)}\n                    if ncol:\n                        if len(ncol) != 1:\n                            raise ValueError('mismatched dimensions')\n                        flat_list = [_ for i in dat for r in i.tolist() for _ in r]\n                        cols = ncol.pop()\n                        rows = len(flat_list)//cols\n                    else:\n                        rows = cols = 0\n                        flat_list = []\n                elif evaluate and any(ismat(i) for i in dat):\n                    ncol = set()\n                    flat_list = []\n                    for i in dat:\n                        if ismat(i):\n                            flat_list.extend(\n                                [k for j in i.tolist() for k in j])\n                            if any(i.shape):\n                                ncol.add(i.cols)\n                        elif raw(i):\n                            if i:\n                                ncol.add(len(i))\n                                flat_list.extend(i)\n                        else:\n                            ncol.add(1)\n                            flat_list.append(i)\n                        if len(ncol) > 1:\n                            raise ValueError('mismatched dimensions')\n                    cols = ncol.pop()\n                    rows = len(flat_list)//cols\n                else:\n                    # list of lists; each sublist is a logical row\n                    # which might consist of many rows if the values in\n                    # the row are matrices\n                    flat_list = []\n                    ncol = set()\n                    rows = cols = 0\n                    for row in dat:\n                        if not is_sequence(row) and \\\n                                not getattr(row, 'is_Matrix', False):\n                            raise ValueError('expecting list of lists')\n                        if not row:\n                            continue\n                        if evaluate and all(ismat(i) for i in row):\n                            r, c, flatT = cls._handle_creation_inputs(\n                                [i.T for i in row])\n                            T = reshape(flatT, [c])\n                            flat = [T[i][j] for j in range(c) for i in range(r)]\n                            r, c = c, r\n                        else:\n                            r = 1\n                            if getattr(row, 'is_Matrix', False):\n                                c = 1\n                                flat = [row]\n                            else:\n                                c = len(row)\n                                flat = [cls._sympify(i) for i in row]\n                        ncol.add(c)\n                        if len(ncol) > 1:\n                            raise ValueError('mismatched dimensions')\n                        flat_list.extend(flat)\n                        rows += r\n                    cols = ncol.pop() if ncol else 0\n\n        elif len(args) == 3:\n            rows = as_int(args[0])\n            cols = as_int(args[1])\n\n            if rows < 0 or cols < 0:\n                raise ValueError(\"Cannot create a {} x {} matrix. \"\n                                 \"Both dimensions must be positive\".format(rows, cols))\n\n            # Matrix(2, 2, lambda i, j: i+j)\n            if len(args) == 3 and isinstance(args[2], Callable):\n                op = args[2]\n                flat_list = []\n                for i in range(rows):\n                    flat_list.extend(\n                        [cls._sympify(op(cls._sympify(i), cls._sympify(j)))\n                         for j in range(cols)])\n\n            # Matrix(2, 2, [1, 2, 3, 4])\n            elif len(args) == 3 and is_sequence(args[2]):\n                flat_list = args[2]\n                if len(flat_list) != rows * cols:\n                    raise ValueError(\n                        'List length should be equal to rows*columns')\n                flat_list = [cls._sympify(i) for i in flat_list]\n\n\n        # Matrix()\n        elif len(args) == 0:\n            # Empty Matrix\n            rows = cols = 0\n            flat_list = []\n\n        if flat_list is None:\n            raise TypeError(filldedent('''\n                Data type not understood; expecting list of lists\n                or lists of values.'''))\n\n        return rows, cols, flat_list"
        },
        {
          "file": "sympy/matrices/matrices.py",
          "type": "function",
          "name": "do",
          "class_name": "MatrixBase",
          "code": "def do(x):\n                        # make Block and Symbol explicit\n                        if isinstance(x, (list, tuple)):\n                            return type(x)([do(i) for i in x])\n                        if isinstance(x, BlockMatrix) or \\\n                                isinstance(x, MatrixSymbol) and \\\n                                all(_.is_Integer for _ in x.shape):\n                            return x.as_explicit()\n                        return x"
        }
      ]
    }
  ]
}