{
  "Selected_candidate": {
    "pr_number": 8225,
    "pr_title": "Print Limit arrows with unicode",
    "pr_body": "```\nIn [1]: Limit(sin(x)/x, x, 0)\nOut[1]: \n     sin(x)\n lim ──────\nx─→0⁺  x   \n```\n",
    "issue_id": 5255,
    "issue_title": "Limit pretty print bug",
    "issue_body": "```\nReported by Aaron in issue 5099 :\n\nIn [24]: Limit(x, x, 1, dir='-')\nOut[24]: \nlim x\nx->1 \n\nShould be\n\nIn [24]: Limit(x, x, 1, dir='-')\nOut[24]: \n lim x\n    - \nx->1  \n\nAnd assumedly it is possible to create a better looking arrow using unicode (?)\n```\n\nOriginal issue for #5255: http://code.google.com/p/sympy/issues/detail?id=2156\nOriginal author: https://code.google.com/u/117997262464115802198/\nReferenced issues: #5099\nOriginal owner: https://code.google.com/u/asmeurer@gmail.com/\n",
    "issue_closed_at": "2014-10-16T08:42:21Z",
    "base_commit": "a40682899bfb540dd8419c5031997cd881dcd426",
    "changes": [
      {
        "file": "sympy/printing/pretty/pretty.py",
        "type": "function",
        "name": "_print_Limit",
        "class_name": "PrettyPrinter",
        "code": "def _print_Limit(self, l):\n        e, z, z0, dir = l.args\n\n        E = self._print(e)\n        Lim = prettyForm('lim')\n\n        LimArg = self._print(z)\n        LimArg = prettyForm(*LimArg.right('->'))\n        LimArg = prettyForm(*LimArg.right(self._print(z0)))\n\n        if z0 in (S.Infinity, S.NegativeInfinity):\n            dir = \"\"\n        else:\n            if self._use_unicode:\n                dir = u('\\u207A') if str(dir) == \"+\" else u('\\u207B')\n\n        LimArg = prettyForm(*LimArg.right(self._print(dir)))\n\n        Lim = prettyForm(*Lim.below(LimArg))\n        Lim = prettyForm(*Lim.right(E))\n\n        return Lim"
      }
    ]
  },
  "Justification": "Candidate B is most helpful because it directly involves the `Limit` function, where the CURRENT bug is also related to limits. It shares structural similarity due to similar error handling within the limit outputs, which can provide insights into the treatment of infinity values and related functionalities in the code base. Even though it specifically addresses pretty printing, the patch relevance to limit usage connects it with the current problem regarding how limits are evaluated and displayed, making it a crucial reference for understanding and resolving the CURRENT bug.",
  "instance_id": "sympy__sympy-13437",
  "repo": "sympy/sympy",
  "created_at": "2017-10-12T18:21:19Z",
  "problem_statement": "bell(n).limit(n, oo) should be oo rather than bell(oo)\n`bell(n).limit(n,oo)` should take the value infinity, but the current output is `bell(oo)`. As the Bell numbers represent the number of partitions of a set, it seems natural that `bell(oo)` should be able to be evaluated rather than be returned unevaluated. This issue is also in line with the recent fixes to the corresponding limit for the Fibonacci numbers and Lucas numbers.\n\n```\nfrom sympy import *\nn = symbols('n')\nbell(n).limit(n,oo)\n\nOutput:\nbell(oo)\n```\n\nI'm new to Sympy, so I'd appreciate the opportunity to fix this bug myself if that's alright.\n\n",
  "patch": "diff --git a/sympy/functions/combinatorial/numbers.py b/sympy/functions/combinatorial/numbers.py\n--- a/sympy/functions/combinatorial/numbers.py\n+++ b/sympy/functions/combinatorial/numbers.py\n@@ -424,6 +424,15 @@ def _bell_incomplete_poly(n, k, symbols):\n \n     @classmethod\n     def eval(cls, n, k_sym=None, symbols=None):\n+        if n is S.Infinity:\n+            if k_sym is None:\n+                return S.Infinity\n+            else:\n+                raise ValueError(\"Bell polynomial is not defined\")\n+\n+        if n.is_negative or n.is_integer is False:\n+            raise ValueError(\"a non-negative integer expected\")\n+\n         if n.is_Integer and n.is_nonnegative:\n             if k_sym is None:\n                 return Integer(cls._bell(int(n)))\n"
}