{
  "original_problem": {
    "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"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_16751",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve dimension handling logic in SymPy and require robust input validation to handle expressions correctly."
      },
      {
        "idx": 2,
        "id": "similar_13066",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about trigonometric function rewriting, unrelated to dimension handling or validation logic."
      },
      {
        "idx": 3,
        "id": "similar_4401",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue deals with complex number simplification, which is unrelated to dimension equivalence or validation."
      },
      {
        "idx": 4,
        "id": "similar_9184",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about limit evaluation for combinatorial functions, unrelated to dimension handling or validation."
      },
      {
        "idx": 5,
        "id": "similar_18268",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue involves matrix construction with NumPy arrays, unrelated to dimension handling or validation."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "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_id": 16751,
        "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_closed_at": "2019-05-01T04:55:02Z",
        "base_commit": "9f6e77b6cf0025201d5d783f24236ca07f82ab99"
      },
      "summary": "### Summary:\nThis issue pertains to a bug in the `Quantity._collect_factor_and_dimension` function within the SymPy library, specifically in the physics.units module. The problem arises when attempting to process mathematical expressions involving quantities with assigned dimensions. The function fails to handle expressions where a quantity is used within an exponent, leading to an unexpected `AttributeError`. This error occurs because the function anticipates a quantity object but encounters a mathematical expression instead, indicating a flaw in type handling or input validation within the function. \n\nKey symptoms include the function returning an `AttributeError` when it should be producing a more informative error or handling the expression correctly. The affected component is the dimension handling logic in the `sympy.physics.units.quantities` module, which is crucial for computations involving physical quantities and units. The potential impact is moderate to high, as it can disrupt any computational processes relying on dimension analysis and manipulation, potentially affecting scientific and engineering applications using the SymPy library. \n\nRelevant technical details include the need for robust input validation to differentiate between quantity objects and mathematical expressions to prevent similar issues from occurring. The fix involves updating the function logic to correctly handle or raise appropriate errors for unsupported operations involving quantities in expressions.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Bug in Quantity._collect_factor_and_dimension\n\nBody:\nThis 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.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/physics/units/quantities.py\n  function: Quantity._collect_factor_and_dimension\n"
    },
    {
      "similar_issue": {
        "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_id": 13066,
        "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_closed_at": "2017-08-10T09:16:46Z",
        "base_commit": "8ff744d843f9dc78c560e61e3edc01f878d1960b"
      },
      "summary": "### Summary:\nThis issue pertains to a problem in the SymPy library, specifically with the `rewrite` method's inability to fully express trigonometric functions in terms of square roots (`sqrt`). The problem is observed when using Python 3.6 but not in earlier versions like Python 3.4, suggesting a version-specific behavior. The issue manifests in the failure of a specific test case, `test_sincos_rewrite_sqrt`, within the `test_trigonometric.py` file, which expects the complete transformation of the expression `cos(pi/51)` into terms involving `sqrt`. However, the output remains partially expressed as trigonometric functions (`cos` and `sin`) combined with `sqrt`, indicating an incomplete rewrite process.\n\nKey symptoms include:\n- Incomplete transformation of `cos(pi/51)` into a `sqrt` expression.\n- Consistent behavior across different attempts to force the rewrite using various combinations of the `rewrite` method.\n- Test failures specifically in Python 3.6, whereas Python 3.4 does not exhibit this issue.\n\nThe affected component is the SymPy library's rewrite functionality for trigonometric expressions, particularly the `cos._fermatCoords` function within `sympy/functions/elementary/trigonometric.py`.\n\nThe potential impact is moderate as it affects the correctness of symbolic computations involving trigonometric functions in Python 3.6, which could lead to incorrect mathematical results or failed assertions in test cases.\n\nTechnical details involve the `rewrite` method not executing as expected for certain trigonometric identities, which may relate to differences in how Python 3.6 handles floating-point arithmetic or symbolic expression evaluation compared to previous versions.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: cos(pi/51).rewrite(sqrt) does not fully rewrite the expression on python 3.6 (test failure)\n\nBody:\nIt 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```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/functions/elementary/trigonometric.py\n  function: cos._fermatCoords\n"
    },
    {
      "similar_issue": {
        "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_id": 4401,
        "pr_number": 8223,
        "pr_title": "Add _eval_simplify helper for AlgebraicNumber",
        "pr_body": "fixes #4401\n",
        "issue_closed_at": "2014-11-06T01:06:09Z",
        "base_commit": "0cd829dc3e88d5b1f0fa76a73360f94d58926008"
      },
      "summary": "### Summary:\n\nThis issue pertains to the computational handling of complex numbers raised to fractional powers within the SymPy library, a Python library for symbolic mathematics. The specific problem arises when attempting to simplify expressions involving complex numbers with fractional exponents; the expected output, as calculated by Mathematica, is not reproduced by SymPy, indicating a discrepancy in the computational results between the two systems.\n\n1. **Problem description in general terms:** The software exhibits incorrect behavior when simplifying mathematical expressions that involve raising complex numbers to fractional powers. The issue is highlighted by a test case where the expected output from another mathematical software (Mathematica) is not matched by SymPy.\n\n2. **Key symptoms and behaviors observed:** When the expression `(3 + 4_I)**(3/2)` is evaluated and simplified using SymPy, the output deviates from the expected result of `2 + 11 * I`, as provided by Mathematica. This behavior indicates a potential flaw in the library's ability to correctly handle complex arithmetic involving fractional exponents.\n\n3. **Affected components or systems:** The problem specifically affects the SymPy library, particularly the components responsible for handling arithmetic operations on complex numbers and their simplification processes.\n\n4. **Potential impact or severity:** The impact of this issue could be significant for users relying on SymPy for accurate mathematical computations involving complex numbers, potentially leading to incorrect results and conclusions in academic, research, or practical applications where such calculations are necessary.\n\n5. **Relevant technical details abstracted for broader understanding:** The resolution involved modifications to the code within `sympy/core/numbers.py`, particularly within the function `AlgebraicNumber.to_algebraic_integer`. These changes aim to align the computational results of SymPy with established mathematical standards and improve its accuracy in handling complex numbers with fractional exponents.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Raising complex numbers to fractional powers\n\nBody:\nbc.. >>> 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\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/core/numbers.py\n  function: AlgebraicNumber.to_algebraic_integer\n"
    },
    {
      "similar_issue": {
        "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_id": 9184,
        "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_closed_at": "2017-10-13T04:35:13Z",
        "base_commit": "674afc619d7f5c519b6a5393a8b0532a131e57e0"
      },
      "summary": "### Summary:\nThis issue pertains to the mathematical software library Sympy, specifically involving the calculation of limits for the Bell numbers, which are used to determine the number of partitions of a set. The problem arises when attempting to evaluate the limit of the Bell number function as the input approaches infinity (`n -> oo`). Instead of returning the expected result of infinity (oo), the software incorrectly returns an unevaluated expression `bell(oo)`. This behavior is inconsistent with recent updates made to similar functions for Fibonacci and Lucas numbers, which have been corrected to output infinity for similar limit evaluations.\n\nKey symptoms include the output of `bell(oo)` when executing the `bell(n).limit(n, oo)` command, which is not the anticipated result given the mathematical properties of Bell numbers. The issue affects the Sympy library, particularly the component dealing with combinatorial number functions.\n\nThe potential impact is moderate, as it could lead to misunderstandings or incorrect results in mathematical computations or applications that rely on the proper evaluation of Bell number limits. This issue may primarily affect users who utilize Sympy for advanced combinatorial mathematics.\n\nRelevant technical details abstracted for broader understanding include the need for the Bell number function to correctly handle limit evaluations to infinity, similar to recent fixes applied to other combinatorial functions like Fibonacci and Lucas numbers. The fix involves modifications to the function implementation in the file `sympy/functions/combinatorial/numbers.py`, specifically within the method `bell._bell_incomplete_poly`.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: bell(n).limit(n, oo) should be oo rather than bell(oo)\n\nBody:\n`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\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/functions/combinatorial/numbers.py\n  function: bell._bell_incomplete_poly\n"
    },
    {
      "similar_issue": {
        "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_id": 18268,
        "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_closed_at": "2020-04-30T09:02:11Z",
        "base_commit": "cc48fad3149e475594b12163a523e132049b7c10"
      },
      "summary": "### Summary: This issue is related to a regression introduced in version 1.5 of the SymPy library, which affects the construction of matrices when using iterable NumPy arrays as input. The problem arises because the Matrix constructor attempts to evaluate the truth value of a NumPy array, which is ambiguous when the array contains more than one element. This results in a `ValueError` being raised. The key symptom observed is the failure of code that previously worked in version 1.4 of SymPy, evidenced by a traceback error message pointing to specific lines within the SymPy codebase. The affected component is the matrix handling functionality within the SymPy library, specifically in the `dense.py` and `matrices.py` modules. The potential impact of this issue is significant for users who rely on integrating NumPy arrays with SymPy matrices, as it could break existing codebases and hinder mathematical computations that leverage these libraries in tandem. The technical detail at the core of this issue is the need to properly handle the truth evaluation of multi-element arrays, which can be resolved by using methods like `a.any()` or `a.all()` to explicitly define how to interpret the array's truth value. The changes made to address this issue involve modifying functions within the SymPy codebase, specifically `MatrixBase.irregular`, `MatrixBase._handle_creation_inputs`, and `MatrixBase.do`, to ensure compatibility and correct handling of NumPy array inputs in future versions.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: ValueError when using NumPy arrays as rows in Matrix constructor in SymPy 1.5\n\nBody:\nVersion 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```\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsympy/matrices/matrices.py\n  function: MatrixBase.irregular\n  function: MatrixBase._handle_creation_inputs\n  function: MatrixBase.do\n"
    }
  ]
}