{
  "Selected_candidate": {
    "pr_number": 12920,
    "pr_title": "fix Piecewise assumptions",
    "pr_body": "fixes #10258\r\n",
    "issue_id": 10258,
    "issue_title": "Relational involving Piecewise evaluates incorrectly as True",
    "issue_body": "``` python\n>>> p = Piecewise((1,x<0),(0,True)); p\nPiecewise((1, x < 0), (0, True))\n>>> p > 0\nTrue  <---- should not evaluate since if x >= 0, the value of the Piecewise is 0 which is not gt 0\n```\n",
    "issue_closed_at": "2017-07-12T13:10:41Z",
    "base_commit": "3a771edb034c81957c0975ca06f0e0d51ab3741b",
    "changes": [
      {
        "file": "sympy/functions/elementary/piecewise.py",
        "type": "function",
        "name": "_eval_subs",
        "class_name": "Piecewise",
        "code": "def _eval_subs(self, old, new):\n        \"\"\"\n        Piecewise conditions may contain bool which are not of Basic type.\n        \"\"\"\n        args = list(self.args)\n        for i, (e, c) in enumerate(args):\n            if isinstance(c, bool):\n                pass\n            elif isinstance(c, Basic):\n                c = c._subs(old, new)\n            if c != False:\n                e = e._subs(old, new)\n            args[i] = e, c\n            if c == True:\n                return self.func(*args)\n\n        return self.func(*args)"
      },
      {
        "file": "sympy/functions/elementary/piecewise.py",
        "type": "function",
        "name": "_eval_template_is_attr",
        "class_name": "Piecewise",
        "code": "def _eval_template_is_attr(self, is_attr, when_multiple=None):\n        b = None\n        for expr, _ in self.args:\n            a = getattr(expr, is_attr)\n            if a is None:\n                return None\n            if b is None:\n                b = a\n            elif b is not a:\n                return when_multiple\n        return b"
      }
    ]
  },
  "Justification": "Candidate B is the most useful report as it relates to symbolic evaluation in the Sympy library, similar to the current bug involving symbolic functions. The structure of the logic and the error related to the evaluation of conditions is analogous to the output behavior observed in the CURRENT bug. Both bugs involve conditions and outputs reliant on symbolic computation. Additionally, both candidates' resolutions target evaluation issues, making insights from Candidate B relevant when debugging the evaluation of coth(log(tan(x))) in the CURRENT bug.",
  "instance_id": "sympy__sympy-13480",
  "repo": "sympy/sympy",
  "created_at": "2017-10-18T17:27:03Z",
  "problem_statement": ".subs on coth(log(tan(x))) errors for certain integral values\n    >>> from sympy import *\r\n    >>> x = Symbol('x')\r\n    >>> e = coth(log(tan(x)))\r\n    >>> print(e.subs(x, 2))\r\n    ...\r\n    File \"C:\\Users\\E\\Desktop\\sympy-master\\sympy\\functions\\elementary\\hyperbolic.py\", line 590, in eval\r\n        if cotm is S.ComplexInfinity:\r\n    NameError: name 'cotm' is not defined\r\n\r\nFails for 2, 3, 5, 6, 8, 9, 11, 12, 13, 15, 18, ... etc.\n",
  "patch": "diff --git a/sympy/functions/elementary/hyperbolic.py b/sympy/functions/elementary/hyperbolic.py\n--- a/sympy/functions/elementary/hyperbolic.py\n+++ b/sympy/functions/elementary/hyperbolic.py\n@@ -587,7 +587,7 @@ def eval(cls, arg):\n                 x, m = _peeloff_ipi(arg)\n                 if m:\n                     cothm = coth(m)\n-                    if cotm is S.ComplexInfinity:\n+                    if cothm is S.ComplexInfinity:\n                         return coth(x)\n                     else: # cothm == 0\n                         return tanh(x)\n"
}