{
  "Selected_candidate": {
    "pr_number": 8654,
    "pr_title": "Fix TrigonometricFunction._eval_is_rational for rational args",
    "pr_body": "closes #8653\n",
    "issue_id": 8653,
    "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_closed_at": "2014-12-21T11:20:39Z",
    "base_commit": "2e4e90b1b0243c85949eb1633f0546466b00829f",
    "changes": [
      {
        "file": "sympy/functions/elementary/exponential.py",
        "type": "function",
        "name": "_eval_is_rational",
        "class_name": "log",
        "code": "def _eval_is_rational(self):\n        s = self.func(*self.args)\n        if s.func == self.func:\n            if (self.args[0] - 1).is_zero:\n                return True\n            if s.args[0].is_rational:\n                return False\n        else:\n            return s.is_rational"
      },
      {
        "file": "sympy/functions/elementary/exponential.py",
        "type": "function",
        "name": "_eval_is_rational",
        "class_name": "log",
        "code": "def _eval_is_rational(self):\n        s = self.func(*self.args)\n        if s.func == self.func:\n            if (self.args[0] - 1).is_zero:\n                return True\n            if s.args[0].is_rational:\n                return False\n        else:\n            return s.is_rational"
      },
      {
        "file": "sympy/functions/elementary/trigonometric.py",
        "type": "class",
        "name": "TrigonometricFunction",
        "code": "class TrigonometricFunction(Function):\n    \"\"\"Base class for trigonometric functions. \"\"\"\n\n    unbranched = True\n\n    def _eval_is_rational(self):\n        s = self.func(*self.args)\n        if s.func == self.func:\n            if s.args[0].is_rational:\n                return False\n        else:\n            return s.is_rational\n\n    def _eval_is_algebraic(self):\n        s = self.func(*self.args)\n        if s.func == self.func:\n            if self.args[0].is_nonzero and self.args[0].is_algebraic:\n                return False\n            pi_coeff = _pi_coeff(self.args[0])\n            if pi_coeff is not None and pi_coeff.is_rational:\n                return True\n        else:\n            return s.is_algebraic\n\n    def _eval_expand_complex(self, deep=True, **hints):\n        re_part, im_part = self.as_real_imag(deep=deep, **hints)\n        return re_part + im_part*S.ImaginaryUnit\n\n    def _as_real_imag(self, deep=True, **hints):\n        if self.args[0].is_real:\n            if deep:\n                hints['complex'] = False\n                return (self.args[0].expand(deep, **hints), S.Zero)\n            else:\n                return (self.args[0], S.Zero)\n        if deep:\n            re, im = self.args[0].expand(deep, **hints).as_real_imag()\n        else:\n            re, im = self.args[0].as_real_imag()\n        return (re, im)"
      }
    ]
  },
  "Justification": "Candidate E addresses assumptions in mathematical function evaluations. The evaluation issue with `sin(n)` being incorrectly marked as irrational mirrors the incorrect handling of non-disjoint cycles in the `Permutation` constructor, as both involve logical assumptions about input types and their resulting computational outputs. The nature of the fix proposed in Candidate E pertains directly to clarifying these evaluations and could shed light on handling the left-to-right application of non-disjoint cycles effectively.",
  "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"
}