{
    "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."
}