{
  "original_problem": {
    "instance_id": "sympy__sympy-24152",
    "repo": "sympy/sympy",
    "created_at": "2022-10-21T13:47:03Z",
    "problem_statement": "Bug in expand of TensorProduct + Workaround + Fix\n### Error description\r\nThe expansion of a TensorProduct object stops incomplete if summands in the tensor product factors have (scalar) factors, e.g.\r\n```\r\nfrom sympy import *\r\nfrom sympy.physics.quantum import *\r\nU = Operator('U')\r\nV = Operator('V')\r\nP = TensorProduct(2*U - V, U + V)\r\nprint(P) \r\n# (2*U - V)x(U + V)\r\nprint(P.expand(tensorproduct=True)) \r\n#result: 2*Ux(U + V) - Vx(U + V) #expansion has missed 2nd tensor factor and is incomplete\r\n```\r\nThis is clearly not the expected behaviour. It also effects other functions that rely on .expand(tensorproduct=True), as e.g. qapply() .\r\n\r\n### Work around\r\nRepeat .expand(tensorproduct=True) as may times as there are tensor factors, resp. until the expanded term does no longer change. This is however only reasonable in interactive session and not in algorithms.\r\n\r\n### Code Fix\r\n.expand relies on the method TensorProduct._eval_expand_tensorproduct(). The issue arises from an inprecise check in TensorProduct._eval_expand_tensorproduct() whether a recursive call is required; it fails when the creation of a TensorProduct object returns commutative (scalar) factors up front: in that case the constructor returns a Mul(c_factors, TensorProduct(..)).\r\nI thus propose the following  code fix in TensorProduct._eval_expand_tensorproduct() in quantum/tensorproduct.py.  I have marked the four lines to be added / modified:\r\n```\r\n    def _eval_expand_tensorproduct(self, **hints):\r\n                ...\r\n                for aa in args[i].args:\r\n                    tp = TensorProduct(*args[:i] + (aa,) + args[i + 1:])\r\n                    c_part, nc_part = tp.args_cnc() #added\r\n                    if len(nc_part)==1 and isinstance(nc_part[0], TensorProduct): #modified\r\n                        nc_part = (nc_part[0]._eval_expand_tensorproduct(), ) #modified\r\n                    add_args.append(Mul(*c_part)*Mul(*nc_part)) #modified\r\n                break\r\n                ...\r\n```\r\nThe fix splits of commutative (scalar) factors from the tp returned. The TensorProduct object will be the one nc factor in nc_part (see TensorProduct.__new__ constructor), if any. Note that the constructor will return 0 if a tensor factor is 0, so there is no guarantee that tp contains a TensorProduct object (e.g. TensorProduct(U-U, U+V).\r\n\r\n\r\n\n",
    "patch": "diff --git a/sympy/physics/quantum/tensorproduct.py b/sympy/physics/quantum/tensorproduct.py\n--- a/sympy/physics/quantum/tensorproduct.py\n+++ b/sympy/physics/quantum/tensorproduct.py\n@@ -246,9 +246,12 @@ def _eval_expand_tensorproduct(self, **hints):\n             if isinstance(args[i], Add):\n                 for aa in args[i].args:\n                     tp = TensorProduct(*args[:i] + (aa,) + args[i + 1:])\n-                    if isinstance(tp, TensorProduct):\n-                        tp = tp._eval_expand_tensorproduct()\n-                    add_args.append(tp)\n+                    c_part, nc_part = tp.args_cnc()\n+                    # Check for TensorProduct object: is the one object in nc_part, if any:\n+                    # (Note: any other object type to be expanded must be added here)\n+                    if len(nc_part) == 1 and isinstance(nc_part[0], TensorProduct):\n+                        nc_part = (nc_part[0]._eval_expand_tensorproduct(), )\n+                    add_args.append(Mul(*c_part)*Mul(*nc_part))\n                 break\n \n         if add_args:\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_18465",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves operation ordering in tensor contraction, which is unrelated to the expansion logic and scalar factor handling in the current issue."
      },
      {
        "idx": 2,
        "id": "similar_17350",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about argument validation in a mathematical function, which does not relate to the recursive expansion logic in the current issue."
      },
      {
        "idx": 3,
        "id": "similar_21176",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue deals with symbolic computation errors in residue calculation, which does not share the recursive expansion or scalar factor handling aspects of the current issue."
      },
      {
        "idx": 4,
        "id": "similar_17722",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue involves input validation for matrix dimensions, which is unrelated to the recursive expansion and scalar factor handling in tensor products."
      },
      {
        "idx": 5,
        "id": "similar_10173",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about rendering high-order derivatives, which does not involve recursive expansion or scalar factor handling relevant to the current issue."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Tensor contractions are wrong",
        "issue_body": "This is essentially a generalization of #17328.\r\n\r\nThe problem in the current implementation is that contractions are handled before applications of the metric, which leads to incorrect results such as in #17328.\r\n\r\nIn `tensor/tensor.py`:\r\n```python\r\nclass Tensor(TensExpr):\r\n# ...\r\n    def _extract_data(self, replacement_dict):\r\n    # ...\r\n        if len(dum1) > 0:\r\n            indices2 = other.get_indices()\r\n            repl = {}\r\n            for p1, p2 in dum1:\r\n                repl[indices2[p2]] = -indices2[p1]\r\n            other = other.xreplace(repl).doit()\r\n            array = _TensorDataLazyEvaluator.data_contract_dum([array], dum1, len(indices2))\r\n\r\n        free_ind1 = self.get_free_indices()\r\n        free_ind2 = other.get_free_indices()\r\n\r\n        return self._match_indices_with_other_tensor(array, free_ind1, free_ind2, replacement_dict)\r\n```\r\nAnd thus, the issue is that `_TensorDataLazyEvaluator.data_contract_dum` is being called prior to `self._match_indices_with_other_tensor` (where the metric is applied).\r\n\r\nThe reason that this ordering matters is because tensor contraction is itself the abstraction of applying the metric to the tensors that represent psuedo-riemannian manifolds. In essence, it means that we must have it that ![equation](https://latex.codecogs.com/svg.latex?T^\\mu_\\mu=g_{\\mu\\nu}T^{\\mu\\nu}); however, this isn't the case here.\r\n\r\nI've tried tampering with the code above, but by the way tensors have been designed, this bug is essentially unavoidable. As a consequence, the tensor module needs to be refactored in order to get accurate results. (Also, I couldn't help but notice that the last argument to `_TensorDataLazyEvaluator.data_contract_dum` isn't used).\r\n\r\n@drybalka had mentioned that he had this sort of refactoring in the works, but based on his fork, progress seems to be slow. I think discussions should be in order for reorganizing how tensors actually represent their components in this module.",
        "issue_id": 18465,
        "pr_number": 19091,
        "pr_title": "Fixed tensor contraction problem",
        "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 #18465 \r\n\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nTensor contractions using `replace_with_arrays` would prematurely contract the data arrays before applying the metric—yielding incorrect results. The solution implemented here is a rather trivial one in that it simply separates out an existing function for doing matrix multiplication with an existing data array with the metric and utilizes it in `Tensor._extract_data` to apply the metric before dummy indices are contracted.\r\n\r\n#### Other comments\r\n\r\nThis is my first pull request with Sympy. Let me know if I should make any adjustments to my code.\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* tensor\r\n  * Fixed a bug where tensor contractions in calls to `replace_with_arrays` would fail to apply the metric.\r\n<!-- END RELEASE NOTES -->",
        "issue_closed_at": "2020-04-20T15:15:50Z",
        "base_commit": "64d28fe0534f6993695d11244ea740f783958dc8"
      },
      "summary": "### Summary:\n\nThis issue is a manifestation of a broader problem related to the order of operations in tensor contraction within the tensor module of the software. Specifically, the problem arises when contractions are computed before the application of the metric, which leads to incorrect results. This issue has been identified as a generalization of a previously reported problem (#17328).\n\n1. **Problem description in general terms**: The core issue revolves around the incorrect ordering of operations in tensor calculations. The system currently performs tensor contractions before applying the metric, which conflicts with mathematical conventions and results in incorrect tensor representations on pseudo-Riemannian manifolds.\n\n2. **Key symptoms and behaviors observed**: The primary symptom is incorrect results in tensor calculations, particularly those involving contractions and metrics. The problem manifests as erroneous tensor expressions that do not adhere to expected mathematical identities and properties.\n\n3. **Affected components or systems**: The components affected are within the `tensor/tensor.py` module, specifically in the methods responsible for extracting data and performing tensor contractions and permutations. Key functions involved include `TensExpr.recursor`, `TensExpr._match_indices_with_other_tensor`, `TensExpr.contract_and_permute`, and `TensorElement._extract_data`.\n\n4. **Potential impact or severity**: The severity of this issue is significant for users relying on accurate tensor computations, especially in mathematical and scientific applications involving pseudo-Riemannian manifolds. The incorrect calculations can lead to flawed results and interpretations, necessitating a refactor of the tensor module to ensure reliable results.\n\n5. **Relevant technical details abstracted for broader understanding**: The problem is attributed to the premature invocation of the `_TensorDataLazyEvaluator.data_contract_dum` function before the metric is applied via `self._match_indices_with_other_tensor`. This misordering disrupts the correct application of tensor contraction, a fundamental operation that requires the metric to be applied first. Additionally, the refactoring of the tensor module is suggested to resolve inherent design limitations that currently prevent a straightforward fix.\n\nOverall, this issue calls for a comprehensive reorganization of the tensor module to align its operations with mathematical conventions and improve its reliability in performing tensor calculations.",
      "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: Tensor contractions are wrong\n\nBody:\nThis is essentially a generalization of #17328.\r\n\r\nThe problem in the current implementation is that contractions are handled before applications of the metric, which leads to incorrect results such as in #17328.\r\n\r\nIn `tensor/tensor.py`:\r\n```python\r\nclass Tensor(TensExpr):\r\n# ...\r\n    def _extract_data(self, replacement_dict):\r\n    # ...\r\n        if len(dum1) > 0:\r\n            indices2 = other.get_indices()\r\n            repl = {}\r\n            for p1, p2 in dum1:\r\n                repl[indices2[p2]] = -indices2[p1]\r\n            other = other.xreplace(repl).doit()\r\n            array = _TensorDataLazyEvaluator.data_contract_dum([array], dum1, len(indices2))\r\n\r\n        free_ind1 = self.get_free_indices()\r\n        free_ind2 = other.get_free_indices()\r\n\r\n        return self._match_indices_with_other_tensor(array, free_ind1, free_ind2, replacement_dict)\r\n```\r\nAnd thus, the issue is that `_TensorDataLazyEvaluator.data_contract_dum` is being called prior to `self._match_indices_with_other_tensor` (where the metric is applied).\r\n\r\nThe reason that this ordering matters is because tensor contraction is itself the abstraction of applying the metric to the tensors that represent psuedo-riemannian manifolds. In essence, it means that we must have it that ![equation](https://latex.codecogs.com/svg.latex?T^\\mu_\\mu=g_{\\mu\\nu}T^{\\mu\\nu}); however, this isn't the case here.\r\n\r\nI've tried tampering with the code above, but by the way tensors have been designed, this bug is essentially unavoidable. As a consequence, the tensor module needs to be refactored in order to get accurate results. (Also, I couldn't help but notice that the last argument to `_TensorDataLazyEvaluator.data_contract_dum` isn't used).\r\n\r\n@drybalka had mentioned that he had this sort of refactoring in the works, but based on his fork, progress seems to be slow. I think discussions should be in order for reorganizing how tensors actually represent their components in this module.\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/tensor/tensor.py\n  function: TensExpr.recursor\n  function: TensExpr._match_indices_with_other_tensor\n  function: TensExpr.contract_and_permute\n  function: TensorElement._extract_data\n"
    },
    {
      "similar_issue": {
        "issue_title": "Should polygamma(a, b) raise NotImplementedError for noninteger (numeric) a?",
        "issue_body": "mpmath's implementation of polygamma is valid only for integer first arguments. SymPy's implementation does not care, but this leads to many issues if you actually try to do things with such objects:\r\n\r\n```\r\n>>> (I*polygamma(I, pi)).as_real_imag()\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'finite'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'extended_positive'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1308, in evalf\r\n    rf = evalf_table[x.func]\r\nKeyError: polygamma\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/eward/se2/sympy/core/mul.py\", line 798, in as_real_imag\r\n    if i.is_zero:\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 864, in _eval_is_negative\r\n    finite = self.is_finite\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 857, in _eval_is_positive\r\n    extended_positive = self.is_extended_positive\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 882, in _eval_is_extended_positive\r\n    n2 = self._eval_evalf(2)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in _eval_evalf\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in <listcomp>\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1489, in _to_mpmath\r\n    re, im, _, _ = evalf(self, prec, {})\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1314, in evalf\r\n    xe = x._eval_evalf(prec)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 590, in _eval_evalf\r\n    v = func(*args)\r\n  File \"/usr/local/lib/python3.6/dist-packages/mpmath/ctx_mp.py\", line 265, in psi\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (tanh(polygamma(I, 1))).rewrite(exp)\r\n...\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (I / polygamma(I, 4)).rewrite(exp)\r\n...\r\n    raise TypeError(\"Invalid comparison of complex %s\" % me)\r\nTypeError: Invalid comparison of complex I\r\n```",
        "issue_id": 17350,
        "pr_number": 17375,
        "pr_title": "polygamma improvements (evaluation, real and positivity determination)",
        "pr_body": "Closes #17350. Fixes #12569.\r\n\r\n#### Brief description of what is fixed or changed\r\n\r\n- Add `_eval_evalf` to prevent evaluation when the first argument is not a nonnegative integer.\r\n- Remove `_eval_is_real` since the logic was wrong.\r\n- Update `_eval_is_positive` and `_eval_is_negative` to avoid doing comparisons with `>`.\r\n\r\n#### Release Notes\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\nNO ENTRY\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-08-23T06:49:24Z",
        "base_commit": "fc6f766ab588fecbb69ad85eb01ca28b44715e5c"
      },
      "summary": "### Summary:\n\nThis issue is centered around the behavior of the `polygamma` function within the SymPy library when its first argument, `a`, is a non-integer numeric value. The primary problem is that mpmath, a dependency used by SymPy for mathematical functions, only supports the `polygamma` function with integer first arguments. SymPy's implementation does not enforce this restriction, which causes several unexpected errors when performing operations involving `polygamma` with non-integer arguments.\n\n1. **Problem Description**: The `polygamma` function in SymPy does not raise a `NotImplementedError` when the first argument is a non-integer, leading to potential errors in downstream operations. This discrepancy between SymPy and mpmath regarding argument constraints results in runtime exceptions.\n\n2. **Key Symptoms and Behaviors Observed**: Users encounter multiple errors when attempting to evaluate expressions involving `polygamma` with non-integer arguments. These include `KeyError` and `TypeError` exceptions, often stemming from failed assumptions checks and invalid type operations in the code.\n\n3. **Affected Components or Systems**: The issue primarily affects the SymPy library, specifically the `polygamma` function within the `gamma_functions.py` module. The mpmath dependency is indirectly involved because its stricter argument requirements are not mirrored in SymPy.\n\n4. **Potential Impact or Severity**: The impact is significant for users who unknowingly use non-integer arguments with `polygamma`, as it can lead to unhandled exceptions, disrupting workflows and calculations that involve symbolic manipulation of mathematical expressions.\n\n5. **Relevant Technical Details**: The errors arise from the assumptions framework in SymPy, which fails to handle certain properties for complex or non-integer inputs. Specifically, the lack of a check for integer arguments in `polygamma` leads to mpmath functions being called with invalid argument types, causing type-related exceptions.\n\nThe changes to address this issue involve modifications in the `sympy/functions/special/gamma_functions.py` file, ensuring that `polygamma` properly checks for integer first arguments and raises appropriate exceptions when invalid inputs are provided.",
      "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: Should polygamma(a, b) raise NotImplementedError for noninteger (numeric) a?\n\nBody:\nmpmath's implementation of polygamma is valid only for integer first arguments. SymPy's implementation does not care, but this leads to many issues if you actually try to do things with such objects:\r\n\r\n```\r\n>>> (I*polygamma(I, pi)).as_real_imag()\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'zero'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'finite'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 262, in getit\r\n    return self._assumptions[fact]\r\nKeyError: 'extended_positive'\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1308, in evalf\r\n    rf = evalf_table[x.func]\r\nKeyError: polygamma\r\n\r\nDuring handling of the above exception, another exception occurred:\r\n\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/home/eward/se2/sympy/core/mul.py\", line 798, in as_real_imag\r\n    if i.is_zero:\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 864, in _eval_is_negative\r\n    finite = self.is_finite\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 321, in _ask\r\n    _ask(pk, obj)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 857, in _eval_is_positive\r\n    extended_positive = self.is_extended_positive\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 266, in getit\r\n    return _ask(fact, self)\r\n  File \"/home/eward/se2/sympy/core/assumptions.py\", line 309, in _ask\r\n    a = evaluate(obj)\r\n  File \"/home/eward/se2/sympy/core/expr.py\", line 882, in _eval_is_extended_positive\r\n    n2 = self._eval_evalf(2)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in _eval_evalf\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 565, in <listcomp>\r\n    args = [arg._to_mpmath(prec + 5) for arg in self.args]\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1489, in _to_mpmath\r\n    re, im, _, _ = evalf(self, prec, {})\r\n  File \"/home/eward/se2/sympy/core/evalf.py\", line 1314, in evalf\r\n    xe = x._eval_evalf(prec)\r\n  File \"/home/eward/se2/sympy/core/function.py\", line 590, in _eval_evalf\r\n    v = func(*args)\r\n  File \"/usr/local/lib/python3.6/dist-packages/mpmath/ctx_mp.py\", line 265, in psi\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (tanh(polygamma(I, 1))).rewrite(exp)\r\n...\r\n    m = int(m)\r\nTypeError: int() argument must be a string, a bytes-like object or a number, not 'mpc'\r\n>>> (I / polygamma(I, 4)).rewrite(exp)\r\n...\r\n    raise TypeError(\"Invalid comparison of complex %s\" % me)\r\nTypeError: Invalid comparison of complex I\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/special/gamma_functions.py\n  class: polygamma\n  function: multigamma.fdiff\n  function: loggamma._eval_expand_func\n"
    },
    {
      "similar_issue": {
        "issue_title": "Incorrect residue of `x**2*cot(pi*x)/(x**4 + 1)`",
        "issue_body": "```\r\nx = Symbol('x')\r\nresidue(x**2*cot(pi*x)/(x**4 + 1), x, -sqrt(2)/2 - sqrt(2)*I/2)\r\n```\r\n~Gives `AttributeError: 'int' object has no attribute 'removeO'`~\r\nNow it gives wrong result",
        "issue_id": 21176,
        "pr_number": 21182,
        "pr_title": "Fixed the error in residue computation and added test",
        "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 #21176\r\n\r\n#### Brief description of what is fixed or changed\r\nChanged the assignment value of variable `res` in `_eval_nseries()` in mul.py because the attribute `removeO()` is only there for sympyfied expressions. `res = 0` assigned the integer equivalent of `0` in python to `res`, to which `removeO()` could not be applied. Also, code credits to @oscarbenjamin .\r\n\r\n#### Other comments\r\nAlso updated the test file.\r\n\r\n#### Release Notes\r\n\r\n<!-- Write the release notes for this release below between the BEGIN and END\r\nstatements. The basic format is a bulleted list with the name of the subpackage\r\nand the release note for this PR. For example:\r\n\r\n* solvers\r\n  * Added a new solver for logarithmic equations.\r\n\r\n* functions\r\n  * Fixed a bug with log of integers.\r\n\r\nor if no release note(s) should be included use:\r\n\r\nNO ENTRY\r\n\r\nSee https://github.com/sympy/sympy/wiki/Writing-Release-Notes for more\r\ninformation on how to write release notes. The bot will check your release\r\nnotes automatically to see if they are formatted correctly. -->\r\n\r\n<!-- BEGIN RELEASE NOTES -->\r\nNO ENTRY\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2021-06-01T05:44:42Z",
        "base_commit": "43ee3d9099b3422276ada33ebdc981a7a58498c6"
      },
      "summary": "### Summary:\nThis issue is related to the incorrect computation of mathematical residues in a symbolic computation library. The specific problem arises when calculating the residue of the expression `x**2*cot(pi*x)/(x**4 + 1)` at a complex point `-sqrt(2)/2 - sqrt(2)*I/2`. Initially, this operation resulted in an `AttributeError`, indicating that an integer object was being improperly manipulated by trying to call a method named `removeO`. After further updates, while the error was resolved, the calculation still produced an incorrect result, indicating a deeper issue in the symbolic computation routines.\n\nKey symptoms and behaviors observed include:\n- Generation of an `AttributeError` related to an unexpected method call on an integer object.\n- Subsequent incorrect calculation results even after the error was handled.\n\nAffected components or systems:\n- The symbolic computation functions within the library, particularly those related to mathematical operations such as residue computation.\n\nPotential impact or severity:\n- Users relying on accurate symbolic calculations for mathematical analysis may receive incorrect results, leading to potential errors in subsequent analyses or applications. This issue could be critical for users who depend on precise mathematical computations.\n\nRelevant technical details abstracted for broader understanding:\n- The issue involves the symbolic manipulation of mathematical expressions, particularly focusing on residue calculations at complex points.\n- The core functionality affected is within the file `sympy/core/mul.py`, specifically the function `Mul.coeff_exp`, which suggests that the underlying mathematical operation's implementation required adjustments to handle edge cases and complex evaluations correctly.",
      "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: Incorrect residue of `x**2*cot(pi*x)/(x**4 + 1)`\n\nBody:\n```\r\nx = Symbol('x')\r\nresidue(x**2*cot(pi*x)/(x**4 + 1), x, -sqrt(2)/2 - sqrt(2)*I/2)\r\n```\r\n~Gives `AttributeError: 'int' object has no attribute 'removeO'`~\r\nNow it gives wrong result\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/mul.py\n  function: Mul.coeff_exp\n"
    },
    {
      "similar_issue": {
        "issue_title": "linsolve error; ValueError: Got rows of variable lengths: [1, 3]",
        "issue_body": "Can anyone tell me if this is a bug and if there is a method to get around this please, cause it seems like the linsolve() function is broken?\r\nA similar question was asked in issue #17430 but this doesn't solve my problem when used in jupyter or qtconsole or spyder. This function would be really useful if it worked for my uni study.\r\n\r\nParameters given are: *system* in form of Ax=b and variables *c* in a tuple of Sympy Symbols\r\n![image](https://user-images.githubusercontent.com/42601907/66694509-028ba580-ed00-11e9-85db-f8e1567a5306.png)\r\n![image](https://user-images.githubusercontent.com/42601907/66694519-1505df00-ed00-11e9-9861-02ea8f1dd249.png)\r\n",
        "issue_id": 17722,
        "pr_number": 17769,
        "pr_title": "Fix linsolve  for immutable matrix",
        "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://github.com/blog/1506-closing-issues-via-pull-requests . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\nFixes #17762 \r\nFixes #17722 \r\n\r\n#### Brief description of what is fixed or changed\r\n\r\nI've fixed the type checking for `linearsolve`, and also fixed some usage of the mutability of a matrix in `gauss_jordan_solve`.\r\n\r\n#### Other comments\r\n\r\nI'd also try to check `linsolve` whether it works with matrix expressions.\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.gauss_jordan_solve` raising `ShapeError` for immutable matrices.\r\n- solvers\r\n  - Fixed `linsolve` raising errors for `ImmutableMatrix`.\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-10-21T21:12:36Z",
        "base_commit": "4c87ea3ec5a36b0d3364b9bc52f88653282bf9aa"
      },
      "summary": "### Summary:\nThis issue involves a malfunction in the `linsolve()` function of the SymPy library, which is a symbolic mathematics library in Python. The problem is characterized by a `ValueError` indicating that the function is receiving input matrices with rows of varying lengths, specifically `[1, 3]`. This error suggests an inconsistency in the dimensions of the input, which the function is unable to process. The problem is observed across various platforms including Jupyter, QtConsole, and Spyder, indicating that it is not limited to a specific environment. The affected components include the matrix-solving functionality within the SymPy library, particularly in the `linsolve` function and related matrix-solving methods like `gauss_jordan_solve`. The potential impact of this issue is significant for users who rely on symbolic solutions of linear equations for academic or research purposes, as it limits the usability of the function for solving systems of equations represented in the form Ax=b. The technical details suggest a need for ensuring that input matrices are properly formatted with consistent row lengths to avoid such errors. The patch addresses these issues by modifying functions in the `sympy/matrices/matrices.py` and `sympy/solvers/solveset.py` files to handle input validation more effectively.",
      "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: linsolve error; ValueError: Got rows of variable lengths: [1, 3]\n\nBody:\nCan anyone tell me if this is a bug and if there is a method to get around this please, cause it seems like the linsolve() function is broken?\r\nA similar question was asked in issue #17430 but this doesn't solve my problem when used in jupyter or qtconsole or spyder. This function would be really useful if it worked for my uni study.\r\n\r\nParameters given are: *system* in form of Ax=b and variables *c* in a tuple of Sympy Symbols\r\n![image](https://user-images.githubusercontent.com/42601907/66694509-028ba580-ed00-11e9-85db-f8e1567a5306.png)\r\n![image](https://user-images.githubusercontent.com/42601907/66694519-1505df00-ed00-11e9-9861-02ea8f1dd249.png)\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.gauss_jordan_solve\n  function: MatrixBase.gauss_jordan_solve\n  function: MatrixBase.gauss_jordan_solve\n\nsympy/solvers/solveset.py\n  function: linsolve\n  function: linsolve\n"
    },
    {
      "similar_issue": {
        "issue_title": "mechanics_printing module does not display 4th derivatives correctly ",
        "issue_body": "When I run the following code snippet in an IPython notebook, the 1st, 2nd, and 3rd derivatives display correctly, but the 4th derivative does not. The 4th derivative simply displays as p, rather than as \\ddddot{p}.\n\n```\n%pylab inline\n\nimport sympy.physics.mechanics.functions\n\nsympy.physics.mechanics.functions.mechanics_printing(use_latex=\"mathjax\", latex_mode=\"equation\")\n\nt = sympy.Symbol(\"t\")\np = sympy.Symbol(\"p\")(t)\n\np, p.diff(t), p.diff(t).diff(t), p.diff(t).diff(t).diff(t), p.diff(t).diff(t).diff(t).diff(t)\n```\n\nAt first glance, this behavior seems to be caused by the `_print_Derivative` function in sympy/sympy/physics/vector/printing.py not handling 4th derivatives. I'll try hacking this function locally to support 4th derivatives and report back if this works around the issue.\n\nIdeally, mechanics_printing should gracefully fall back to Leibniz notation in the case of high-order derivatives, rather than printing them incorrectly.\n",
        "issue_id": 10173,
        "pr_number": 15849,
        "pr_title": "Fixed vector derivatives printing ",
        "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://github.com/blog/1506-closing-issues-via-pull-requests . Please also\r\nwrite a comment on that issue linking back to this pull request once it is\r\nopen. -->\r\nFixes #10173\r\n\r\n#### Brief description of what is fixed or changed\r\nFixed the fourth-order printing issue.\r\n\r\nThis has been attempted in #10283 and #15022 but no unit tests were added. It wasn't clear which one of these I should base it on, but as seen, the current PR deals with higher order derivatives as well. And fixes some unused/redundant imports.\r\n\r\n#### Other comments\r\nI choose to keep two separate `if`-clauses to make the comments stand alone, while the newly added `if dot_i >= 5:` could easily have been added with the previous `if`.\r\n\r\nThe result looks different in different renders, see https://github.com/sympy/sympy/issues/14425#issuecomment-457834386 Hence, it may look a bit \"ugly\" in certain circumstances.\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* physics.vector\r\n   * printing of arbitrary order vector derivatives is fixed\r\n<!-- END RELEASE NOTES -->\r\n",
        "issue_closed_at": "2019-01-29T15:53:05Z",
        "base_commit": "1e999fc5159b830a9872b86675bc5f3692a9c1be"
      },
      "summary": "### Summary:\nThis issue pertains to the incorrect rendering of high-order derivatives, specifically the 4th derivative, in the `mechanics_printing` module of the SymPy library when used within an IPython notebook. The problem manifests as an incorrect display of the 4th derivative, which appears as a simple variable `p` instead of the expected notation (\\(\\ddddot{p}\\)). This issue is linked to the `_print_Derivative` function within the `sympy/physics/vector/printing.py` file, which does not adequately handle derivatives beyond the third order. The affected component is the derivative rendering functionality within the SymPy library's mechanics printing module. The potential impact of this issue involves misleading or incorrect outputs for users working with high-order derivatives, which could lead to misinterpretations or errors in mathematical computations or presentations. The proposed solution suggests that the module should fallback to a more universally recognized format, such as Leibniz notation, for derivatives that exceed the currently supported order, thereby maintaining accuracy and clarity in mathematical 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: mechanics_printing module does not display 4th derivatives correctly \n\nBody:\nWhen I run the following code snippet in an IPython notebook, the 1st, 2nd, and 3rd derivatives display correctly, but the 4th derivative does not. The 4th derivative simply displays as p, rather than as \\ddddot{p}.\n\n```\n%pylab inline\n\nimport sympy.physics.mechanics.functions\n\nsympy.physics.mechanics.functions.mechanics_printing(use_latex=\"mathjax\", latex_mode=\"equation\")\n\nt = sympy.Symbol(\"t\")\np = sympy.Symbol(\"p\")(t)\n\np, p.diff(t), p.diff(t).diff(t), p.diff(t).diff(t).diff(t), p.diff(t).diff(t).diff(t).diff(t)\n```\n\nAt first glance, this behavior seems to be caused by the `_print_Derivative` function in sympy/sympy/physics/vector/printing.py not handling 4th derivatives. I'll try hacking this function locally to support 4th derivatives and report back if this works around the issue.\n\nIdeally, mechanics_printing should gracefully fall back to Leibniz notation in the case of high-order derivatives, rather than printing them incorrectly.\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/physics/vector/printing.py\n  function: VectorPrettyPrinter._print_Derivative\n  function: VectorPrettyPrinter._print_Derivative\n  function: VectorPrettyPrinter._print_Derivative\n  function: VectorPrettyPrinter._print_Derivative\n"
    }
  ]
}