{
  "original_problem": {
    "instance_id": "sympy__sympy-12481",
    "repo": "sympy/sympy",
    "created_at": "2017-04-03T01:52:33Z",
    "problem_statement": "`Permutation` constructor fails with non-disjoint cycles\nCalling `Permutation([[0,1],[0,1]])` raises a `ValueError` instead of constructing the identity permutation.  If the cycles passed in are non-disjoint, they should be applied in left-to-right order and the resulting permutation should be returned.\r\n\r\nThis should be easy to compute.  I don't see a reason why non-disjoint cycles should be forbidden.\n",
    "patch": "diff --git a/sympy/combinatorics/permutations.py b/sympy/combinatorics/permutations.py\n--- a/sympy/combinatorics/permutations.py\n+++ b/sympy/combinatorics/permutations.py\n@@ -895,12 +895,8 @@ def __new__(cls, *args, **kwargs):\n         # counting starts from 1.\n \n         temp = flatten(args)\n-        if has_dups(temp):\n-            if is_cycle:\n-                raise ValueError('there were repeated elements; to resolve '\n-                'cycles use Cycle%s.' % ''.join([str(tuple(c)) for c in args]))\n-            else:\n-                raise ValueError('there were repeated elements.')\n+        if has_dups(temp) and not is_cycle:\n+            raise ValueError('there were repeated elements.')\n         temp = set(temp)\n \n         if not is_cycle and \\\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_12177",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves polynomial simplification, which is unrelated to handling non-disjoint cycles in permutations."
      },
      {
        "idx": 2,
        "id": "similar_8657",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about the gamma function's undefined values, which does not relate to permutation cycle handling."
      },
      {
        "idx": 3,
        "id": "similar_8138",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves default parameter behavior in matrix expressions, unrelated to permutation cycle logic."
      },
      {
        "idx": 4,
        "id": "similar_7233",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about numerical evaluation discrepancies, not applicable to permutation cycle handling."
      },
      {
        "idx": 5,
        "id": "similar_8653",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue involves trigonometric function irrationality checks, unrelated to permutation cycle handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "Wrong result with apart",
        "issue_body": "```\r\nPython 3.6.0 |Continuum Analytics, Inc.| (default, Dec 23 2016, 12:22:00) \r\nType \"copyright\", \"credits\" or \"license\" for more information.\r\n\r\nIPython 5.1.0 -- An enhanced Interactive Python.\r\n?         -> Introduction and overview of IPython's features.\r\n%quickref -> Quick reference.\r\nhelp      -> Python's own help system.\r\nobject?   -> Details about 'object', use 'object??' for extra details.\r\n\r\nIn [1]: from sympy import symbols\r\n\r\nIn [2]: a = symbols('a', real=True)\r\n\r\nIn [3]: t = symbols('t', real=True, negative=False)\r\n\r\nIn [4]: bug = a * (-t + (-t + 1) * (2 * t - 1)) / (2 * t - 1)\r\n\r\nIn [5]: bug.subs(a, 1)\r\nOut[5]: (-t + (-t + 1)*(2*t - 1))/(2*t - 1)\r\n\r\nIn [6]: bug.subs(a, 1).apart()\r\nOut[6]: -t + 1/2 - 1/(2*(2*t - 1))\r\n\r\nIn [7]: bug.subs(a, 1).apart(t)\r\nOut[7]: -t + 1/2 - 1/(2*(2*t - 1))\r\n\r\nIn [8]: bug.apart(t)\r\nOut[8]: -a*t\r\n\r\nIn [9]: import sympy; sympy.__version__\r\nOut[9]: '1.0'\r\n```",
        "issue_id": 12177,
        "pr_number": 12236,
        "pr_title": "Fixed apart() producing wrong answer",
        "pr_body": "apart() produced a wrong result when given multivariate polynomial with fractional coefficients in a result. Division was done correctly, but the domain wasn't properly converted to a field. Now the default parameter `field=True` is set explicitly before conversion to polynomial.\r\n\r\nPreviously:\r\n`In [1]: apart(x/2, y)`\r\n`Out[1]: 0`\r\n\r\nNow:\r\n`In [1]: apart(x/2, y)`\r\n`Out[1]:`\r\nx\r\n─\r\n2\r\n\r\nThis fixes #12177, #9123.",
        "issue_closed_at": "2017-03-06T12:58:04Z",
        "base_commit": "d60497958f6dea7f5e25bc41e9107a6a63694d01"
      },
      "summary": "### Summary: This issue pertains to an incorrect result when using the `apart` method in the SymPy library, specifically when applied to a symbolic expression involving polynomial division. The problem arises when the `apart` method is used on a symbolic expression that includes a polynomial with certain properties, such as having a negative term. In the reported scenario, the method fails to correctly simplify the expression when a specific symbol is substituted, leading to inconsistent and unexpected output. This issue affects the symbolic computation components of the SymPy library, particularly those related to polynomial manipulation and simplification.\n\nKey symptoms and behaviors observed include:\n- The symbolic expression `(a * (-t + (-t + 1) * (2 * t - 1))) / (2 * t - 1)` does not simplify correctly when the `apart` method is used after substituting a specific value for the variable `a`.\n- The output of `apart` differs depending on whether it is called before or after the substitution of the variable `a`.\n- The inconsistency is observed in SymPy version 1.0.\n\nThe affected component is the symbolic algebra system, particularly the polynomial manipulation capabilities in the SymPy library.\n\nThe potential impact or severity of this issue is moderate, as it affects the correctness of symbolic computations which may lead to incorrect results in mathematical analysis or scientific computation using SymPy.\n\nRelevant technical details abstracted for broader understanding include the importance of ensuring consistent behavior of symbolic manipulation methods such as `apart`, especially in the context of polynomial expressions. The issue highlights the need for thorough testing of symbolic computation libraries to ensure they handle edge cases and specific configurations of polynomial expressions correctly.\n\nChanges Summary:\n- The issue was addressed by modifying the `PolynomialRing.from_PolynomialRing` function in the `sympy/polys/domains/polynomialring.py` file, which likely involved adjustments to the handling of polynomial expressions to ensure consistent and correct simplification results.",
      "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: Wrong result with apart\n\nBody:\n```\r\nPython 3.6.0 |Continuum Analytics, Inc.| (default, Dec 23 2016, 12:22:00) \r\nType \"copyright\", \"credits\" or \"license\" for more information.\r\n\r\nIPython 5.1.0 -- An enhanced Interactive Python.\r\n?         -> Introduction and overview of IPython's features.\r\n%quickref -> Quick reference.\r\nhelp      -> Python's own help system.\r\nobject?   -> Details about 'object', use 'object??' for extra details.\r\n\r\nIn [1]: from sympy import symbols\r\n\r\nIn [2]: a = symbols('a', real=True)\r\n\r\nIn [3]: t = symbols('t', real=True, negative=False)\r\n\r\nIn [4]: bug = a * (-t + (-t + 1) * (2 * t - 1)) / (2 * t - 1)\r\n\r\nIn [5]: bug.subs(a, 1)\r\nOut[5]: (-t + (-t + 1)*(2*t - 1))/(2*t - 1)\r\n\r\nIn [6]: bug.subs(a, 1).apart()\r\nOut[6]: -t + 1/2 - 1/(2*(2*t - 1))\r\n\r\nIn [7]: bug.subs(a, 1).apart(t)\r\nOut[7]: -t + 1/2 - 1/(2*(2*t - 1))\r\n\r\nIn [8]: bug.apart(t)\r\nOut[8]: -a*t\r\n\r\nIn [9]: import sympy; sympy.__version__\r\nOut[9]: '1.0'\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/polys/domains/polynomialring.py\n  function: PolynomialRing.from_PolynomialRing\n"
    },
    {
      "similar_issue": {
        "issue_title": "gamma(x) is assumed (wrongly) to be real when x is real",
        "issue_body": "It may be that `x` is -1, for example, where `gamma` is not defined (or rather is `zoo`). So, unless it is known that `x` is not a nonpositive integer, `gamma(x).is_real` should return `None` (currently it returns `True`).\n",
        "issue_id": 8657,
        "pr_number": 8707,
        "pr_title": "Fix real assumption for gamma function.",
        "pr_body": "- [x] Updated code as suggested by Sergey.\n\n@pelegm @skirpichev \n",
        "issue_closed_at": "2014-12-31T11:14:57Z",
        "base_commit": "ed054cc55f714dab9e809036151f0ca136397604"
      },
      "summary": "### Summary: This issue pertains to the incorrect assumption about the nature of the output of the gamma function when applied to real numbers in a symbolic mathematics library. The specific problem arises when the gamma function is evaluated at real numbers that are nonpositive integers, such as -1. In such cases, the gamma function is mathematically undefined and should return a symbolic representation of an undefined value (often denoted as 'zoo' in symbolic computation contexts), rather than assuming the result is real. The current behavior incorrectly returns `True` for `gamma(x).is_real`, which misleads users into believing that the gamma function's result is real under these conditions.\n\n1. **Problem description in general terms**: The issue involves the misinterpretation of the gamma function's output when applied to certain real values, leading to incorrect assumptions about the result's reality.\n\n2. **Key symptoms and behaviors observed**: When the gamma function is evaluated at nonpositive integers, the system incorrectly indicates that the result is real, despite being undefined.\n\n3. **Affected components or systems**: The symbolic mathematics library's gamma function evaluation system, specifically in the logic determining the reality of the output.\n\n4. **Potential impact or severity**: The incorrect assumption can lead to erroneous results in symbolic computations, which could affect any applications or research relying on accurate mathematical evaluations, particularly where gamma functions at nonpositive integers are involved.\n\n5. **Relevant technical details abstracted for broader understanding**: The function `gamma(x).is_real` should not return `True` for nonpositive integers. Correct behavior would involve recognizing the undefined nature of the gamma function at these points and appropriately returning a non-real or undefined symbolic representation. The resolution involved modifying the function logic, particularly in the `loggamma._eval_conjugate` function within the `sympy/functions/special/gamma_functions.py` file.",
      "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: gamma(x) is assumed (wrongly) to be real when x is real\n\nBody:\nIt may be that `x` is -1, for example, where `gamma` is not defined (or rather is `zoo`). So, unless it is known that `x` is not a nonpositive integer, `gamma(x).is_real` should return `None` (currently it returns `True`).\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  function: loggamma._eval_conjugate\n"
    },
    {
      "similar_issue": {
        "issue_title": "MatExpr.doit: deep default should be True for Expr (and still False for MatExpr?)",
        "issue_body": "I notice `MatExpr.doit()` has deep defaulting to False.  I assume that is deliberate (forget where but recall it looked deliberate).\n\nAnyway, deep should probably still default to True for any `Expr` (i.e., non-Matrix) it encounters.  \n\nConsider the following current behaviour:\n\n```\nx = S('x')\nn = S('n')\nA = MatrixSymbol('A', n, n)\nfive = Add(2, 3, evaluate=False)\n\nf = five*x\nG = five*A\n\nf.doit()\n# gives: 5*x\n\nG.doit()\n# gives: (2 + 3)*A\n```\n\nSame for `MatPow` where I saw this.\n",
        "issue_id": 8138,
        "pr_number": 9009,
        "pr_title": "MatrixExpr: add MatPow doit(), changes to doit for MatAdd, MatMul, Trace",
        "pr_body": "I'm been looking at `doit()` support in MatrixExpr.  In particular, I'm interested in cases where these have ImmutableMatrices inside and they could be evaluated (e.g., after a substitution).\n\nHere are some fixes:\n- MatPow: added `doit()`.\n- MatPow: refactor my older `.as_explicit()` code to use the the `doit()`.\n- MatAdd: had rather ineffective `doit()`, improved.\n- MatMul: change the default from `deep=False` to `deep=True`.  I cannot find a reason for it, so I've switched it.\n- MatMul: clean up test code.\n- Trace: change the default to `deep=True`.\n\nThe `deep=True` changes might be controversial: if someone knows why it `deep=False` before, I could always revert that (and add a comment to the code!)\n\nAnyway, here is what it does:\n\n```\nIn [6]: A = Matrix([[1,2],[3,4]])\n\nIn [7]: B = Matrix([[2,3],[4,5]])\n\nIn [8]: n = Symbol('n', integer=True)\n\nIn [9]: w = MatPow(A, n) + MatMul(A, MatPow(B,2*n))\n\nIn [10]: pprint(w)\n               2⋅n           n\n⎡1  2⎤⋅⎛⎡2  3⎤⎞    + ⎛⎡1  2⎤⎞ \n⎢    ⎥ ⎜⎢    ⎥⎟      ⎜⎢    ⎥⎟ \n⎣3  4⎦ ⎝⎣4  5⎦⎠      ⎝⎣3  4⎦⎠ \n\nIn [21]: pprint(w.subs(n, 1))\n               2           1\n⎡1  2⎤⋅⎛⎡2  3⎤⎞  + ⎛⎡1  2⎤⎞ \n⎢    ⎥ ⎜⎢    ⎥⎟    ⎜⎢    ⎥⎟ \n⎣3  4⎦ ⎝⎣4  5⎦⎠    ⎝⎣3  4⎦⎠ \n\nIn [22]: pprint(w.subs(n, 1).doit())    % these fixes make this work\n⎡73   97 ⎤\n⎢        ⎥\n⎣163  215⎦\n```\n",
        "issue_closed_at": "2015-02-19T04:28:17Z",
        "base_commit": "cf171b2f088bc6985f5973972425fa0a9fc65f31"
      },
      "summary": "### Summary: This issue pertains to the behavior of the `doit()` method in the SymPy library, specifically its application to matrix expressions (`MatExpr`) versus non-matrix expressions (`Expr`). The general problem lies in the inconsistent default behavior of this method's `deep` parameter across different types of expressions. For non-matrix expressions, the `deep` parameter should default to `True`, ensuring that all sub-expressions are evaluated recursively. However, for matrix expressions, the default should remain `False`, allowing users to control the depth of evaluation explicitly.\n\nKey symptoms include the differing outputs of the `doit()` method when applied to a symbolic multiplication (`f`) versus a matrix multiplication (`G`). While the former evaluates to a simplified product (`5*x`), the latter retains its unevaluated form (`(2 + 3)*A`), suggesting a need for distinct handling based on expression type.\n\nAffected components are primarily within the `sympy.matrices.expressions` module, including functions related to matrix addition, multiplication, power, and trace operations. Specifically, these are `MatAdd._eval_trace`, `MatMul._eval_inverse`, `MatPow.shape`, and `Trace.arg`.\n\nThe potential impact of this issue is moderate, potentially affecting users who rely on consistent evaluation behavior between matrix and non-matrix expressions. This inconsistency could lead to unexpected results in symbolic computations, particularly in complex mathematical models or simulations.\n\nRelevant technical details include the need for explicit handling of the `deep` parameter within the `doit()` method, ensuring that this parameter aligns with the user's expectations for various expression types. The patch addresses these concerns by refining the method's behavior across the different affected components.",
      "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: MatExpr.doit: deep default should be True for Expr (and still False for MatExpr?)\n\nBody:\nI notice `MatExpr.doit()` has deep defaulting to False.  I assume that is deliberate (forget where but recall it looked deliberate).\n\nAnyway, deep should probably still default to True for any `Expr` (i.e., non-Matrix) it encounters.  \n\nConsider the following current behaviour:\n\n```\nx = S('x')\nn = S('n')\nA = MatrixSymbol('A', n, n)\nfive = Add(2, 3, evaluate=False)\n\nf = five*x\nG = five*A\n\nf.doit()\n# gives: 5*x\n\nG.doit()\n# gives: (2 + 3)*A\n```\n\nSame for `MatPow` where I saw this.\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/expressions/matadd.py\n  function: MatAdd._eval_trace\n\nsympy/matrices/expressions/matmul.py\n  function: MatMul._eval_inverse\n\nsympy/matrices/expressions/matpow.py\n  function: MatPow.shape\n\nsympy/matrices/expressions/trace.py\n  function: Trace.arg\n"
    },
    {
      "similar_issue": {
        "issue_title": "N(Max(0.0, n + m)) returns Max(1.0, n + m)",
        "issue_body": "```\nThe following code does not return what is expected,\n\nn = sympy.Symbol('n')\nm = sympy.Symbol('m')\na = sympy.Max(0.0, n + m)\nprint a\nprint sympy.N(a)\n\noutputs:\n>> Max(0.0, m + n)\n>> Max(1.0, m + n)\n```\n\nOriginal issue for #7233: http://code.google.com/p/sympy/issues/detail?id=4134\nOriginal author: https://code.google.com/u/100679098312105897492/\n",
        "issue_id": 7233,
        "pr_number": 7928,
        "pr_title": "give MaxMinBase an evalf routine",
        "pr_body": "Although Or, And, etc... will not have a number as an\nargument, Min and Max can. When the operations version\nof _eval_evalf is called a call to as_independent is\nmade. This creates an x (=1) that is assumed to be an\nargument of the object so Max(0,y).n() becomes Max(1, 0, y) -> Max(1, y).\nTo avoid this an evalf routine was added to handle MaxMinBase separately.\n\nfixes #7233\n",
        "issue_closed_at": "2014-08-29T23:58:03Z",
        "base_commit": "d365f932a26c28c4c57b2b9f6dddee2ca94a5c66"
      },
      "summary": "### Summary:\nThis issue pertains to a discrepancy in the behavior of a symbolic computation library, specifically SymPy, when evaluating the numerical approximation of a symbolic maximum function. The problem arises when using the `sympy.Max` function combined with the `sympy.N` function for numerical evaluation. The expected behavior is that the numerical evaluation of `Max(0.0, n + m)` should return the same symbolic structure unless `n + m` resolves to a numerical value greater than 0.0. However, the observed output erroneously returns `Max(1.0, m + n)` instead of the anticipated `Max(0.0, m + n)`, indicating an unexpected shift in the constant value from 0.0 to 1.0 during numerical evaluation.\n\nKey symptoms and behaviors include the incorrect output of the numerical evaluation, which introduces an incorrect constant into the result. This issue affects the symbolic computation component of the SymPy library, specifically the `Max` function when combined with numerical evaluation functions like `sympy.N`.\n\nThe potential impact of this issue is significant for users relying on precise symbolic and numerical computations, as it may lead to incorrect results in mathematical models, simulations, or any application that utilizes SymPy for symbolic maximum calculations.\n\nThe problem was addressed by modifying the derivative evaluation function within the SymPy library, suggesting a potential flaw in the logic handling numerical evaluation of symbolic expressions. Understanding this issue is crucial for developers and users of symbolic computation libraries to ensure accurate and reliable mathematical computations.",
      "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: N(Max(0.0, n + m)) returns Max(1.0, n + m)\n\nBody:\n```\nThe following code does not return what is expected,\n\nn = sympy.Symbol('n')\nm = sympy.Symbol('m')\na = sympy.Max(0.0, n + m)\nprint a\nprint sympy.N(a)\n\noutputs:\n>> Max(0.0, m + n)\n>> Max(1.0, m + n)\n```\n\nOriginal issue for #7233: http://code.google.com/p/sympy/issues/detail?id=4134\nOriginal author: https://code.google.com/u/100679098312105897492/\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/miscellaneous.py\n  function: MinMaxBase._eval_derivative\n"
    },
    {
      "similar_issue": {
        "issue_title": "sin(n) is assumed (wrongly) to be irrational for an integer n",
        "issue_body": "Check this:\n\n``` python\n>>> n = Symbol('n', integer=True)  # may be 0\n>>> sin(n).is_irrational\nTrue\n```\n\nwhile `sin(0)` is clearly rational.\n",
        "issue_id": 8653,
        "pr_number": 8654,
        "pr_title": "Fix TrigonometricFunction._eval_is_rational for rational args",
        "pr_body": "closes #8653\n",
        "issue_closed_at": "2014-12-21T11:20:39Z",
        "base_commit": "2e4e90b1b0243c85949eb1633f0546466b00829f"
      },
      "summary": "### Summary:\nThis issue pertains to a logical error in the SymPy library, a Python library for symbolic mathematics, specifically within the handling of trigonometric functions. The problem arises from an incorrect assumption about the irrationality of the sine function when applied to integer arguments. The incorrect behavior is observed when evaluating the irrationality property of `sin(n)` where `n` is an integer, including zero. The function incorrectly returns `True`, implying that `sin(n)` is always irrational, whereas it is rational for certain integer arguments such as zero (`sin(0)` equals zero, which is rational).\n\nKey symptoms include the incorrect return value of `True` for the `is_irrational` check on `sin(n)` for integer values of `n`, which does not align with mathematical properties where the sine of zero should clearly return a rational number. This issue affects the functionality of symbolic computation involving trigonometric functions in SymPy, particularly in logical evaluations and assumptions about number types.\n\nThe severity of the issue is moderate as it leads to incorrect mathematical conclusions in symbolic computations, which could impact any dependent calculations or logical reasoning performed using the library. This could potentially affect users relying on the accuracy of mathematical properties in their symbolic expressions.\n\nThe technical resolution involved modifications to the SymPy library, specifically in the `sympy/functions/elementary/exponential.py` and `sympy/functions/elementary/trigonometric.py` files. The resolution likely involved correcting the logical checks within the trigonometric function class and ensuring that the evaluation of rationality properties of trigonometric functions adheres to mathematical correctness for integer inputs.",
      "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: sin(n) is assumed (wrongly) to be irrational for an integer n\n\nBody:\nCheck this:\n\n``` python\n>>> n = Symbol('n', integer=True)  # may be 0\n>>> sin(n).is_irrational\nTrue\n```\n\nwhile `sin(0)` is clearly rational.\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/exponential.py\n  function: log._eval_is_rational\n  function: log._eval_is_rational\n\nsympy/functions/elementary/trigonometric.py\n  class: TrigonometricFunction\n"
    }
  ]
}